- start_time = time.time()
- result = unittest.TextTestRunner(verbosity=2).run(self.suite)
- end_time = time.time()
-
- if result.errors:
- self.logger.error('Number of errors in test suite - ' +
- str(len(result.errors)))
- for test, message in result.errors:
- self.logger.error(str(test) + " ERROR with " + message)
-
- if result.failures:
- self.logger.error('Number of failures in test suite - ' +
- str(len(result.failures)))
- for test, message in result.failures:
- self.logger.error(str(test) + " FAILED with " + message)
-
- if (result.errors and len(result.errors) > 0) \
- or (result.failures and len(result.failures) > 0):
- self.logger.info("%s FAILED" % self.case_name)
- self.criteria = 'FAIL'
- exit_code = TestCasesBase.TestCasesBase.EX_RUN_ERROR
- else:
- self.logger.info("%s OK" % self.case_name)
- exit_code = TestCasesBase.TestCasesBase.EX_OK
-
- self.details = {'timestart': start_time,
- 'duration': round(end_time - start_time, 1),
- 'status': self.criteria}
- return exit_code
+ try:
+ name = kwargs["name"]
+ try:
+ self.suite = unittest.TestLoader().loadTestsFromName(name)
+ except ImportError:
+ self.logger.error("Can not import %s", name)
+ return testcase.TestCase.EX_RUN_ERROR
+ except KeyError:
+ pass
+ self.start_time = time.time()
+ stream = six.StringIO()
+ result = unittest.TextTestRunner(
+ stream=stream, verbosity=2).run(self.suite)
+ self.logger.debug("\n\n%s", stream.getvalue())
+ self.stop_time = time.time()
+ self.details = {"failures": result.failures,
+ "errors": result.errors}
+ try:
+ self.result = 100 * (
+ (result.testsRun - (len(result.failures) +
+ len(result.errors))) /
+ result.testsRun)
+ return testcase.TestCase.EX_OK
+ except ZeroDivisionError:
+ self.logger.error("No test has been run")
+ return testcase.TestCase.EX_RUN_ERROR