dfhack/travis/run-tests.py

41 lines
1.0 KiB
Python

2018-02-04 14:00:53 -07:00
import os, subprocess, sys
MAX_TRIES = 5
dfhack = 'Dwarf Fortress.exe' if sys.platform == 'win32' else './dfhack'
test_stage = 'test_stage.txt'
def get_test_stage():
if os.path.isfile(test_stage):
return open(test_stage).read().strip()
return '0'
os.chdir(sys.argv[1])
if os.path.exists(test_stage):
os.remove(test_stage)
2019-01-02 15:34:08 -07:00
print(os.getcwd())
print(os.listdir('.'))
2018-02-04 14:00:53 -07:00
tries = 0
while True:
tries += 1
stage = get_test_stage()
print('Run #%i: stage=%s' % (tries, get_test_stage()))
if stage == 'done':
print('Done!')
os.remove(test_stage)
sys.exit(0)
elif stage == 'fail':
print('Failed!')
os.remove(test_stage)
sys.exit(1)
2018-02-04 14:00:53 -07:00
if tries > MAX_TRIES:
print('Too many tries - aborting')
sys.exit(1)
process = subprocess.Popen([dfhack], stdout=subprocess.PIPE, stderr=subprocess.PIPE, stdin=subprocess.PIPE)
process.communicate()
2019-01-02 15:34:08 -07:00
if process.returncode != 0:
print('DF exited with ' + repr(process.returncode))