diff options
Diffstat (limited to 'tests/unittests/test_datasource/test_azure_helper.py')
| -rw-r--r-- | tests/unittests/test_datasource/test_azure_helper.py | 120 | 
1 files changed, 48 insertions, 72 deletions
| diff --git a/tests/unittests/test_datasource/test_azure_helper.py b/tests/unittests/test_datasource/test_azure_helper.py index a5228870..1134199b 100644 --- a/tests/unittests/test_datasource/test_azure_helper.py +++ b/tests/unittests/test_datasource/test_azure_helper.py @@ -1,6 +1,4 @@  import os -import struct -import unittest  from cloudinit.sources.helpers import azure as azure_helper  from ..helpers import TestCase @@ -40,7 +38,7 @@ GOAL_STATE_TEMPLATE = """\            <HostingEnvironmentConfig>              http://100.86.192.70:80/...hostingEnvironmentConfig...            </HostingEnvironmentConfig> -          <SharedConfig>{shared_config_url}</SharedConfig> +          <SharedConfig>http://100.86.192.70:80/..SharedConfig..</SharedConfig>            <ExtensionsConfig>              http://100.86.192.70:80/...extensionsConfig...            </ExtensionsConfig> @@ -55,21 +53,6 @@ GOAL_STATE_TEMPLATE = """\  """ -class TestReadAzureSharedConfig(unittest.TestCase): - -    def test_valid_content(self): -        xml = """<?xml version="1.0" encoding="utf-8"?> -            <SharedConfig> -             <Deployment name="MY_INSTANCE_ID"> -              <Service name="myservice"/> -              <ServiceInstance name="INSTANCE_ID.0" guid="{abcd-uuid}" /> -             </Deployment> -            <Incarnation number="1"/> -            </SharedConfig>""" -        ret = azure_helper.iid_from_shared_config_content(xml) -        self.assertEqual("MY_INSTANCE_ID", ret) - -  class TestFindEndpoint(TestCase):      def setUp(self): @@ -90,48 +73,64 @@ class TestFindEndpoint(TestCase):          self.assertRaises(Exception,                            azure_helper.WALinuxAgentShim.find_endpoint) -    def _build_lease_content(self, ip_address, use_hex=True): -        ip_address_repr = ':'.join( -            [hex(int(part)).replace('0x', '') -             for part in ip_address.split('.')]) -        if not use_hex: -            ip_address_repr = struct.pack( -                '>L', int(ip_address_repr.replace(':', ''), 16)) -            ip_address_repr = '"{0}"'.format(ip_address_repr.decode('utf-8')) +    @staticmethod +    def _build_lease_content(encoded_address):          return '\n'.join([              'lease {',              ' interface "eth0";', -            ' option unknown-245 {0};'.format(ip_address_repr), +            ' option unknown-245 {0};'.format(encoded_address),              '}']) -    def test_hex_string(self): -        ip_address = '98.76.54.32' -        file_content = self._build_lease_content(ip_address) +    def test_latest_lease_used(self): +        encoded_addresses = ['5:4:3:2', '4:3:2:1'] +        file_content = '\n'.join([self._build_lease_content(encoded_address) +                                  for encoded_address in encoded_addresses])          self.load_file.return_value = file_content -        self.assertEqual(ip_address, +        self.assertEqual(encoded_addresses[-1].replace(':', '.'),                           azure_helper.WALinuxAgentShim.find_endpoint()) + +class TestExtractIpAddressFromLeaseValue(TestCase): + +    def test_hex_string(self): +        ip_address, encoded_address = '98.76.54.32', '62:4c:36:20' +        self.assertEqual( +            ip_address, +            azure_helper.WALinuxAgentShim.get_ip_from_lease_value( +                encoded_address +            )) +      def test_hex_string_with_single_character_part(self): -        ip_address = '4.3.2.1' -        file_content = self._build_lease_content(ip_address) -        self.load_file.return_value = file_content -        self.assertEqual(ip_address, -                         azure_helper.WALinuxAgentShim.find_endpoint()) +        ip_address, encoded_address = '4.3.2.1', '4:3:2:1' +        self.assertEqual( +            ip_address, +            azure_helper.WALinuxAgentShim.get_ip_from_lease_value( +                encoded_address +            ))      def test_packed_string(self): -        ip_address = '98.76.54.32' -        file_content = self._build_lease_content(ip_address, use_hex=False) -        self.load_file.return_value = file_content -        self.assertEqual(ip_address, -                         azure_helper.WALinuxAgentShim.find_endpoint()) +        ip_address, encoded_address = '98.76.54.32', 'bL6 ' +        self.assertEqual( +            ip_address, +            azure_helper.WALinuxAgentShim.get_ip_from_lease_value( +                encoded_address +            )) -    def test_latest_lease_used(self): -        ip_addresses = ['4.3.2.1', '98.76.54.32'] -        file_content = '\n'.join([self._build_lease_content(ip_address) -                                  for ip_address in ip_addresses]) -        self.load_file.return_value = file_content -        self.assertEqual(ip_addresses[-1], -                         azure_helper.WALinuxAgentShim.find_endpoint()) +    def test_packed_string_with_escaped_quote(self): +        ip_address, encoded_address = '100.72.34.108', 'dH\\"l' +        self.assertEqual( +            ip_address, +            azure_helper.WALinuxAgentShim.get_ip_from_lease_value( +                encoded_address +            )) + +    def test_packed_string_containing_a_colon(self): +        ip_address, encoded_address = '100.72.58.108', 'dH:l' +        self.assertEqual( +            ip_address, +            azure_helper.WALinuxAgentShim.get_ip_from_lease_value( +                encoded_address +            ))  class TestGoalStateParsing(TestCase): @@ -140,7 +139,6 @@ class TestGoalStateParsing(TestCase):          'incarnation': 1,          'container_id': 'MyContainerId',          'instance_id': 'MyInstanceId', -        'shared_config_url': 'MySharedConfigUrl',          'certificates_url': 'MyCertificatesUrl',      } @@ -174,20 +172,9 @@ class TestGoalStateParsing(TestCase):          goal_state = self._get_goal_state(instance_id=instance_id)          self.assertEqual(instance_id, goal_state.instance_id) -    def test_shared_config_xml_parsed_and_fetched_correctly(self): -        http_client = mock.MagicMock() -        shared_config_url = 'TestSharedConfigUrl' -        goal_state = self._get_goal_state( -            http_client=http_client, shared_config_url=shared_config_url) -        shared_config_xml = goal_state.shared_config_xml -        self.assertEqual(1, http_client.get.call_count) -        self.assertEqual(shared_config_url, http_client.get.call_args[0][0]) -        self.assertEqual(http_client.get.return_value.contents, -                         shared_config_xml) -      def test_certificates_xml_parsed_and_fetched_correctly(self):          http_client = mock.MagicMock() -        certificates_url = 'TestSharedConfigUrl' +        certificates_url = 'TestCertificatesUrl'          goal_state = self._get_goal_state(              http_client=http_client, certificates_url=certificates_url)          certificates_xml = goal_state.certificates_xml @@ -324,8 +311,6 @@ class TestWALinuxAgentShim(TestCase):                  azure_helper.WALinuxAgentShim, 'find_endpoint'))          self.GoalState = patches.enter_context(              mock.patch.object(azure_helper, 'GoalState')) -        self.iid_from_shared_config_content = patches.enter_context( -            mock.patch.object(azure_helper, 'iid_from_shared_config_content'))          self.OpenSSLManager = patches.enter_context(              mock.patch.object(azure_helper, 'OpenSSLManager'))          patches.enter_context( @@ -367,15 +352,6 @@ class TestWALinuxAgentShim(TestCase):          data = shim.register_with_azure_and_fetch_data()          self.assertEqual([], data['public-keys']) -    def test_instance_id_returned_in_data(self): -        shim = azure_helper.WALinuxAgentShim() -        data = shim.register_with_azure_and_fetch_data() -        self.assertEqual( -            [mock.call(self.GoalState.return_value.shared_config_xml)], -            self.iid_from_shared_config_content.call_args_list) -        self.assertEqual(self.iid_from_shared_config_content.return_value, -                         data['instance-id']) -      def test_correct_url_used_for_report_ready(self):          self.find_endpoint.return_value = 'test_endpoint'          shim = azure_helper.WALinuxAgentShim() | 
