X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/45a172b5f59ea7464b7241212464bf9113a18f36..12bfd7a65c6635a882cb2e5e419321db100b9d56:/services/nodemanager/tests/test_computenode_driver_azure.py diff --git a/services/nodemanager/tests/test_computenode_driver_azure.py b/services/nodemanager/tests/test_computenode_driver_azure.py index 049e7081b6..59fc503128 100644 --- a/services/nodemanager/tests/test_computenode_driver_azure.py +++ b/services/nodemanager/tests/test_computenode_driver_azure.py @@ -26,19 +26,18 @@ class AzureComputeNodeDriverTestCase(testutil.DriverTestMixin, unittest.TestCase self.assertEqual(kwargs, self.driver_mock.call_args[1]) def test_create_image_loaded_at_initialization(self): - list_method = self.driver_mock().list_images - list_method.return_value = [testutil.cloud_object_mock(c) - for c in 'abc'] + get_method = self.driver_mock().get_image + get_method.return_value = testutil.cloud_object_mock('id_b') driver = self.new_driver(create_kwargs={'image': 'id_b'}) - self.assertEqual(1, list_method.call_count) + self.assertEqual(1, get_method.call_count) - def test_create_includes_ping_url(self): + def test_create_includes_ping(self): arv_node = testutil.arvados_node_mock(info={'ping_secret': 'ssshh'}) + arv_node["hostname"] = None driver = self.new_driver() driver.create_node(testutil.MockSize(1), arv_node) create_method = self.driver_mock().create_node self.assertTrue(create_method.called) - print(create_method.call_args[1]) self.assertIn('ping_secret=ssshh', create_method.call_args[1].get('ex_tags', {}).get('arv-ping-url', "")) @@ -46,7 +45,9 @@ class AzureComputeNodeDriverTestCase(testutil.DriverTestMixin, unittest.TestCase arv_node = testutil.arvados_node_mock(hostname=None) driver = self.new_driver() self.assertEqual('compute-000000000000063-zzzzz', - driver.arvados_create_kwargs(arv_node)['name']) + driver.arvados_create_kwargs(testutil.MockSize(1), arv_node)['name']) + + def check_node_tagged(self, cloud_node, expected_tags): tag_mock = self.driver_mock().ex_create_tags @@ -54,14 +55,6 @@ class AzureComputeNodeDriverTestCase(testutil.DriverTestMixin, unittest.TestCase self.assertIs(cloud_node, tag_mock.call_args[0][0]) self.assertEqual(expected_tags, tag_mock.call_args[0][1]) - def test_sync_node(self): - arv_node = testutil.arvados_node_mock(1) - cloud_node = testutil.cloud_node_mock(2) - driver = self.new_driver() - driver.sync_node(cloud_node, arv_node) - self.check_node_tagged(cloud_node, - {'hostname': 'compute1.zzzzz.arvadosapi.com'}) - def test_node_create_time(self): refsecs = int(time.time()) reftuple = time.gmtime(refsecs) @@ -88,3 +81,56 @@ class AzureComputeNodeDriverTestCase(testutil.DriverTestMixin, unittest.TestCase self.assertFalse( azure.ComputeNodeDriver.is_cloud_exception(ValueError("test error")), "ValueError flagged as cloud exception") + + def test_sync_node(self): + arv_node = testutil.arvados_node_mock(1) + cloud_node = testutil.cloud_node_mock(2) + driver = self.new_driver() + driver.sync_node(cloud_node, arv_node) + self.check_node_tagged(cloud_node, + {'hostname': 'compute1.zzzzz.arvadosapi.com'}) + + def test_custom_data(self): + arv_node = testutil.arvados_node_mock(hostname=None) + driver = self.new_driver() + self.assertEqual("""#!/bin/sh +mkdir -p /var/tmp/arv-node-data/meta-data +echo 'https://100::/arvados/v1/nodes/zzzzz-yyyyy-000000000000063/ping?ping_secret=defaulttestsecret' > /var/tmp/arv-node-data/arv-ping-url +echo compute-000000000000063-zzzzz > /var/tmp/arv-node-data/meta-data/instance-id +echo z1.test > /var/tmp/arv-node-data/meta-data/instance-type +""", + driver.arvados_create_kwargs(testutil.MockSize(1), arv_node)['ex_customdata']) + + def test_create_raises_but_actually_succeeded(self): + arv_node = testutil.arvados_node_mock(1, hostname=None) + driver = self.new_driver(create_kwargs={"tag_arvados-class": "dynamic-compute"}) + nodelist = [testutil.cloud_node_mock(1, tags={"arvados-class": "dynamic-compute"})] + nodelist[0].name = 'compute-000000000000001-zzzzz' + self.driver_mock().list_nodes.return_value = nodelist + self.driver_mock().create_node.side_effect = IOError + n = driver.create_node(testutil.MockSize(1), arv_node) + self.assertEqual('compute-000000000000001-zzzzz', n.name) + + def test_ex_fetch_nic_false(self): + arv_node = testutil.arvados_node_mock(1, hostname=None) + driver = self.new_driver(create_kwargs={"tag_arvados-class": "dynamic-compute"}) + nodelist = [testutil.cloud_node_mock(1, tags={"arvados-class": "dynamic-compute"})] + nodelist[0].name = 'compute-000000000000001-zzzzz' + self.driver_mock().list_nodes.return_value = nodelist + n = driver.list_nodes() + self.assertEqual(nodelist, n) + self.driver_mock().list_nodes.assert_called_with(ex_fetch_nic=False, ex_resource_group='TestResourceGroup') + + def test_create_can_find_node_after_timeout(self): + super(AzureComputeNodeDriverTestCase, + self).test_create_can_find_node_after_timeout( + create_kwargs={'tag_arvados-class': 'test'}, + node_extra={'tags': {'arvados-class': 'test'}}) + + def test_node_found_after_timeout_has_fixed_size(self): + size = testutil.MockSize(4) + node_props = {'hardwareProfile': {'vmSize': size.id}} + cloud_node = testutil.cloud_node_mock( + size=None, tags={'arvados-class': 'test'}, properties=node_props) + self.check_node_found_after_timeout_has_fixed_size( + size, cloud_node, {'tag_arvados-class': 'test'})