Просмотр исходного кода

Add tests for `coriolis.cmd.conductor` module

Cristian Matiut 2 лет назад
Родитель
Сommit
22478f4391
2 измененных файлов с 96 добавлено и 0 удалено
  1. 0 0
      coriolis/tests/cmd/__init__.py
  2. 96 0
      coriolis/tests/cmd/test_conductor.py

+ 0 - 0
coriolis/tests/cmd/__init__.py


+ 96 - 0
coriolis/tests/cmd/test_conductor.py

@@ -0,0 +1,96 @@
+# Copyright 2024 Cloudbase Solutions Srl
+# All Rights Reserved.
+
+import sys
+from unittest import mock
+
+from coriolis.cmd import conductor
+from coriolis.conductor.rpc import server as rpc_server
+from coriolis import constants
+from coriolis import service
+from coriolis.tests import test_base
+from coriolis import utils
+
+
+class ConductorTestCase(test_base.CoriolisBaseTestCase):
+    """Test suite for the Coriolis conductor CMD"""
+
+    @mock.patch.object(service, 'service')
+    @mock.patch.object(rpc_server, 'ConductorServerEndpoint')
+    @mock.patch.object(service, 'MessagingService')
+    @mock.patch.object(service, 'check_locks_dir_empty')
+    @mock.patch.object(utils, 'setup_logging')
+    @mock.patch('coriolis.cmd.conductor.CONF')
+    @mock.patch.object(service, 'get_worker_count_from_args')
+    @mock.patch.object(sys, 'argv')
+    def test_main(
+        self,
+        mock_argv,
+        mock_get_worker_count_from_args,
+        mock_conf,
+        mock_setup_logging,
+        mock_check_locks_dir_empty,
+        mock_MessagingService,
+        mock_ConductorServerEndpoint,
+        mock_service
+    ):
+        worker_count = mock.sentinel.worker_count
+        args = ['mock_arg_1', 'mock_arg_2']
+        mock_get_worker_count_from_args.return_value = (worker_count, args)
+
+        conductor.main()
+
+        mock_get_worker_count_from_args.assert_called_once_with(mock_argv)
+        mock_conf.assert_called_once_with(
+            ['mock_arg_2'], project='coriolis', version="1.0.0")
+        mock_setup_logging.assert_called_once()
+        mock_check_locks_dir_empty.assert_called_once()
+        mock_MessagingService.assert_called_once_with(
+            constants.CONDUCTOR_MAIN_MESSAGING_TOPIC,
+            [mock_ConductorServerEndpoint.return_value],
+            rpc_server.VERSION, worker_count=worker_count)
+        mock_service.launch.assert_called_once_with(
+            mock_conf, mock_MessagingService.return_value,
+            workers=mock_MessagingService.return_value.
+            get_workers_count.return_value)
+        mock_service.launch.return_value.wait.assert_called_once()
+
+    @mock.patch.object(service, 'service')
+    @mock.patch.object(rpc_server, 'ConductorServerEndpoint')
+    @mock.patch.object(service, 'MessagingService')
+    @mock.patch.object(service, 'check_locks_dir_empty')
+    @mock.patch.object(utils, 'setup_logging')
+    @mock.patch('coriolis.cmd.conductor.CONF')
+    @mock.patch.object(service, 'get_worker_count_from_args')
+    @mock.patch.object(sys, 'argv')
+    def test_main_no_worker_count(
+        self,
+        mock_argv,
+        mock_get_worker_count_from_args,
+        mock_conf,
+        mock_setup_logging,
+        mock_check_locks_dir_empty,
+        mock_MessagingService,
+        mock_ConductorServerEndpoint,
+        mock_service
+    ):
+        worker_count = None
+        args = ['mock_arg_1', 'mock_arg_2']
+        mock_get_worker_count_from_args.return_value = (worker_count, args)
+
+        conductor.main()
+
+        mock_get_worker_count_from_args.assert_called_once_with(mock_argv)
+        mock_conf.assert_called_once_with(
+            ['mock_arg_2'], project='coriolis', version="1.0.0")
+        mock_setup_logging.assert_called_once()
+        mock_check_locks_dir_empty.assert_called_once()
+        mock_MessagingService.assert_called_once_with(
+            constants.CONDUCTOR_MAIN_MESSAGING_TOPIC,
+            [mock_ConductorServerEndpoint.return_value],
+            rpc_server.VERSION, worker_count=mock_conf.conductor.worker_count)
+        mock_service.launch.assert_called_once_with(
+            mock_conf, mock_MessagingService.return_value,
+            workers=mock_MessagingService.return_value.
+            get_workers_count.return_value)
+        mock_service.launch.return_value.wait.assert_called_once()