summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorvalentin boucher <valentin.boucher@orange.com>2017-05-22 13:07:52 +0000
committerGerrit Code Review <gerrit@opnfv.org>2017-05-22 13:07:52 +0000
commit6f70bd17b238e3c931f5d575e4b8eb625dbca91d (patch)
treef4f778007b6b19755544f2158e36616a5d1e253d
parent5509d6b06cc77ecd913761b534db3951eb9777bd (diff)
parent5873cb24ff67b9f878db312d98187aaec05b5bd7 (diff)
Merge "Fully cover pytest_suite_runner.py"
-rw-r--r--functest/tests/unit/core/test_pytest_suite_runner.py42
1 files changed, 36 insertions, 6 deletions
diff --git a/functest/tests/unit/core/test_pytest_suite_runner.py b/functest/tests/unit/core/test_pytest_suite_runner.py
index 4160df03..f317cdea 100644
--- a/functest/tests/unit/core/test_pytest_suite_runner.py
+++ b/functest/tests/unit/core/test_pytest_suite_runner.py
@@ -21,25 +21,32 @@ class PyTestSuiteRunnerTesting(unittest.TestCase):
def setUp(self):
self.psrunner = pytest_suite_runner.PyTestSuiteRunner()
- def _test_run(self, result, status=testcase.TestCase.EX_OK):
+ @mock.patch('unittest.TestLoader')
+ def _test_run(self, mock_class=None, result=mock.Mock(),
+ status=testcase.TestCase.EX_OK):
with mock.patch('functest.core.pytest_suite_runner.'
'unittest.TextTestRunner.run',
return_value=result):
self.assertEqual(self.psrunner.run(), status)
+ mock_class.assert_not_called()
+
+ def test_check_suite_null(self):
+ self.assertEqual(self.psrunner.suite, None)
def test_run_no_ut(self):
mock_result = mock.Mock(testsRun=0, errors=[], failures=[])
- self._test_run(mock_result, testcase.TestCase.EX_RUN_ERROR)
+ self._test_run(result=mock_result,
+ status=testcase.TestCase.EX_RUN_ERROR)
self.assertEqual(self.psrunner.result, 0)
self.assertEqual(self.psrunner.details, {'errors': [], 'failures': []})
self.assertEqual(self.psrunner.is_successful(),
testcase.TestCase.EX_TESTCASE_FAILED)
- def test_run_ko(self):
+ def test_run_result_ko(self):
self.psrunner.criteria = 100
mock_result = mock.Mock(testsRun=50, errors=[('test1', 'error_msg1')],
failures=[('test2', 'failure_msg1')])
- self._test_run(mock_result, testcase.TestCase.EX_OK)
+ self._test_run(result=mock_result)
self.assertEqual(self.psrunner.result, 96)
self.assertEqual(self.psrunner.details,
{'errors': [('test1', 'error_msg1')],
@@ -47,15 +54,38 @@ class PyTestSuiteRunnerTesting(unittest.TestCase):
self.assertEqual(self.psrunner.is_successful(),
testcase.TestCase.EX_TESTCASE_FAILED)
- def test_run_ok(self):
+ def test_run_result_ok(self):
mock_result = mock.Mock(testsRun=50, errors=[],
failures=[])
- self._test_run(mock_result)
+ self._test_run(result=mock_result)
self.assertEqual(self.psrunner.result, 100)
self.assertEqual(self.psrunner.details, {'errors': [], 'failures': []})
self.assertEqual(self.psrunner.is_successful(),
testcase.TestCase.EX_OK)
+ @mock.patch('unittest.TestLoader')
+ def test_run_name_exc(self, mock_class=None):
+ mock_obj = mock.Mock(side_effect=ImportError)
+ mock_class.side_effect = mock_obj
+ self.assertEqual(self.psrunner.run(name='foo'),
+ testcase.TestCase.EX_RUN_ERROR)
+ mock_class.assert_called_once_with()
+ mock_obj.assert_called_once_with()
+
+ @mock.patch('unittest.TestLoader')
+ def test_run_name(self, mock_class=None):
+ mock_result = mock.Mock(testsRun=50, errors=[],
+ failures=[])
+ mock_obj = mock.Mock()
+ mock_class.side_effect = mock_obj
+ with mock.patch('functest.core.pytest_suite_runner.'
+ 'unittest.TextTestRunner.run',
+ return_value=mock_result):
+ self.assertEqual(self.psrunner.run(name='foo'),
+ testcase.TestCase.EX_OK)
+ mock_class.assert_called_once_with()
+ mock_obj.assert_called_once_with()
+
if __name__ == "__main__":
logging.disable(logging.CRITICAL)