X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/3bef97ac46da8f5a7c322ec31c6bba4affb8ad80..efc17768290cc63cf7be7b2bccfc5caa77720846:/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 0bdb2cba47..ecf83c693a 100644 --- a/services/nodemanager/tests/test_computenode_dispatch.py +++ b/services/nodemanager/tests/test_computenode_dispatch.py @@ -27,24 +27,38 @@ class ComputeNodeSetupActorTestCase(testutil.ActorTestMixin, unittest.TestCase): def make_actor(self, arv_node=None): if not hasattr(self, 'timer'): - self.make_mocks(arvados_effect=[arv_node]) + self.make_mocks(arvados_effect=[arv_node] if arv_node else None) self.setup_actor = dispatch.ComputeNodeSetupActor.start( self.timer, self.api_client, self.cloud_client, testutil.MockSize(1), arv_node).proxy() + def assert_node_properties_updated(self, uuid=None, + size=testutil.MockSize(1)): + self.api_client.nodes().update.assert_any_call( + uuid=(uuid or self.arvados_effect[-1]['uuid']), + body={ + 'properties': { + 'cloud_node': { + 'size': size.id, + 'price': size.price}}}) + def test_creation_without_arvados_node(self): self.make_actor() self.assertEqual(self.arvados_effect[-1], self.setup_actor.arvados_node.get(self.TIMEOUT)) - self.assertTrue(self.api_client.nodes().create().execute.called) + self.assertEqual(1, self.api_client.nodes().create().execute.call_count) + self.assertEqual(1, self.api_client.nodes().update().execute.call_count) + self.assert_node_properties_updated() self.assertEqual(self.cloud_client.create_node(), self.setup_actor.cloud_node.get(self.TIMEOUT)) def test_creation_with_arvados_node(self): + self.make_mocks(arvados_effect=[testutil.arvados_node_mock()]*2) self.make_actor(testutil.arvados_node_mock()) self.assertEqual(self.arvados_effect[-1], self.setup_actor.arvados_node.get(self.TIMEOUT)) - self.assertTrue(self.api_client.nodes().update().execute.called) + self.assert_node_properties_updated() + self.assertEqual(2, self.api_client.nodes().update().execute.call_count) self.assertEqual(self.cloud_client.create_node(), self.setup_actor.cloud_node.get(self.TIMEOUT)) @@ -98,8 +112,9 @@ class ComputeNodeSetupActorTestCase(testutil.ActorTestMixin, unittest.TestCase): self.make_actor() subscriber = mock.Mock(name='subscriber_mock') self.setup_actor.subscribe(subscriber) - self.api_client.nodes().create().execute.side_effect = [ - testutil.arvados_node_mock()] + retry_resp = [testutil.arvados_node_mock()] + self.api_client.nodes().create().execute.side_effect = retry_resp + self.api_client.nodes().update().execute.side_effect = retry_resp self.wait_for_assignment(self.setup_actor, 'cloud_node') self.assertEqual(self.setup_actor.actor_ref.actor_urn, subscriber.call_args[0][0].actor_ref.actor_urn)