Add api to remove segment tier1 connectivity

Change-Id: I8550e7797b7e6baa50d1737d32ad4c03041e3cd5
This commit is contained in:
asarfaty 2020-04-14 10:19:44 +02:00 committed by Adit Sarfaty
parent 7ace65e11c
commit 12f0edff2f
2 changed files with 27 additions and 0 deletions

View File

@ -4153,6 +4153,18 @@ class TestPolicySegment(NsxPolicyLibTestCase):
'%s/segments/%s' % (TEST_TENANT, segment_id),
{'id': segment_id, 'connectivity_path': None, 'subnets': None})
def test_remove_connectivity_path(self):
segment_id = '111'
with mock.patch.object(self.policy_api, "get",
return_value={'id': segment_id}) as api_get,\
mock.patch.object(self.policy_api.client, "update") as api_put:
self.resourceApi.remove_connectivity_path(
segment_id, tenant=TEST_TENANT)
api_get.assert_called_once()
api_put.assert_called_once_with(
'%s/segments/%s' % (TEST_TENANT, segment_id),
{'id': segment_id, 'connectivity_path': None})
def test_build_subnet(self):
gateway_address = "10.0.0.1/24"
dhcp_ranges = None

View File

@ -2028,6 +2028,21 @@ class NsxPolicySegmentApi(NsxPolicyResourceBase):
self.policy_api.client.update(path, segment)
def remove_connectivity_path(self, segment_id,
tenant=constants.POLICY_INFRA_TENANT):
"""Disconnect a segment from a router.
PATCH does not support this action so PUT is used for this
"""
# Get the current segment and update it
segment = self.get(segment_id)
segment['connectivity_path'] = None
segment_def = self.entry_def(segment_id=segment_id, tenant=tenant)
path = segment_def.get_resource_path()
self.policy_api.client.update(path, segment)
def get_realized_state(self, segment_id, entity_type=None,
tenant=constants.POLICY_INFRA_TENANT,
realization_info=None):