Пример #1
0
    def test_get_service_nodes(self, service_name, service_cls,
                               mock_ansible_runner):
        ansible_runner_inst = mock_ansible_runner.return_value
        ansible_runner_inst.execute.side_effect = [
            [self.fake_ansible_result],
            [
                fakes.FakeAnsibleResult(payload={'stdout': ''},
                                        status=executor.STATUS_FAILED,
                                        host='10.0.0.2'),
                fakes.FakeAnsibleResult(payload={'stdout': ''},
                                        host='10.0.0.3')
            ]
        ]

        tcp_managment = tcpcloud.TCPCloudManagement(self.tcp_conf)

        service = tcp_managment.get_service(service_name)
        self.assertIsInstance(service, service_cls)

        nodes = service.get_nodes()
        cmd = 'bash -c "ps ax | grep \'{}\'"'.format(service_cls.GREP)
        ansible_runner_inst.execute.assert_has_calls([
            mock.call(['tcp.local'], {'command': self.get_nodes_cmd}),
            mock.call(['10.0.0.2', '10.0.0.3'], {'command': cmd}, []),
        ])

        hosts = [
            node_collection.Host(ip='10.0.0.3',
                                 mac='09:7b:74:90:63:c3',
                                 fqdn='cmp02.mk20.local'),
        ]
        self.assertEqual(nodes.hosts, hosts)
Пример #2
0
    def test_start(self, service_name, service_cls, mock_ansible_runner):
        ansible_runner_inst = mock_ansible_runner.return_value
        ansible_runner_inst.execute.side_effect = [
            [self.fake_ansible_result],
            [
                fakes.FakeAnsibleResult(payload={'stdout': ''},
                                        status=executor.STATUS_FAILED,
                                        host='10.0.0.2'),
                fakes.FakeAnsibleResult(payload={'stdout': ''},
                                        host='10.0.0.3')
            ],
            [
                fakes.FakeAnsibleResult(payload={'stdout': ''},
                                        host='10.0.0.2'),
                fakes.FakeAnsibleResult(payload={'stdout': ''},
                                        host='10.0.0.3')
            ]
        ]

        tcp_managment = tcpcloud.TCPCloudManagement(self.tcp_conf)

        service = tcp_managment.get_service(service_name)
        self.assertIsInstance(service, service_cls)

        service.start()

        cmd = 'bash -c "ps ax | grep \'{}\'"'.format(service_cls.GREP)
        ansible_runner_inst.execute.assert_has_calls([
            mock.call(['tcp.local'], {'command': self.get_nodes_cmd}),
            mock.call(['10.0.0.2', '10.0.0.3'], {'command': cmd}, []),
            mock.call(['10.0.0.3'], {'shell': service.START_CMD}),
        ])
Пример #3
0
    def test_execute_on_cloud(self, mock_ansible_runner):
        ansible_runner_inst = mock_ansible_runner.return_value
        ansible_runner_inst.execute.side_effect = [
            [self.fake_ansible_result], [self.fake_node_ip_result],
            [
                fakes.FakeAnsibleResult(payload={'stdout': ''}),
                fakes.FakeAnsibleResult(payload={'stdout': ''})
            ]
        ]
        tcp_managment = tcpcloud.TCPCloudManagement(self.tcp_conf)
        nodes = tcp_managment.get_nodes()
        result = tcp_managment.execute_on_cloud(nodes.hosts,
                                                {'command': 'mycmd'},
                                                raise_on_error=False)

        ansible_runner_inst.execute.assert_has_calls([
            mock.call([self.master_host], {'command': self.get_nodes_cmd}),
            mock.call([self.master_host], {'command': self.get_ips_cmd}),
            mock.call(self.hosts, {'command': 'mycmd'}, []),
        ])

        self.assertEqual(result, [
            fakes.FakeAnsibleResult(payload={'stdout': ''}),
            fakes.FakeAnsibleResult(payload={'stdout': ''})
        ])
Пример #4
0
    def test_start(self, service_name, mock_ansible_runner):
        ansible_runner_inst = mock_ansible_runner.return_value
        ansible_runner_inst.execute.side_effect = [
            [self.fake_ansible_result], [self.fake_node_ip_result],
            [
                fakes.FakeAnsibleResult(payload={'stdout': ''},
                                        status=executor.STATUS_FAILED,
                                        host='10.0.0.2'),
                fakes.FakeAnsibleResult(payload={'stdout': ''},
                                        host='10.0.0.3')
            ],
            [
                fakes.FakeAnsibleResult(payload={'stdout': ''},
                                        host='10.0.0.2'),
                fakes.FakeAnsibleResult(payload={'stdout': ''},
                                        host='10.0.0.3')
            ]
        ]

        tcp_managment = tcpcloud.TCPCloudManagement(self.tcp_conf)

        service = tcp_managment.get_service(service_name)
        service.start()

        cmd = 'bash -c "ps ax | grep -v grep | grep \'{}\'"'.format(
            service.grep)
        ansible_runner_inst.execute.assert_has_calls([
            mock.call([self.master_host], {'command': self.get_nodes_cmd}),
            mock.call([self.master_host], {'command': self.get_ips_cmd}),
            mock.call(self.hosts, {'command': cmd}, []),
            mock.call([self.hosts[1]], {'shell': service.start_cmd}),
        ])
Пример #5
0
    def test_init(self, config, expected_runner_calls, mock_ansible_runner):
        ansible_runner_inst = mock_ansible_runner.return_value

        tcp_managment = tcpcloud.TCPCloudManagement(config)

        mock_ansible_runner.assert_has_calls(expected_runner_calls)
        self.assertIs(tcp_managment.master_node_executor, ansible_runner_inst)
        self.assertIs(tcp_managment.cloud_executor, ansible_runner_inst)
Пример #6
0
    def test_get_nodes_fqdns(self, mock_ansible_runner):
        ansible_runner_inst = mock_ansible_runner.return_value
        ansible_runner_inst.execute.side_effect = [
            [self.fake_ansible_result],
            [self.fake_node_ip_result],
        ]
        tcp_managment = tcpcloud.TCPCloudManagement(self.tcp_conf)
        nodes = tcp_managment.get_nodes(fqdns=['cmp02.mk20.local'])

        self.assertEqual(nodes.hosts, [self.hosts[1]])
Пример #7
0
    def test_get_nodes_fqdns(self, mock_ansible_runner):
        ansible_runner_inst = mock_ansible_runner.return_value
        ansible_runner_inst.execute.side_effect = [[self.fake_ansible_result]]
        tcp_managment = tcpcloud.TCPCloudManagement(self.tcp_conf)
        nodes = tcp_managment.get_nodes(fqdns=['cmp02.mk20.local'])

        hosts = [
            node_collection.Host(ip='10.0.0.3',
                                 mac='09:7b:74:90:63:c3',
                                 fqdn='cmp02.mk20.local'),
        ]
        self.assertEqual(nodes.hosts, hosts)
Пример #8
0
    def test_get_nodes(self, mock_ansible_runner):
        ansible_runner_inst = mock_ansible_runner.return_value
        ansible_runner_inst.execute.side_effect = [
            [self.fake_ansible_result],
            [self.fake_node_ip_result],
        ]
        tcp_managment = tcpcloud.TCPCloudManagement(self.tcp_conf)
        nodes = tcp_managment.get_nodes()

        ansible_runner_inst.execute.assert_has_calls([
            mock.call([self.master_host], {'command': self.get_nodes_cmd}),
            mock.call([self.master_host], {'command': self.get_ips_cmd}),
        ])

        self.assertEqual(nodes.hosts, self.hosts)
Пример #9
0
    def test_verify(self, mock_ansible_runner):
        ansible_runner_inst = mock_ansible_runner.return_value
        ansible_runner_inst.execute.side_effect = [
            [self.fake_ansible_result],
            [
                fakes.FakeAnsibleResult(payload={'stdout': ''}),
                fakes.FakeAnsibleResult(payload={'stdout': ''})
            ],
        ]
        tcp_managment = tcpcloud.TCPCloudManagement(self.tcp_conf)
        tcp_managment.verify()

        ansible_runner_inst.execute.assert_has_calls([
            mock.call(['tcp.local'], {'command': self.get_nodes_cmd}),
            mock.call(['10.0.0.2', '10.0.0.3'], {'command': 'hostname'}),
        ])
Пример #10
0
    def test_get_nodes_from_discover_driver(self, mock_ansible_runner):
        ansible_runner_inst = mock_ansible_runner.return_value
        hosts = [
            node_collection.Host(ip='10.0.2.2',
                                 mac='09:7b:74:90:63:c2',
                                 fqdn='mynode1.local'),
            node_collection.Host(ip='10.0.2.3',
                                 mac='09:7b:74:90:63:c3',
                                 fqdn='mynode2.local'),
        ]
        node_discover_driver = mock.Mock()
        node_discover_driver.discover_hosts.return_value = hosts
        tcp_managment = tcpcloud.TCPCloudManagement(self.tcp_conf)
        tcp_managment.set_node_discover(node_discover_driver)
        nodes = tcp_managment.get_nodes()

        self.assertFalse(ansible_runner_inst.execute.called)
        self.assertEqual(hosts, nodes.hosts)
Пример #11
0
    def test_get_nodes(self, mock_ansible_runner):
        ansible_runner_inst = mock_ansible_runner.return_value
        ansible_runner_inst.execute.side_effect = [[self.fake_ansible_result]]
        tcp_managment = tcpcloud.TCPCloudManagement(self.tcp_conf)
        nodes = tcp_managment.get_nodes()

        ansible_runner_inst.execute.assert_has_calls([
            mock.call(['tcp.local'], {'command': self.get_nodes_cmd}),
        ])

        hosts = [
            node_collection.Host(ip='10.0.0.2',
                                 mac='09:7b:74:90:63:c2',
                                 fqdn='cmp01.mk20.local'),
            node_collection.Host(ip='10.0.0.3',
                                 mac='09:7b:74:90:63:c3',
                                 fqdn='cmp02.mk20.local'),
        ]
        self.assertEqual(nodes.hosts, hosts)
Пример #12
0
    def test_verify(self, mock_ansible_runner):
        ansible_runner_inst = mock_ansible_runner.return_value
        ansible_runner_inst.execute.side_effect = [
            [self.fake_ansible_result],
            [self.fake_node_ip_result],
            [
                fakes.FakeAnsibleResult(payload={'stdout': ''}),
                fakes.FakeAnsibleResult(payload={'stdout': ''})
            ],
        ]
        self.tcp_conf['slave_name_regexp'] = '(ctl*|cmp*)'
        tcp_managment = tcpcloud.TCPCloudManagement(self.tcp_conf)
        tcp_managment.verify()

        get_nodes_cmd = "salt -E '(ctl*|cmp*)' network.interfaces --out=yaml"
        get_ips_cmd = ("salt -E '(ctl*|cmp*)' "
                       "pillar.get _param:single_address --out=yaml")
        ansible_runner_inst.execute.assert_has_calls([
            mock.call([self.master_host], {'command': get_nodes_cmd}),
            mock.call([self.master_host], {'command': get_ips_cmd}),
            mock.call(self.hosts, {'command': 'hostname'}),
        ])
Пример #13
0
 def test_validate_services(self):
     tcp_managment = tcpcloud.TCPCloudManagement(self.tcp_conf)
     tcp_managment.validate_services()