Tests: leave unit.log in case of error or failure.
This commit is contained in:
parent
ff9bed64da
commit
4d7f708b25
1 changed files with 21 additions and 1 deletions
22
test/unit.py
22
test/unit.py
|
@ -25,11 +25,31 @@ class TestUnit(unittest.TestCase):
|
|||
def tearDown(self):
|
||||
self.stop()
|
||||
|
||||
# detect errors and failures for current test
|
||||
|
||||
def list2reason(exc_list):
|
||||
if exc_list and exc_list[-1][0] is self:
|
||||
return exc_list[-1][1]
|
||||
|
||||
if hasattr(self, '_outcome'):
|
||||
result = self.defaultTestResult()
|
||||
self._feedErrorsToResult(result, self._outcome.errors)
|
||||
else:
|
||||
result = getattr(self, '_outcomeForDoCleanups',
|
||||
self._resultForDoCleanups)
|
||||
|
||||
success = not list2reason(result.errors) \
|
||||
and not list2reason(result.failures)
|
||||
|
||||
# check unit.log for alerts
|
||||
|
||||
with open(self.testdir + '/unit.log', 'r', encoding='utf-8',
|
||||
errors='ignore') as f:
|
||||
self._check_alerts(f.read())
|
||||
|
||||
if '--leave' not in sys.argv:
|
||||
# remove unit.log
|
||||
|
||||
if '--leave' not in sys.argv and success:
|
||||
shutil.rmtree(self.testdir)
|
||||
|
||||
def check_modules(self, *modules):
|
||||
|
|
Loading…
Reference in a new issue