Commit e94fce89 authored by Denis Bilenko's avatar Denis Bilenko

testrunner.py: get rid of regex that can take a long time

parent 2edfdccb
...@@ -351,8 +351,6 @@ def get_failed_testcases(cursor, runid): ...@@ -351,8 +351,6 @@ def get_failed_testcases(cursor, runid):
_warning_re = re.compile('\w*warning', re.I) _warning_re = re.compile('\w*warning', re.I)
_error_re = re.compile(r'(?P<prefix>\s*)Traceback \(most recent call last\):' +
r'(\n(?P=prefix)[ \t]+[^\n]*)+\n(?P=prefix)(?P<error>[\w\.]+)')
def get_warnings(output): def get_warnings(output):
...@@ -374,7 +372,19 @@ def get_exceptions(output): ...@@ -374,7 +372,19 @@ def get_exceptions(output):
... ZeroDivisionError: integer division or modulo by zero''') ... ZeroDivisionError: integer division or modulo by zero''')
['ZeroDivisionError'] ['ZeroDivisionError']
""" """
return [x.group('error') for x in _error_re.finditer(output)] errors = []
readtb = False
for line in output.split('\n'):
if 'Traceback (most recent call last):' in line:
readtb = True
else:
if readtb:
if line[:1] == ' ':
pass
else:
errors.append(line.split(':')[0])
readtb = False
return errors
def get_warning_stats(output): def get_warning_stats(output):
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment