summaryrefslogtreecommitdiff
path: root/test/RegressTests.py
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2016-09-29 09:59:06 -0700
committerGitHub <noreply@github.com>2016-09-29 09:59:06 -0700
commitcd58d43228996198b5ba329f7c05109f2aaee65a (patch)
tree62166e8ec93573e1a5b6312e721fb5c24bfc18fc /test/RegressTests.py
parent258cab91ab702e82d477b41bb1c6a026c848bda5 (diff)
parent0e691e76dbd928b4aa919cbb9788c805e34937dc (diff)
downloadfork-ledger-cd58d43228996198b5ba329f7c05109f2aaee65a.tar.gz
fork-ledger-cd58d43228996198b5ba329f7c05109f2aaee65a.tar.bz2
fork-ledger-cd58d43228996198b5ba329f7c05109f2aaee65a.zip
Merge pull request #467 from schmave/win-2
Fix test harness to work with msys2
Diffstat (limited to 'test/RegressTests.py')
-rwxr-xr-xtest/RegressTests.py28
1 files changed, 25 insertions, 3 deletions
diff --git a/test/RegressTests.py b/test/RegressTests.py
index a5bab42d..58869edc 100755
--- a/test/RegressTests.py
+++ b/test/RegressTests.py
@@ -98,6 +98,13 @@ class RegressFile(object):
def run_test(self, test):
use_stdin = False
+ if sys.platform == 'win32':
+ test['command'] = test['command'].replace('/dev/null', 'nul')
+ # There is no equivalent to /dev/stdout, /dev/stderr, /dev/stdin
+ # on Windows, so skip tests that require them.
+ if '/dev/std' in test['command']:
+ harness.success()
+ return
if test['command'].find("-f ") != -1:
test['command'] = '$ledger ' + test['command']
if re.search("-f (-|/dev/stdin)(\s|$)", test['command']):
@@ -122,7 +129,16 @@ class RegressFile(object):
printed = False
index = 0
if test['output'] is not None:
- for line in unified_diff(test['output'], harness.readlines(p.stdout)):
+ process_output = harness.readlines(p.stdout)
+ expected_output = test['output']
+ if sys.platform == 'win32':
+ process_output = [l.replace('\r\n', '\n').replace('\\', '/')
+ for l in process_output]
+ # Replace \ with / in the expected output because the line above
+ # makes it impossible for the process output to have a \.
+ expected_output = [l.replace('\\', '/') for l in expected_output]
+
+ for line in unified_diff(expected_output, process_output):
index += 1
if index < 3:
continue
@@ -135,8 +151,14 @@ class RegressFile(object):
printed = False
index = 0
- if test['error'] is not None:
- for line in unified_diff(test['error'], harness.readlines(p.stderr)):
+ process_error = harness.readlines(p.stderr)
+ if test['error'] is not None or process_error is not None:
+ if test['error'] is None:
+ test['error'] = []
+ if sys.platform == 'win32':
+ process_error = [l.replace('\r\n', '\n').replace('\\', '/')
+ for l in process_error]
+ for line in unified_diff(test['error'], process_error):
index += 1
if index < 3:
continue