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 = saltcloud.SaltCloudManagement(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}), ])
def test_init(self, config, expected_runner_calls, mock_ansible_runner): ansible_runner_inst = mock_ansible_runner.return_value tcp_managment = saltcloud.SaltCloudManagement(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)
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 = saltcloud.SaltCloudManagement(self.tcp_conf) nodes = tcp_managment.get_nodes(fqdns=['cmp02.mk20.local']) self.assertEqual(nodes.hosts, [self.hosts[1]])
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 = saltcloud.SaltCloudManagement(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)
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 = saltcloud.SaltCloudManagement(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)
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 = saltcloud.SaltCloudManagement(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'}), ])
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 = saltcloud.SaltCloudManagement(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': ''})])
def test_validate_services(self, _): tcp_managment = saltcloud.SaltCloudManagement(self.tcp_conf) tcp_managment.validate_services()