self.k8stesting = k8stest.K8sTesting()
- def _test_no_env_var(self, var):
- del os.environ[var]
- with self.assertRaises(Exception):
- k8stest.K8sTesting().check_envs()
-
- def test_no_deploy_scenario(self):
- self._test_no_env_var("DEPLOY_SCENARIO")
-
- def test_no_kube_master_ip(self):
- self._test_no_env_var("KUBE_MASTER_IP")
-
- def test_no_kube_master_url(self):
- self._test_no_env_var("KUBE_MASTER_URL")
-
- def test_no_kubernetes_provider(self):
- self._test_no_env_var("KUBERNETES_PROVIDER")
-
@mock.patch('functest_kubernetes.k8stest.os.path.isfile',
return_value=False)
def test_run_missing_config_file(self, mock_func):
"Cannot run k8s testcases. Config file not found")
mock_func.assert_called_with('not_file')
+ def test_run_kubetest_cmd_none(self):
+ self.k8stesting.cmd = None
+ with self.assertRaises(TypeError):
+ self.k8stesting.run_kubetest()
+
+ @mock.patch('functest_kubernetes.k8stest.os.path.isfile')
+ def test_error_logging(self, mock_isfile):
+ # pylint: disable=unused-argument
+ with mock.patch('functest_kubernetes.k8stest.'
+ 'subprocess.Popen') as mock_popen, \
+ mock.patch.object(self.k8stesting,
+ '_K8sTesting__logger') as mock_logger:
+ mock_stdout = mock.Mock()
+ attrs = {'stdout.read.return_value': 'Error loading client'}
+ mock_stdout.configure_mock(**attrs)
+ mock_popen.return_value = mock_stdout
+ self.k8stesting.run()
+ mock_logger.exception.assert_called_with(
+ "Error with running kubetest:")
+
+ @mock.patch('functest_kubernetes.k8stest.os.path.isfile')
+ @mock.patch('functest_kubernetes.k8stest.subprocess.Popen')
+ def test_run(self, mock_open, mock_isfile):
+ self.assertEquals(self.k8stesting.run(),
+ testcase.TestCase.EX_OK)
+ mock_isfile.assert_called()
+ mock_open.assert_called()
+
if __name__ == "__main__":
logging.disable(logging.CRITICAL)