diff options
Diffstat (limited to 'test')
-rwxr-xr-x | test/RegressTests.py | 222 |
1 files changed, 129 insertions, 93 deletions
diff --git a/test/RegressTests.py b/test/RegressTests.py index 48efaaa1..d5df6ced 100755 --- a/test/RegressTests.py +++ b/test/RegressTests.py @@ -16,104 +16,140 @@ tests = sys.argv[2] if not os.path.isdir(tests) and not os.path.isfile(tests): sys.exit(1) -def test_regression(test_file): - bug = open(test_file) - command = bug.readline() - - line = bug.readline() - assert "<<<\n" == line - line = bug.readline() - - data = [] - while line != ">>>1\n": - data.append(line) - line = bug.readline() - line = bug.readline() - - use_stdin = False - if command.startswith("-f - "): - use_stdin = True - - command = '$ledger ' + command - else: - tempdata = tempfile.mkstemp() - - os.write(tempdata[0], join(data, '')) - os.close(tempdata[0]) - - command = ('$ledger -f "%s" ' % tempdata[1]) + command - - output = [] - while line != ">>>2\n": - output.append(line) - line = bug.readline() - line = bug.readline() - - error = [] - while not line.startswith("==="): - error.append(line) - line = bug.readline() - - match = re.match('=== ([0-9]+)', line) - assert match - - exitcode = int(match.group(1)) - - p = harness.run(command, columns=(not re.search('--columns', command))) - - if use_stdin: - p.stdin.write(join(data)) - p.stdin.close() - - success = True - printed = False - index = 0 - 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) - success = False - printed = True - print " ", line, - - printed = False - index = 0 - for line in unified_diff([re.sub('\$FILE', tempdata[1], line) - 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) - success = False - printed = True - print " ", line, - - if exitcode == p.wait(): - if success: - harness.success() +class RegressFile: + def __init__(self, filename): + self.filename = filename + self.fd = open(self.filename) + + def is_directive(self, line): + return line == "<<<\n" or \ + line == ">>>1\n" or \ + line == ">>>2\n" or \ + line.startswith("===") + + def read_section(self): + lines = [] + line = self.fd.readline() + while not self.is_directive(line): + lines.append(line) + line = self.fd.readline() + return (lines, line) + + def read_test(self, last_test = None): + test = { + 'command': None, + 'input': None, + 'output': None, + 'error': None, + 'exitcode': None + } + if last_test: + test['input'] = last_test['input'] + + line = self.fd.readline() + while line: + if line == "<<<\n": + (test['input'], line) = self.read_section() + elif line == ">>>1\n": + (test['output'], line) = self.read_section() + elif line == ">>>2\n": + (test['error'], line) = self.read_section() + elif line.startswith("==="): + match = re.match('=== ([0-9]+)', line) + assert match + test['exitcode'] = int(match.group(1)) + return test + else: + test['command'] = line + line = self.fd.readline() + + return None + + def run_test(self, test): + use_stdin = False + if test['command'].find("-f - ") != -1: + use_stdin = True + + test['command'] = '$ledger ' + test['command'] + else: + tempdata = tempfile.mkstemp() + + os.write(tempdata[0], join(test['input'], '')) + os.close(tempdata[0]) + + test['command'] = (('$ledger -f "%s" ' % tempdata[1]) + + test['command']) + + p = harness.run(test['command'], + columns=(not re.search('--columns', test['command']))) + + if use_stdin: + p.stdin.write(join(test['input'], '')) + p.stdin.close() + + success = True + printed = False + index = 0 + for line in unified_diff(test['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(self.filename) + success = False + printed = True + print " ", line, + + printed = False + index = 0 + for line in unified_diff([re.sub('\$FILE', tempdata[1], line) + for line in test['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(self.filename) + success = False + printed = True + print " ", line, + + if test['exitcode'] == p.wait(): + if success: + harness.success() + else: + harness.failure() else: + if success: print + print "Regression failure in exitcode from %s: %d (expected) != %d" % \ + (os.path.basename(self.filename), test['exitcode'], p.returncode) harness.failure() - else: - 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]) + if not use_stdin: + os.remove(tempdata[1]) + + def run_tests(self): + test = self.read_test() + while test: + self.run_test(test) + test = self.read_test() + + def close(self): + self.fd.close() if os.path.isdir(tests): - for test in os.listdir(tests): - if re.search('\.test$', test): - test_regression(os.path.join(tests, test)) + for test_file in os.listdir(tests): + if re.search('\.test$', test_file): + entry = RegressFile(os.path.join(tests, test_file)) + entry.run_tests() + entry.close() else: - test_regression(tests) + entry = RegressFile(tests) + entry.run_tests() + entry.close() harness.exit() |