def _update_broker_config(self, svc, config):
        """
        Retrieve the latest broker configuration from the management service
        and update it in the supplied `config`.

        :param dxlclient._cli._management_service.ManagementService svc: the
            management service to query for the new broker cert chain
        :param dxlclient._cli._provision_config.DxlProvisionConfig config:
            object representing the dxl client configuration
        """
        broker_response = svc.invoke_command(self._BROKER_LIST_COMMAND)
        try:
            brokers = json.loads(broker_response)["brokers"]
            config.brokers = [
                Broker(broker["hostName"], broker["guid"], broker["ipAddress"],
                       broker["port"]) for broker in brokers
            ]
            websocket_brokers = json.loads(broker_response)["webSocketBrokers"]
            config.websocket_brokers = [
                Broker(broker["hostName"], broker["guid"], broker["ipAddress"],
                       broker["port"]) for broker in websocket_brokers
            ]
        except Exception as ex:
            logger.error("Failed to process broker list. Message: %s", ex)
            raise
Exemplo n.º 2
0
    def test_write_modified_config(self):
        initial_data = os.linesep.join([
            "# mycerts", "[Certs]", "BrokerCertChain = abundle.crt",
            "CertFile = acertfile.crt", "# pk file", "PrivateKey = akey.key",
            "{}[Brokers]".format(os.linesep), "# broker 7",
            "myid7 = myid7;8007;myhost7;10.10.100.7", "# broker 8",
            "myid8 = myid8;8008;myhost8;10.10.100.8{}".format(os.linesep)
        ])

        expected_data_after_mods = os.linesep.join([
            "# mycerts", "[Certs]", "BrokerCertChain = newbundle.pem",
            "CertFile = acertfile.crt", "# pk file", "PrivateKey = newkey.pem",
            "{}[Brokers]".format(os.linesep), "# broker 8",
            "myid8 = myid8;8008;myhost8;10.10.100.8",
            "myid9 = myid9;8009;myhost9;10.10.100.9{}".format(os.linesep)
        ])

        with patch.object(builtins, 'open',
                          return_value=io.BytesIO(initial_data.encode())), \
                patch.object(os.path, 'isfile', return_value=True):
            config = DxlClientConfig.create_dxl_config_from_file(
                "mock_file.cfg")
        del config.brokers[0]
        config.broker_ca_bundle = "newbundle.pem"
        config.private_key = "newkey.pem"
        config.brokers.append(Broker("myhost9", "myid9", "10.10.100.9", 8009))
        byte_stream = self.CapturedBytesIO()
        with patch.object(builtins, 'open',
                          return_value=byte_stream) as mock_open:
            config.write("newfile.txt")
        self.assertEqual(expected_data_after_mods.encode(),
                         byte_stream.bytes_captured)
        mock_open.assert_called_with("newfile.txt", "wb")
Exemplo n.º 3
0
    def test_client_raises_exception_when_cannot_sync_connect_to_broker(self):

        with self.create_client() as client:
            broker = Broker("localhost", UuidGenerator.generate_id_as_string(), "127.0.0.1")
            client._config.brokers = [broker]

            with self.assertRaises(DxlException):
                client.connect()
Exemplo n.º 4
0
 def test_write_in_memory_config(self):
     expected_data = os.linesep.join([
         "[Certs]", "BrokerCertChain = mycabundle.pem",
         "CertFile = mycertfile.pem", "PrivateKey = myprivatekey.pem",
         "{}[Brokers]".format(os.linesep),
         "myid1 = myid1;8001;myhost1;10.10.100.1",
         "myid2 = myid2;8002;myhost2;10.10.100.2{}".format(os.linesep)
     ])
     byte_stream = self.CapturedBytesIO()
     with patch.object(builtins, 'open',
                       return_value=byte_stream) as mock_open:
         config = DxlClientConfig(
             "mycabundle.pem", "mycertfile.pem", "myprivatekey.pem", [
                 Broker("myhost1", "myid1", "10.10.100.1", 8001),
                 Broker("myhost2", "myid2", "10.10.100.2", 8002)
             ])
         config.write("myfile.txt")
     self.assertEqual(expected_data.encode(), byte_stream.bytes_captured)
     mock_open.assert_called_with("myfile.txt", "wb")
Exemplo n.º 5
0
 def test_get_sorted_broker_list_returns_all_brokers(self):
     # Create config
     config = DxlClientConfig(broker_ca_bundle=get_ca_bundle_pem(),
                              cert_file=get_cert_file_pem(),
                              private_key=get_dxl_private_key(),
                              brokers=[])
     # Create mocked brokers
     broker1 = Broker('b1host')
     broker2 = Broker('b2host')
     broker1._connect_to_broker = broker2._connect_to_broker = Mock(
         return_value=True)
     # Add them to config
     config.brokers.append(broker1)
     config.brokers.append(broker2)
     # Get all brokers
     broker_list = config._get_sorted_broker_list()
     # Check all brokers are in the list
     self.assertTrue(broker1 in broker_list)
     self.assertTrue(broker2 in broker_list)
Exemplo n.º 6
0
    def test_client_retries_defines_how_many_times_the_client_retries_connection(self, retries, connect_count):
        # Client wont' connect ;)
        self.client._client.connect = Mock(side_effect=Exception('Could not connect'))
        # No delay between retries (faster unit tests)
        self.client.config.reconnect_delay = 0
        self.client._wait_for_policy_delay = 0

        broker = Broker(host_name='localhost')
        broker._parse(UuidGenerator.generate_id_as_string() + ";9999;localhost;127.0.0.1")

        self.client.config.brokers = [broker]
        self.client.config.connect_retries = retries

        with self.assertRaises(DxlException):
            self.client.connect()
        self.assertEqual(self.client._client.connect.call_count, connect_count)
    def _brokers_for_config(broker_lines):
        """
        Convert the supplied broker configuration, a `list` of strings - one
        for each broker - into a list of :class:`Broker` objects. Each string
        in the input list represents a key/value pair, delimited by an equal
        sign. This method uses :meth:`Broker._parse` as a constructor, raising
        an `Exception` any broker configuration lines are syntactically
        invalid.

        :param broker_lines: collection of configuration info for each broker
        :type broker_lines: list(str) or tuple(str) or set(str)
        :return: `list` of broker info
        :rtype: list(Broker)
        """
        brokers = []
        for broker_line in broker_lines:
            try:
                broker_key, broker_value = broker_line.split("=")
            except Exception:
                logger.error("Invalid key value pair for broker entry: %s",
                             broker_line)
                raise
            broker = Broker(host_name="none")
            try:
                broker._parse(broker_value)
            except Exception as ex:
                logger.error("Failed to process broker value: %s. Message: %s",
                             broker_value, ex)
                raise
            if not broker.unique_id:
                raise Exception("No guid for broker: {}".format(broker_value))
            if broker.unique_id != broker_key:
                raise Exception("{}{}{}{}. Broker line: {}".format(
                    "guid for broker key ", broker_key,
                    " did not match guid for broker value: ", broker.unique_id,
                    broker_line))
            brokers.append(broker)
        return brokers
Exemplo n.º 8
0
 def setUp(self):
     self.socket_mock = patch('socket.socket').start()
     self.connection_mock = patch('socket.create_connection').start()
     self.connection_mock.return_value = self.socket_mock
     self.broker = Broker(host_name='localhost')