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)
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)
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)
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)
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)
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)
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)
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)
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)