Segment: Allow for setting multicast in advanced_config

This change enables specifying multicast in Segment's advanced_config
attribute. Upon update, the attribute is replaced. It is up to the
caller to make sure other components such as address_pool_paths are
not overwritten.

Change-Id: I738daa6243772006b69e6149b42de9451befa7e5
This commit is contained in:
Salvatore Orlando 2021-08-26 07:35:59 -07:00
parent d0b20761cd
commit aa25bd32fd
3 changed files with 46 additions and 7 deletions

View File

@ -4503,7 +4503,7 @@ class TestPolicySegment(NsxPolicyLibTestCase):
def _test_create(self, tier1_id=None, tier0_id=None, mdproxy=None, def _test_create(self, tier1_id=None, tier0_id=None, mdproxy=None,
dhcp_server=None, admin_state=None, dhcp_server=None, admin_state=None,
ip_pool_id='external-ip-pool', ls_id=None, ip_pool_id='external-ip-pool', multicast=None, ls_id=None,
unique_id=None, tz_id=None, ep_id=None, overlay_id=None): unique_id=None, tz_id=None, ep_id=None, overlay_id=None):
name = 'test' name = 'test'
description = 'desc' description = 'desc'
@ -4512,6 +4512,8 @@ class TestPolicySegment(NsxPolicyLibTestCase):
'subnets': subnets, 'subnets': subnets,
'ip_pool_id': ip_pool_id, 'ip_pool_id': ip_pool_id,
'tenant': TEST_TENANT} 'tenant': TEST_TENANT}
if multicast:
kwargs['multicast'] = multicast
if tier1_id: if tier1_id:
kwargs['tier1_id'] = tier1_id kwargs['tier1_id'] = tier1_id
@ -4559,6 +4561,8 @@ class TestPolicySegment(NsxPolicyLibTestCase):
ip_pool_path = ip_pool_def.get_resource_full_path() ip_pool_path = ip_pool_def.get_resource_full_path()
expected_advanced_config = { expected_advanced_config = {
'address_pool_paths': [ip_pool_path]} 'address_pool_paths': [ip_pool_path]}
if multicast is not None:
expected_advanced_config.update({'multicast': multicast})
self.assertEqual(expected_def.get_obj_dict()['advanced_config'], self.assertEqual(expected_def.get_obj_dict()['advanced_config'],
expected_advanced_config) expected_advanced_config)
@ -4603,6 +4607,12 @@ class TestPolicySegment(NsxPolicyLibTestCase):
def test_create_with_overlay_id(self): def test_create_with_overlay_id(self):
self._test_create(overlay_id=100) self._test_create(overlay_id=100)
def test_create_with_multicast_and_no_ip_pool(self):
self._test_create(tier1_id='111', ip_pool_id=None, multicast=True)
def test_create_with_multicast_and_ip_pool(self):
self._test_create(tier1_id='111', ip_pool_id='xxx', multicast=True)
def test_delete(self): def test_delete(self):
segment_id = '111' segment_id = '111'
with mock.patch.object(self.policy_api, "delete") as api_call: with mock.patch.object(self.policy_api, "delete") as api_call:
@ -4648,6 +4658,25 @@ class TestPolicySegment(NsxPolicyLibTestCase):
tenant=TEST_TENANT) tenant=TEST_TENANT)
self.assert_called_with_def(update_call, expected_def) self.assert_called_with_def(update_call, expected_def)
def test_update_with_multicast(self):
# Test and update call which sets advanced_config
segment_id = '111'
admin_state = False
with self.mock_get(segment_id, 'xxx'), \
self.mock_create_update() as update_call:
self.resourceApi.update(segment_id,
admin_state=admin_state,
multicast=False,
tenant=TEST_TENANT)
expected_def = core_defs.SegmentDef(
nsx_version=nsxlib_testcase.LATEST_VERSION,
segment_id=segment_id,
multicast=False,
admin_state=admin_state,
tenant=TEST_TENANT)
self.assert_called_with_def(update_call, expected_def)
def test_remove_connectivity_and_subnets(self): def test_remove_connectivity_and_subnets(self):
segment_id = '111' segment_id = '111'
with mock.patch.object(self.policy_api, "get", with mock.patch.object(self.policy_api, "get",

View File

@ -938,12 +938,15 @@ class BaseSegmentDef(ResourceDef):
for subnet in self.get_attr('subnets')] for subnet in self.get_attr('subnets')]
self._set_attr_if_specified(body, 'subnets', value=subnets) self._set_attr_if_specified(body, 'subnets', value=subnets)
adv_cfg = {}
if self.has_attr('ip_pool_id'): if self.has_attr('ip_pool_id'):
ip_pool_id = self.get_attr('ip_pool_id') ip_pool_id = self.get_attr('ip_pool_id')
adv_cfg = self._get_adv_config(ip_pool_id) adv_cfg.update(self._get_adv_config_ip_pool(ip_pool_id))
self._set_attr_if_specified(body, 'ip_pool_id', if self.has_attr('multicast'):
body_attr='advanced_config', adv_cfg['multicast'] = self.get_attr('multicast')
value=adv_cfg) if adv_cfg:
body['advanced_config'] = adv_cfg
self._set_attrs_if_specified( self._set_attrs_if_specified(
body, ['domain_name', 'vlan_ids', 'ls_id']) body, ['domain_name', 'vlan_ids', 'ls_id'])
return body return body
@ -952,7 +955,7 @@ class BaseSegmentDef(ResourceDef):
def resource_type(): def resource_type():
return 'Segment' return 'Segment'
def _get_adv_config(self, ip_pool_id): def _get_adv_config_ip_pool(self, ip_pool_id):
if ip_pool_id is None: if ip_pool_id is None:
return {'address_pool_paths': []} return {'address_pool_paths': []}
ip_pool_def = IpPoolDef(ip_pool_id=ip_pool_id) ip_pool_def = IpPoolDef(ip_pool_id=ip_pool_id)

View File

@ -2259,6 +2259,7 @@ class NsxPolicySegmentApi(NsxPolicyResourceBase):
vlan_ids=IGNORE, vlan_ids=IGNORE,
transport_zone_id=IGNORE, transport_zone_id=IGNORE,
ip_pool_id=IGNORE, ip_pool_id=IGNORE,
multicast=IGNORE,
metadata_proxy_id=IGNORE, metadata_proxy_id=IGNORE,
dhcp_server_config_id=IGNORE, dhcp_server_config_id=IGNORE,
admin_state=IGNORE, admin_state=IGNORE,
@ -2286,6 +2287,7 @@ class NsxPolicySegmentApi(NsxPolicyResourceBase):
vlan_ids=vlan_ids, vlan_ids=vlan_ids,
transport_zone_id=transport_zone_id, transport_zone_id=transport_zone_id,
ip_pool_id=ip_pool_id, ip_pool_id=ip_pool_id,
multicast=multicast,
metadata_proxy_id=metadata_proxy_id, metadata_proxy_id=metadata_proxy_id,
dhcp_server_config_id=dhcp_server_config_id, dhcp_server_config_id=dhcp_server_config_id,
admin_state=admin_state, admin_state=admin_state,
@ -2323,10 +2325,14 @@ class NsxPolicySegmentApi(NsxPolicyResourceBase):
def update(self, segment_id, name=IGNORE, description=IGNORE, def update(self, segment_id, name=IGNORE, description=IGNORE,
tier1_id=IGNORE, tier0_id=IGNORE, subnets=IGNORE, tier1_id=IGNORE, tier0_id=IGNORE, subnets=IGNORE,
dns_domain_name=IGNORE, dns_domain_name=IGNORE,
vlan_ids=IGNORE, metadata_proxy_id=IGNORE, vlan_ids=IGNORE, multicast=IGNORE, metadata_proxy_id=IGNORE,
dhcp_server_config_id=IGNORE, admin_state=IGNORE, dhcp_server_config_id=IGNORE, admin_state=IGNORE,
tags=IGNORE, tenant=constants.POLICY_INFRA_TENANT): tags=IGNORE, tenant=constants.POLICY_INFRA_TENANT):
# NOTE: Setting multicast upon update will reset any other advanced
# config attribute that might have been set previously
# TODO(sorlando): Regardless of patch strategy always fetch advanced
# config and merge before updating
self._update(segment_id=segment_id, self._update(segment_id=segment_id,
name=name, name=name,
description=description, description=description,
@ -2335,6 +2341,7 @@ class NsxPolicySegmentApi(NsxPolicyResourceBase):
subnets=subnets, subnets=subnets,
dns_domain_name=dns_domain_name, dns_domain_name=dns_domain_name,
vlan_ids=vlan_ids, vlan_ids=vlan_ids,
multicast=multicast,
metadata_proxy_id=metadata_proxy_id, metadata_proxy_id=metadata_proxy_id,
dhcp_server_config_id=dhcp_server_config_id, dhcp_server_config_id=dhcp_server_config_id,
admin_state=admin_state, admin_state=admin_state,