summaryrefslogtreecommitdiff
path: root/test/RegressTests.py
diff options
context:
space:
mode:
Diffstat (limited to 'test/RegressTests.py')
-rwxr-xr-xtest/RegressTests.py78
1 files changed, 23 insertions, 55 deletions
diff --git a/test/RegressTests.py b/test/RegressTests.py
index 2320a83a..e59ecc50 100755
--- a/test/RegressTests.py
+++ b/test/RegressTests.py
@@ -3,26 +3,20 @@
import sys
import os
import re
-import string
import tempfile
+from string import join
from difflib import unified_diff
-from subprocess import Popen, PIPE
-ledger = sys.argv[1]
-tests = sys.argv[2]
+from LedgerHarness import LedgerHarness
+
+harness = LedgerHarness(sys.argv)
+tests = sys.argv[2]
-if not os.path.isfile(ledger):
- sys.exit(1)
if not os.path.isdir(tests) and not os.path.isfile(tests):
sys.exit(1)
-succeeded = 0
-failed = 0
-
def test_regression(test_file):
- global succeeded, failed
-
bug = open(test_file)
command = bug.readline()
@@ -40,23 +34,14 @@ def test_regression(test_file):
if command.startswith("-f - "):
use_stdin = True
- if re.search('--columns', command):
- command = ("%s" % ledger) + " --verify --args-only " + command
- else:
- command = (("%s" % ledger) +
- " --verify --args-only --columns=80 " + command)
+ command = '$ledger ' + command
else:
tempdata = tempfile.mkstemp()
- os.write(tempdata[0], string.join(data, ''))
+ os.write(tempdata[0], join(data, ''))
os.close(tempdata[0])
- if re.search('--columns', command):
- command = (("%s -f \"%s\" " % (ledger, tempdata[1])) +
- " --verify --args-only " + command)
- else:
- command = (("%s -f \"%s\" " % (ledger, tempdata[1])) +
- " --verify --args-only --columns=80 " + command)
+ command = ('$ledger -f "%s" ' % tempdata[1]) + command
output = []
while line != ">>>2\n":
@@ -74,26 +59,23 @@ def test_regression(test_file):
exitcode = int(match.group(1))
- p = Popen(command[:-1], shell=True,
- stdin=PIPE, stdout=PIPE, stderr=PIPE,
- close_fds=True)
+ p = harness.run(command, columns=(not re.search('--columns', command)))
if use_stdin:
- p.stdin.write(string.join(data))
+ p.stdin.write(join(data))
p.stdin.close()
success = True
printed = False
index = 0
- for line in unified_diff(output, p.stdout.readlines()):
+ for line in unified_diff(output, harness.readlines(p.stdout)):
index += 1
if index < 3:
continue
if not printed:
if success: print
- print "Regression failure in output from %s:" \
- % os.path.basename(test_file)
- if success: failed += 1
+ print "Regression failure in output from %s:" % \
+ os.path.basename(test_file)
success = False
printed = True
print " ", line,
@@ -101,32 +83,25 @@ def test_regression(test_file):
printed = False
index = 0
for line in unified_diff([re.sub('\$FILE', tempdata[1], line)
- for line in error],
- p.stderr.readlines()):
+ for line in error], harness.readlines(p.stderr)):
index += 1
if index < 3:
continue
if not printed:
if success: print
- print "Regression failure in error output from %s:" \
- % os.path.basename(test_file)
- if success: failed += 1
+ print "Regression failure in error output from %s:" % \
+ os.path.basename(test_file)
success = False
printed = True
print " ", line,
- if exitcode != p.wait():
- if success: print
- if success: failed += 1
- success = False
- print "Regression failure in exitcode from %s: %d (expected) != %d" \
- % (os.path.basename(test_file), exitcode, p.returncode)
-
- if success:
- succeeded += 1
- sys.stdout.write(".")
+ if exitcode == p.wait():
+ harness.success()
else:
- sys.stdout.write("E")
+ if success: print
+ print "Regression failure in exitcode from %s: %d (expected) != %d" % \
+ (os.path.basename(test_file), exitcode, p.returncode)
+ harness.failure()
if not use_stdin:
os.remove(tempdata[1])
@@ -138,11 +113,4 @@ if os.path.isdir(tests):
else:
test_regression(tests)
-print
-if succeeded > 0:
- print "OK (%d) " % succeeded,
-if failed > 0:
- print "FAILED (%d)" % failed,
-print
-
-sys.exit(failed)
+harness.exit()