summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/annotate.cc3
-rwxr-xr-xtest/RegressTests.py68
2 files changed, 39 insertions, 32 deletions
diff --git a/src/annotate.cc b/src/annotate.cc
index 352690c6..093837fe 100644
--- a/src/annotate.cc
+++ b/src/annotate.cc
@@ -42,7 +42,8 @@ void annotation_t::parse(std::istream& in)
{
do {
istream_pos_type pos = in.tellg();
- assert(pos != -1);
+ if (pos == -1)
+ return;
char buf[256];
char c = peek_next_nonws(in);
diff --git a/test/RegressTests.py b/test/RegressTests.py
index b668e51f..e176f8fc 100755
--- a/test/RegressTests.py
+++ b/test/RegressTests.py
@@ -87,6 +87,12 @@ class RegressFile(object):
return test['command'] and test
+ def notify_user(self, msg, test):
+ print msg
+ print "--"
+ print test['command'],
+ print "--"
+
def run_test(self, test):
use_stdin = False
if test['command'].find("-f - ") != -1:
@@ -112,48 +118,48 @@ class RegressFile(object):
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,
+ if test['output'] is not None:
+ for line in unified_diff(test['output'], harness.readlines(p.stdout)):
+ index += 1
+ if index < 3:
+ continue
+ if not printed:
+ if success: print
+ self.notify_user("Regression failure in output from %s:" % self.filename, test)
+ 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 test['error'] is not None:
+ 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
+ self.notify_user("Regression failure in error output from %s:" % self.filename, test)
+ success = False
+ printed = True
+ print " ", line,
+
+ if not use_stdin:
+ os.remove(tempdata[1])
+
+ if test['exitcode'] is None or 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)
+ self.notify_user("Regression failure in exit code (%d (expected) != %d) from %s:"
+ % (test['exitcode'], p.returncode), test, self.filename)
harness.failure()
- if not use_stdin:
- os.remove(tempdata[1])
-
def run_tests(self):
test = self.read_test()
while test: