From e8ee29b21edb2ea2a306aee727962b8a25b33c6c Mon Sep 17 00:00:00 2001 From: Kennan Date: Fri, 27 Mar 2015 09:41:18 +0800 Subject: [PATCH] Add kube service tests in kubeutils Add tests for service update/create Partial-Bug: #1436633 Change-Id: If77476215574e89f57fcdf20a85222797b933fa7 --- .../handlers/common/test_kube_utils.py | 88 +++++++++++++++++++ 1 file changed, 88 insertions(+) diff --git a/magnum/tests/conductor/handlers/common/test_kube_utils.py b/magnum/tests/conductor/handlers/common/test_kube_utils.py index 141e2a602f..2e18b3b9bf 100644 --- a/magnum/tests/conductor/handlers/common/test_kube_utils.py +++ b/magnum/tests/conductor/handlers/common/test_kube_utils.py @@ -255,6 +255,94 @@ class KubeClientTestCase(base.TestCase): self.assertFalse(result) mock_trycmd.assert_called_once_with(*expected_command) + @patch('magnum.conductor.handlers.common.kube_utils._k8s_update') + def test_service_update(self, mock_k8s_update): + expected_api_address = 'master-address' + expected_service_content = mock.MagicMock(manifest='service_content') + expected_command = [ + expected_api_address, + expected_service_content + ] + mock_k8s_update.return_value = ("", "") + + result = self.kube_client.service_update(expected_api_address, + expected_service_content) + self.assertTrue(result) + mock_k8s_update.assert_called_once_with(*expected_command) + + @patch('magnum.conductor.handlers.common.kube_utils._k8s_update') + def test_service_update_with_err(self, mock_k8s_update): + expected_api_address = 'master-address' + expected_service_content = mock.MagicMock(manifest='service_content') + expected_command = [ + expected_api_address, + expected_service_content + ] + mock_k8s_update.return_value = ("", "create failed") + + result = self.kube_client.service_update(expected_api_address, + expected_service_content) + self.assertFalse(result) + mock_k8s_update.assert_called_once_with(*expected_command) + + @patch('magnum.conductor.handlers.common.kube_utils._k8s_update') + def test_service_update_failure_exception(self, mock_k8s_update): + expected_api_address = 'master-address' + expected_service_content = mock.MagicMock(manifest='service_content') + expected_command = [ + expected_api_address, + expected_service_content + ] + mock_k8s_update.side_effect = Exception() + result = self.kube_client.service_update(expected_api_address, + expected_service_content) + self.assertFalse(result) + mock_k8s_update.assert_called_once_with(*expected_command) + + @patch('magnum.conductor.handlers.common.kube_utils._k8s_create') + def test_service_create(self, mock_k8s_create): + expected_api_address = 'master-address' + expected_service_content = mock.MagicMock(manifest='service_content') + expected_command = [ + expected_api_address, + expected_service_content + ] + mock_k8s_create.return_value = ("", "") + + result = self.kube_client.service_create(expected_api_address, + expected_service_content) + self.assertTrue(result) + mock_k8s_create.assert_called_once_with(*expected_command) + + @patch('magnum.conductor.handlers.common.kube_utils._k8s_create') + def test_service_create_with_err(self, mock_k8s_create): + expected_api_address = 'master-address' + expected_service_content = mock.MagicMock(manifest='service_content') + expected_command = [ + expected_api_address, + expected_service_content + ] + mock_k8s_create.return_value = ("", "create failed") + + result = self.kube_client.service_create(expected_api_address, + expected_service_content) + self.assertFalse(result) + mock_k8s_create.assert_called_once_with(*expected_command) + + @patch('magnum.conductor.handlers.common.kube_utils._k8s_create') + def test_service_create_failure_exception(self, mock_k8s_create): + expected_api_address = 'master-address' + expected_service_content = mock.MagicMock(manifest='service_content') + expected_command = [ + expected_api_address, + expected_service_content + ] + mock_k8s_create.side_effect = Exception() + result = self.kube_client.service_create(expected_api_address, + expected_service_content) + self.assertFalse(result) + mock_k8s_create.assert_called_once_with(*expected_command) + @patch('magnum.conductor.handlers.common.kube_utils._k8s_update') def test_rc_update(self, mock_k8s_update): expected_api_address = 'master-address'