NSX|v validate PG provider networks
Prevent the creation of several portgroup provider networks with the same physical network. Already existing networks will not be affected. In addition, fix the vcns spoofguard mocks as they fail the new test Change-Id: I5f03117ca0231536df5c43ec1a5169612b4b2364
This commit is contained in:
parent
dc5d1a318f
commit
3e886eeaea
@ -549,6 +549,15 @@ def get_network_bindings_by_physical_net(session, phy_uuid):
|
|||||||
all())
|
all())
|
||||||
|
|
||||||
|
|
||||||
|
def get_network_bindings_by_physical_net_and_type(session, phy_uuid,
|
||||||
|
binding_type):
|
||||||
|
session = session or db.get_reader_session()
|
||||||
|
return (session.query(nsxv_models.NsxvTzNetworkBinding).
|
||||||
|
filter_by(phy_uuid=phy_uuid,
|
||||||
|
binding_type=binding_type).
|
||||||
|
all())
|
||||||
|
|
||||||
|
|
||||||
def delete_network_bindings(session, network_id):
|
def delete_network_bindings(session, network_id):
|
||||||
return (session.query(nsxv_models.NsxvTzNetworkBinding).
|
return (session.query(nsxv_models.NsxvTzNetworkBinding).
|
||||||
filter_by(network_id=network_id).delete())
|
filter_by(network_id=network_id).delete())
|
||||||
|
@ -679,6 +679,15 @@ class NsxVPluginV2(addr_pair_db.AllowedAddressPairsMixin,
|
|||||||
not self.nsx_v.vcns.validate_network_name(
|
not self.nsx_v.vcns.validate_network_name(
|
||||||
physical_network, network['name'])):
|
physical_network, network['name'])):
|
||||||
err_msg = _("Portgroup name must match network name")
|
err_msg = _("Portgroup name must match network name")
|
||||||
|
|
||||||
|
# make sure no other neutron network is using it
|
||||||
|
bindings = (
|
||||||
|
nsxv_db.get_network_bindings_by_physical_net_and_type(
|
||||||
|
context.elevated().session, physical_network,
|
||||||
|
network_type))
|
||||||
|
if bindings:
|
||||||
|
err_msg = (_('protgroup %s is already used by '
|
||||||
|
'another network') % physical_network)
|
||||||
else:
|
else:
|
||||||
err_msg = (_("%(net_type_param)s %(net_type_value)s not "
|
err_msg = (_("%(net_type_param)s %(net_type_value)s not "
|
||||||
"supported") %
|
"supported") %
|
||||||
|
@ -323,6 +323,30 @@ class TestNetworksV2(test_plugin.TestNetworksV2, NsxVPluginV2TestCase):
|
|||||||
for k, v in expected:
|
for k, v in expected:
|
||||||
self.assertEqual(net['network'][k], v)
|
self.assertEqual(net['network'][k], v)
|
||||||
|
|
||||||
|
def test_create_portgroup_network(self):
|
||||||
|
name = 'pg_net'
|
||||||
|
expected = [('subnets', []), ('name', name), ('admin_state_up', True),
|
||||||
|
('status', 'ACTIVE'), ('shared', False),
|
||||||
|
(pnet.NETWORK_TYPE, 'portgroup'),
|
||||||
|
(pnet.PHYSICAL_NETWORK, 'tzuuid')]
|
||||||
|
providernet_args = {pnet.NETWORK_TYPE: 'portgroup',
|
||||||
|
pnet.PHYSICAL_NETWORK: 'tzuuid'}
|
||||||
|
with self.network(name=name,
|
||||||
|
providernet_args=providernet_args,
|
||||||
|
arg_list=(pnet.NETWORK_TYPE,
|
||||||
|
pnet.PHYSICAL_NETWORK)) as net:
|
||||||
|
for k, v in expected:
|
||||||
|
self.assertEqual(net['network'][k], v)
|
||||||
|
|
||||||
|
# try to create another one on the same physical net will failure
|
||||||
|
res = self._create_network(
|
||||||
|
self.fmt, name, True,
|
||||||
|
providernet_args=providernet_args,
|
||||||
|
arg_list=(pnet.NETWORK_TYPE,
|
||||||
|
pnet.PHYSICAL_NETWORK))
|
||||||
|
data = self.deserialize(self.fmt, res)
|
||||||
|
self.assertIn('NeutronError', data)
|
||||||
|
|
||||||
def test_delete_network_after_removing_subnet(self):
|
def test_delete_network_after_removing_subnet(self):
|
||||||
gateway_ip = '10.0.0.1'
|
gateway_ip = '10.0.0.1'
|
||||||
cidr = '10.0.0.0/24'
|
cidr = '10.0.0.0/24'
|
||||||
|
@ -1109,7 +1109,7 @@ class FakeVcns(object):
|
|||||||
|
|
||||||
def create_spoofguard_policy(self, enforcement_points, name, enable):
|
def create_spoofguard_policy(self, enforcement_points, name, enable):
|
||||||
policy = {'name': name,
|
policy = {'name': name,
|
||||||
'enforcement_point': enforcement_points[0],
|
'enforcementPoints': [{'id': enforcement_points[0]}],
|
||||||
'operationMode': 'MANUAL' if enable else 'DISABLE'}
|
'operationMode': 'MANUAL' if enable else 'DISABLE'}
|
||||||
policy_id = len(self._spoofguard_policies)
|
policy_id = len(self._spoofguard_policies)
|
||||||
self._spoofguard_policies.append(policy)
|
self._spoofguard_policies.append(policy)
|
||||||
@ -1118,7 +1118,7 @@ class FakeVcns(object):
|
|||||||
def update_spoofguard_policy(self, policy_id,
|
def update_spoofguard_policy(self, policy_id,
|
||||||
enforcement_points, name, enable):
|
enforcement_points, name, enable):
|
||||||
policy = {'name': name,
|
policy = {'name': name,
|
||||||
'enforcement_point': enforcement_points[0],
|
'enforcementPoints': [{'id': enforcement_points[0]}],
|
||||||
'operationMode': 'MANUAL' if enable else 'DISABLE'}
|
'operationMode': 'MANUAL' if enable else 'DISABLE'}
|
||||||
self._spoofguard_policies[int(policy_id)] = policy
|
self._spoofguard_policies[int(policy_id)] = policy
|
||||||
return None, ''
|
return None, ''
|
||||||
|
Loading…
Reference in New Issue
Block a user