Esempio n. 1
0
    def test_delete_loadbalancers_no_candidate(self, mock_clients):
        mock_lbs = {"loadbalancers": []}
        mock_octavie_client = mock.MagicMock()
        mock_octavie_client.load_balancer_list.return_value = mock_lbs
        osc = mock.MagicMock()
        mock_clients.return_value = osc
        osc.octavia.return_value = mock_octavie_client

        octavia.delete_loadbalancers(self.context, self.cluster)

        self.assertFalse(mock_octavie_client.load_balancer_delete.called)
Esempio n. 2
0
    def test_delete_loadbalancers_no_candidate(self, mock_clients):
        mock_lbs = {
            "loadbalancers": []
        }
        mock_octavie_client = mock.MagicMock()
        mock_octavie_client.load_balancer_list.return_value = mock_lbs
        osc = mock.MagicMock()
        mock_clients.return_value = osc
        osc.octavia.return_value = mock_octavie_client

        octavia.delete_loadbalancers(self.context, self.cluster)

        self.assertFalse(mock_octavie_client.load_balancer_delete.called)
Esempio n. 3
0
    def test_delete_loadbalancers(self, mock_clients, mock_delete_fip):
        mock_lbs = {
            "loadbalancers": [
                {
                    "id":
                    "fake_id_1",
                    "description":
                    "Kubernetes external service "
                    "ad3080723f1c211e88adbfa163ee1203 from "
                    "cluster %s" % self.cluster.uuid,
                    "name":
                    "fake_name_1",
                    "provisioning_status":
                    "ACTIVE",
                    "vip_port_id":
                    "b4ca07d1-a31e-43e2-891a-7d14f419f342"
                },
                {
                    "id":
                    "fake_id_2",
                    "description":
                    "Kubernetes Ingress test-octavia-ingress "
                    "in namespace default from cluster %s, "
                    "version: 32207" % self.cluster.uuid,
                    "name":
                    "fake_name_2",
                    "provisioning_status":
                    "ERROR",
                    "vip_port_id":
                    "c17c1a6e-1868-11e9-84cd-00224d6b7bc1"
                },
            ]
        }
        mock_octavie_client = mock.MagicMock()
        mock_octavie_client.load_balancer_list.side_effect = [
            mock_lbs, {
                "loadbalancers": []
            }
        ]
        osc = mock.MagicMock()
        mock_clients.return_value = osc
        osc.octavia.return_value = mock_octavie_client

        octavia.delete_loadbalancers(self.context, self.cluster)

        calls = [
            mock.call("fake_id_1", cascade=True),
            mock.call("fake_id_2", cascade=True)
        ]
        mock_octavie_client.load_balancer_delete.assert_has_calls(calls)
Esempio n. 4
0
    def test_delete_loadbalancers(self, mock_clients):
        mock_lbs = {
            "loadbalancers": [
                {
                    "id":
                    "fake_id_1",
                    "description":
                    "Kubernetes external service "
                    "ad3080723f1c211e88adbfa163ee1203 from "
                    "cluster %s" % self.cluster.uuid,
                    "name":
                    "fake_name_1",
                    "provisioning_status":
                    "ACTIVE"
                },
                {
                    "id":
                    "fake_id_2",
                    "description":
                    "Kubernetes external service "
                    "a9f9ba08cf28811e89547fa163ea824f from "
                    "cluster %s" % self.cluster.uuid,
                    "name":
                    "fake_name_2",
                    "provisioning_status":
                    "ERROR"
                },
            ]
        }
        mock_octavie_client = mock.MagicMock()
        mock_octavie_client.load_balancer_list.side_effect = [
            mock_lbs, {
                "loadbalancers": []
            }
        ]
        osc = mock.MagicMock()
        mock_clients.return_value = osc
        osc.octavia.return_value = mock_octavie_client

        octavia.delete_loadbalancers(self.context, self.cluster)

        calls = [
            mock.call("fake_id_1", cascade=True),
            mock.call("fake_id_2", cascade=True)
        ]
        mock_octavie_client.load_balancer_delete.assert_has_calls(calls)
Esempio n. 5
0
    def test_delete_loadbalancers_with_stack_not_found(self, mock_clients,
                                                       mock_delete_fip):
        mock_octavia_client = mock.MagicMock()
        mock_octavia_client.load_balancer_list.return_value = {
            "loadbalancers": []
        }

        mock_heat_client = mock.MagicMock()
        mock_heat_client.resources.list.side_effect = \
            heat_exc.HTTPNotFound

        osc = mock.MagicMock()
        mock_clients.return_value = osc
        osc.octavia.return_value = mock_octavia_client
        osc.heat.return_value = mock_heat_client

        octavia.delete_loadbalancers(self.context, self.cluster)

        self.assertFalse(mock_octavia_client.load_balancer_show.called)
        self.assertFalse(mock_octavia_client.load_balancer_delete.called)
Esempio n. 6
0
    def test_delete_loadbalancers_already_deleted(self, mock_clients,
                                                  mock_delete_fip):
        mock_octavia_client = mock.MagicMock()
        mock_octavia_client.load_balancer_list.return_value = {
            "loadbalancers": []
        }

        mock_heat_client = mock.MagicMock()
        mock_heat_client.resources.list.return_value = [
            TestHeatLBResource(None)
        ]

        osc = mock.MagicMock()
        mock_clients.return_value = osc
        osc.octavia.return_value = mock_octavia_client
        osc.heat.return_value = mock_heat_client

        octavia.delete_loadbalancers(self.context, self.cluster)

        self.assertFalse(mock_octavia_client.load_balancer_show.called)
        self.assertFalse(mock_octavia_client.load_balancer_delete.called)
Esempio n. 7
0
    def test_delete_loadbalancers(self, mock_clients, mock_delete_fip):
        mock_lbs = {
            "loadbalancers": [
                {
                    "id": "fake_id_1",
                    "description": "Kubernetes external service "
                                   "ad3080723f1c211e88adbfa163ee1203 from "
                                   "cluster %s" % self.cluster.uuid,
                    "name": "fake_name_1",
                    "provisioning_status": "ACTIVE",
                    "vip_port_id": "b4ca07d1-a31e-43e2-891a-7d14f419f342"
                },
                {
                    "id": "fake_id_2",
                    "description": "Kubernetes external service "
                                   "a9f9ba08cf28811e89547fa163ea824f from "
                                   "cluster %s" % self.cluster.uuid,
                    "name": "fake_name_2",
                    "provisioning_status": "ERROR",
                    "vip_port_id": "c17c1a6e-1868-11e9-84cd-00224d6b7bc1"
                },
            ]
        }
        mock_octavie_client = mock.MagicMock()
        mock_octavie_client.load_balancer_list.side_effect = [
            mock_lbs, {"loadbalancers": []}
        ]
        osc = mock.MagicMock()
        mock_clients.return_value = osc
        osc.octavia.return_value = mock_octavie_client

        octavia.delete_loadbalancers(self.context, self.cluster)

        calls = [
            mock.call("fake_id_1", cascade=True),
            mock.call("fake_id_2", cascade=True)
        ]
        mock_octavie_client.load_balancer_delete.assert_has_calls(calls)
Esempio n. 8
0
 def pre_delete_cluster(self, context, cluster):
     """Delete cloud resources before deleting the cluster."""
     if keystone.is_octavia_enabled():
         LOG.info("Starting to delete loadbalancers for cluster %s",
                  cluster.uuid)
         octavia.delete_loadbalancers(context, cluster)
Esempio n. 9
0
 def pre_delete_cluster(self, context, cluster):
     """Delete cloud resources before deleting the cluster."""
     if keystone.is_octavia_enabled():
         LOG.info("Starting to delete loadbalancers for cluster %s",
                  cluster.uuid)
         octavia.delete_loadbalancers(context, cluster)