X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/a5b7c827e89fb082a51c6ab48ab98261f85d2a24..c5f81922eff0f35eb2bcf8f9da7b9da1a7f86e90:/services/nodemanager/tests/test_computenode_dispatch.py diff --git a/services/nodemanager/tests/test_computenode_dispatch.py b/services/nodemanager/tests/test_computenode_dispatch.py index 8d69ea958c..c22e7a0e0b 100644 --- a/services/nodemanager/tests/test_computenode_dispatch.py +++ b/services/nodemanager/tests/test_computenode_dispatch.py @@ -79,14 +79,16 @@ class ComputeNodeSetupActorTestCase(testutil.ActorTestMixin, unittest.TestCase): self.make_mocks( arverror.ApiError(httplib2.Response({'status': '500'}), "")) self.make_actor() - self.setup_actor.stop_if_no_cloud_node() + self.assertTrue( + self.setup_actor.stop_if_no_cloud_node().get(self.TIMEOUT)) self.assertTrue( self.setup_actor.actor_ref.actor_stopped.wait(self.TIMEOUT)) def test_no_stop_when_cloud_node(self): self.make_actor() self.wait_for_assignment(self.setup_actor, 'cloud_node') - self.setup_actor.stop_if_no_cloud_node().get(self.TIMEOUT) + self.assertFalse( + self.setup_actor.stop_if_no_cloud_node().get(self.TIMEOUT)) self.assertTrue(self.stop_proxy(self.setup_actor), "actor was stopped by stop_if_no_cloud_node") @@ -119,6 +121,7 @@ class ComputeNodeShutdownActorMixin(testutil.ActorTestMixin): self.shutdowns = testutil.MockShutdownTimer() self.shutdowns._set_state(shutdown_open, 300) self.cloud_client = mock.MagicMock(name='cloud_client') + self.arvados_client = mock.MagicMock(name='arvados_client') self.updates = mock.MagicMock(name='update_mock') if cloud_node is None: cloud_node = testutil.cloud_node_mock() @@ -129,10 +132,12 @@ class ComputeNodeShutdownActorMixin(testutil.ActorTestMixin): if not hasattr(self, 'timer'): self.make_mocks() monitor_actor = dispatch.ComputeNodeMonitorActor.start( - self.cloud_node, time.time(), self.shutdowns, self.timer, - self.updates, self.arvados_node) + self.cloud_node, time.time(), self.shutdowns, + testutil.cloud_node_fqdn, self.timer, self.updates, + self.arvados_node) self.shutdown_actor = self.ACTOR_CLASS.start( - self.timer, self.cloud_client, monitor_actor, cancellable).proxy() + self.timer, self.cloud_client, self.arvados_client, monitor_actor, + cancellable).proxy() self.monitor_actor = monitor_actor.proxy() def check_success_flag(self, expected, allow_msg_count=1): @@ -154,6 +159,31 @@ class ComputeNodeShutdownActorMixin(testutil.ActorTestMixin): self.cloud_client.destroy_node.return_value = True self.check_success_flag(True) + def test_arvados_node_cleaned_after_shutdown(self, *mocks): + cloud_node = testutil.cloud_node_mock(62) + arv_node = testutil.arvados_node_mock(62) + self.make_mocks(cloud_node, arv_node) + self.make_actor() + self.check_success_flag(True, 3) + update_mock = self.arvados_client.nodes().update + self.assertTrue(update_mock.called) + update_kwargs = update_mock.call_args_list[0][1] + self.assertEqual(arv_node['uuid'], update_kwargs.get('uuid')) + self.assertIn('body', update_kwargs) + for clear_key in ['slot_number', 'hostname', 'ip_address', + 'first_ping_at', 'last_ping_at']: + self.assertIn(clear_key, update_kwargs['body']) + self.assertIsNone(update_kwargs['body'][clear_key]) + self.assertTrue(update_mock().execute.called) + + def test_arvados_node_not_cleaned_after_shutdown_cancelled(self, *mocks): + cloud_node = testutil.cloud_node_mock(61) + arv_node = testutil.arvados_node_mock(61) + self.make_mocks(cloud_node, arv_node, shutdown_open=False) + self.make_actor(cancellable=True) + self.check_success_flag(False, 2) + self.assertFalse(self.arvados_client.nodes().update.called) + class ComputeNodeShutdownActorTestCase(ComputeNodeShutdownActorMixin, unittest.TestCase): @@ -218,8 +248,9 @@ class ComputeNodeMonitorActorTestCase(testutil.ActorTestMixin, if start_time is None: start_time = time.time() self.node_actor = dispatch.ComputeNodeMonitorActor.start( - self.cloud_mock, start_time, self.shutdowns, self.timer, - self.updates, arv_node).proxy() + self.cloud_mock, start_time, self.shutdowns, + testutil.cloud_node_fqdn, self.timer, self.updates, + arv_node).proxy() self.node_actor.subscribe(self.subscriber).get(self.TIMEOUT) def node_state(self, *states): @@ -356,3 +387,20 @@ class ComputeNodeMonitorActorTestCase(testutil.ActorTestMixin, current_arvados = self.node_actor.arvados_node.get(self.TIMEOUT) self.assertEqual(testutil.ip_address_mock(4), current_arvados['ip_address']) + + def test_update_arvados_node_syncs_when_fqdn_mismatch(self): + self.make_mocks(5) + self.cloud_mock.extra['testname'] = 'cloudfqdn.zzzzz.arvadosapi.com' + self.make_actor() + arv_node = testutil.arvados_node_mock(5) + self.node_actor.update_arvados_node(arv_node).get(self.TIMEOUT) + self.assertEqual(1, self.updates.sync_node.call_count) + + def test_update_arvados_node_skips_sync_when_fqdn_match(self): + self.make_mocks(6) + arv_node = testutil.arvados_node_mock(6) + self.cloud_mock.extra['testname'] ='{n[hostname]}.{n[domain]}'.format( + n=arv_node) + self.make_actor() + self.node_actor.update_arvados_node(arv_node).get(self.TIMEOUT) + self.assertEqual(0, self.updates.sync_node.call_count)