Fixes Tempest XML test failures for Cisco N1kv plugin
Renamed N1kv_profile class to N1kv. Modified N1kv attribute extension class to fix XML namespace issues. Change-Id: I29b541730fc95c5e16667b64efd180be31e25b17 Closes-Bug: #1282352
This commit is contained in:
parent
46e2c5b4ae
commit
546259bce3
@ -19,6 +19,7 @@
|
|||||||
# @author: Aruna Kushwaha, Cisco Systems, Inc.
|
# @author: Aruna Kushwaha, Cisco Systems, Inc.
|
||||||
# @author: Sergey Sudakovich, Cisco Systems, Inc.
|
# @author: Sergey Sudakovich, Cisco Systems, Inc.
|
||||||
|
|
||||||
|
from neutron.api import extensions
|
||||||
from neutron.api.v2 import attributes
|
from neutron.api.v2 import attributes
|
||||||
|
|
||||||
|
|
||||||
@ -56,7 +57,7 @@ EXTENDED_ATTRIBUTES_2_0 = {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
class N1kv_profile(object):
|
class N1kv(extensions.ExtensionDescriptor):
|
||||||
|
|
||||||
"""Extension class supporting N1kv profiles.
|
"""Extension class supporting N1kv profiles.
|
||||||
|
|
||||||
@ -80,11 +81,11 @@ class N1kv_profile(object):
|
|||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def get_name(cls):
|
def get_name(cls):
|
||||||
return "n1kv_profile"
|
return "n1kv"
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def get_alias(cls):
|
def get_alias(cls):
|
||||||
return "n1kv_profile"
|
return "n1kv"
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def get_description(cls):
|
def get_description(cls):
|
||||||
@ -92,7 +93,7 @@ class N1kv_profile(object):
|
|||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def get_namespace(cls):
|
def get_namespace(cls):
|
||||||
return "http://docs.openstack.org/ext/n1kv_profile/api/v2.0"
|
return "http://docs.openstack.org/ext/n1kv/api/v2.0"
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def get_updated(cls):
|
def get_updated(cls):
|
@ -28,7 +28,7 @@ from neutron.plugins.cisco.common import cisco_constants as c_const
|
|||||||
from neutron.plugins.cisco.common import cisco_credentials_v2 as c_cred
|
from neutron.plugins.cisco.common import cisco_credentials_v2 as c_cred
|
||||||
from neutron.plugins.cisco.common import cisco_exceptions as c_exc
|
from neutron.plugins.cisco.common import cisco_exceptions as c_exc
|
||||||
from neutron.plugins.cisco.db import network_db_v2
|
from neutron.plugins.cisco.db import network_db_v2
|
||||||
from neutron.plugins.cisco.extensions import n1kv_profile
|
from neutron.plugins.cisco.extensions import n1kv
|
||||||
from neutron import wsgi
|
from neutron import wsgi
|
||||||
|
|
||||||
LOG = logging.getLogger(__name__)
|
LOG = logging.getLogger(__name__)
|
||||||
@ -180,7 +180,7 @@ class Client(object):
|
|||||||
'subType': overlay_subtype,
|
'subType': overlay_subtype,
|
||||||
'tenantId': network['tenant_id']}
|
'tenantId': network['tenant_id']}
|
||||||
if overlay_subtype == c_const.NETWORK_SUBTYPE_NATIVE_VXLAN:
|
if overlay_subtype == c_const.NETWORK_SUBTYPE_NATIVE_VXLAN:
|
||||||
body['groupIp'] = network[n1kv_profile.MULTICAST_IP]
|
body['groupIp'] = network[n1kv.MULTICAST_IP]
|
||||||
return self._post(self.bridge_domains_path,
|
return self._post(self.bridge_domains_path,
|
||||||
body=body)
|
body=body)
|
||||||
|
|
||||||
|
@ -48,7 +48,7 @@ from neutron.plugins.cisco.common import cisco_exceptions
|
|||||||
from neutron.plugins.cisco.common import config as c_conf
|
from neutron.plugins.cisco.common import config as c_conf
|
||||||
from neutron.plugins.cisco.db import n1kv_db_v2
|
from neutron.plugins.cisco.db import n1kv_db_v2
|
||||||
from neutron.plugins.cisco.db import network_db_v2
|
from neutron.plugins.cisco.db import network_db_v2
|
||||||
from neutron.plugins.cisco.extensions import n1kv_profile
|
from neutron.plugins.cisco.extensions import n1kv
|
||||||
from neutron.plugins.cisco.n1kv import n1kv_client
|
from neutron.plugins.cisco.n1kv import n1kv_client
|
||||||
from neutron.plugins.common import constants as svc_constants
|
from neutron.plugins.common import constants as svc_constants
|
||||||
|
|
||||||
@ -146,7 +146,7 @@ class N1kvNeutronPluginV2(db_base_plugin_v2.NeutronDbPluginV2,
|
|||||||
# bulk operations.
|
# bulk operations.
|
||||||
__native_bulk_support = False
|
__native_bulk_support = False
|
||||||
supported_extension_aliases = ["provider", "agent",
|
supported_extension_aliases = ["provider", "agent",
|
||||||
"n1kv_profile", "network_profile",
|
"n1kv", "network_profile",
|
||||||
"policy_profile", "external-net", "router",
|
"policy_profile", "external-net", "router",
|
||||||
"credential"]
|
"credential"]
|
||||||
|
|
||||||
@ -288,18 +288,18 @@ class N1kvNeutronPluginV2(db_base_plugin_v2.NeutronDbPluginV2,
|
|||||||
if binding.network_type == c_const.NETWORK_TYPE_OVERLAY:
|
if binding.network_type == c_const.NETWORK_TYPE_OVERLAY:
|
||||||
network[providernet.PHYSICAL_NETWORK] = None
|
network[providernet.PHYSICAL_NETWORK] = None
|
||||||
network[providernet.SEGMENTATION_ID] = binding.segmentation_id
|
network[providernet.SEGMENTATION_ID] = binding.segmentation_id
|
||||||
network[n1kv_profile.MULTICAST_IP] = binding.multicast_ip
|
network[n1kv.MULTICAST_IP] = binding.multicast_ip
|
||||||
elif binding.network_type == c_const.NETWORK_TYPE_VLAN:
|
elif binding.network_type == c_const.NETWORK_TYPE_VLAN:
|
||||||
network[providernet.PHYSICAL_NETWORK] = binding.physical_network
|
network[providernet.PHYSICAL_NETWORK] = binding.physical_network
|
||||||
network[providernet.SEGMENTATION_ID] = binding.segmentation_id
|
network[providernet.SEGMENTATION_ID] = binding.segmentation_id
|
||||||
elif binding.network_type == c_const.NETWORK_TYPE_TRUNK:
|
elif binding.network_type == c_const.NETWORK_TYPE_TRUNK:
|
||||||
network[providernet.PHYSICAL_NETWORK] = binding.physical_network
|
network[providernet.PHYSICAL_NETWORK] = binding.physical_network
|
||||||
network[providernet.SEGMENTATION_ID] = None
|
network[providernet.SEGMENTATION_ID] = None
|
||||||
network[n1kv_profile.MULTICAST_IP] = None
|
network[n1kv.MULTICAST_IP] = None
|
||||||
elif binding.network_type == c_const.NETWORK_TYPE_MULTI_SEGMENT:
|
elif binding.network_type == c_const.NETWORK_TYPE_MULTI_SEGMENT:
|
||||||
network[providernet.PHYSICAL_NETWORK] = None
|
network[providernet.PHYSICAL_NETWORK] = None
|
||||||
network[providernet.SEGMENTATION_ID] = None
|
network[providernet.SEGMENTATION_ID] = None
|
||||||
network[n1kv_profile.MULTICAST_IP] = None
|
network[n1kv.MULTICAST_IP] = None
|
||||||
|
|
||||||
def _process_provider_create(self, context, attrs):
|
def _process_provider_create(self, context, attrs):
|
||||||
network_type = attrs.get(providernet.NETWORK_TYPE)
|
network_type = attrs.get(providernet.NETWORK_TYPE)
|
||||||
@ -537,9 +537,9 @@ class N1kvNeutronPluginV2(db_base_plugin_v2.NeutronDbPluginV2,
|
|||||||
member_dict = {'segment': net['name'],
|
member_dict = {'segment': net['name'],
|
||||||
'dot1qtag': dot1qtag}
|
'dot1qtag': dot1qtag}
|
||||||
trunk_list.append(member_dict)
|
trunk_list.append(member_dict)
|
||||||
if oper == n1kv_profile.SEGMENT_ADD:
|
if oper == n1kv.SEGMENT_ADD:
|
||||||
network['add_segment_list'] = trunk_list
|
network['add_segment_list'] = trunk_list
|
||||||
elif oper == n1kv_profile.SEGMENT_DEL:
|
elif oper == n1kv.SEGMENT_DEL:
|
||||||
network['del_segment_list'] = trunk_list
|
network['del_segment_list'] = trunk_list
|
||||||
|
|
||||||
def _parse_multi_segments(self, context, attrs, param):
|
def _parse_multi_segments(self, context, attrs, param):
|
||||||
@ -649,23 +649,23 @@ class N1kvNeutronPluginV2(db_base_plugin_v2.NeutronDbPluginV2,
|
|||||||
elif binding.network_type == c_const.NETWORK_TYPE_MULTI_SEGMENT:
|
elif binding.network_type == c_const.NETWORK_TYPE_MULTI_SEGMENT:
|
||||||
members = n1kv_db_v2.get_multi_segment_members(context.session,
|
members = n1kv_db_v2.get_multi_segment_members(context.session,
|
||||||
network['id'])
|
network['id'])
|
||||||
network[n1kv_profile.MEMBER_SEGMENTS] = members
|
network[n1kv.MEMBER_SEGMENTS] = members
|
||||||
|
|
||||||
def _extend_network_dict_profile(self, context, network):
|
def _extend_network_dict_profile(self, context, network):
|
||||||
"""Add the extended parameter network profile to the network."""
|
"""Add the extended parameter network profile to the network."""
|
||||||
binding = n1kv_db_v2.get_network_binding(context.session,
|
binding = n1kv_db_v2.get_network_binding(context.session,
|
||||||
network['id'])
|
network['id'])
|
||||||
network[n1kv_profile.PROFILE_ID] = binding.profile_id
|
network[n1kv.PROFILE_ID] = binding.profile_id
|
||||||
|
|
||||||
def _extend_port_dict_profile(self, context, port):
|
def _extend_port_dict_profile(self, context, port):
|
||||||
"""Add the extended parameter port profile to the port."""
|
"""Add the extended parameter port profile to the port."""
|
||||||
binding = n1kv_db_v2.get_port_binding(context.session,
|
binding = n1kv_db_v2.get_port_binding(context.session,
|
||||||
port['id'])
|
port['id'])
|
||||||
port[n1kv_profile.PROFILE_ID] = binding.profile_id
|
port[n1kv.PROFILE_ID] = binding.profile_id
|
||||||
|
|
||||||
def _process_network_profile(self, context, network):
|
def _process_network_profile(self, context, network):
|
||||||
"""Validate network profile exists."""
|
"""Validate network profile exists."""
|
||||||
profile_id = network.get(n1kv_profile.PROFILE_ID)
|
profile_id = network.get(n1kv.PROFILE_ID)
|
||||||
profile_id_set = attributes.is_attr_set(profile_id)
|
profile_id_set = attributes.is_attr_set(profile_id)
|
||||||
if not profile_id_set:
|
if not profile_id_set:
|
||||||
profile_name = c_conf.CISCO_N1K.default_network_profile
|
profile_name = c_conf.CISCO_N1K.default_network_profile
|
||||||
@ -677,7 +677,7 @@ class N1kvNeutronPluginV2(db_base_plugin_v2.NeutronDbPluginV2,
|
|||||||
|
|
||||||
def _process_policy_profile(self, context, attrs):
|
def _process_policy_profile(self, context, attrs):
|
||||||
"""Validates whether policy profile exists."""
|
"""Validates whether policy profile exists."""
|
||||||
profile_id = attrs.get(n1kv_profile.PROFILE_ID)
|
profile_id = attrs.get(n1kv.PROFILE_ID)
|
||||||
profile_id_set = attributes.is_attr_set(profile_id)
|
profile_id_set = attributes.is_attr_set(profile_id)
|
||||||
if not profile_id_set:
|
if not profile_id_set:
|
||||||
msg = _("n1kv:profile_id does not exist")
|
msg = _("n1kv:profile_id does not exist")
|
||||||
@ -755,13 +755,13 @@ class N1kvNeutronPluginV2(db_base_plugin_v2.NeutronDbPluginV2,
|
|||||||
"""
|
"""
|
||||||
LOG.debug(_('_send_create_network_request: %s'), network['id'])
|
LOG.debug(_('_send_create_network_request: %s'), network['id'])
|
||||||
profile = self.get_network_profile(context,
|
profile = self.get_network_profile(context,
|
||||||
network[n1kv_profile.PROFILE_ID])
|
network[n1kv.PROFILE_ID])
|
||||||
n1kvclient = n1kv_client.Client()
|
n1kvclient = n1kv_client.Client()
|
||||||
if network[providernet.NETWORK_TYPE] == c_const.NETWORK_TYPE_OVERLAY:
|
if network[providernet.NETWORK_TYPE] == c_const.NETWORK_TYPE_OVERLAY:
|
||||||
n1kvclient.create_bridge_domain(network, profile['sub_type'])
|
n1kvclient.create_bridge_domain(network, profile['sub_type'])
|
||||||
if network[providernet.NETWORK_TYPE] == c_const.NETWORK_TYPE_TRUNK:
|
if network[providernet.NETWORK_TYPE] == c_const.NETWORK_TYPE_TRUNK:
|
||||||
self._populate_member_segments(context, network, segment_pairs,
|
self._populate_member_segments(context, network, segment_pairs,
|
||||||
n1kv_profile.SEGMENT_ADD)
|
n1kv.SEGMENT_ADD)
|
||||||
network['del_segment_list'] = []
|
network['del_segment_list'] = []
|
||||||
if profile['sub_type'] == c_const.NETWORK_TYPE_OVERLAY:
|
if profile['sub_type'] == c_const.NETWORK_TYPE_OVERLAY:
|
||||||
encap_dict = {'name': (network['name'] +
|
encap_dict = {'name': (network['name'] +
|
||||||
@ -788,7 +788,7 @@ class N1kvNeutronPluginV2(db_base_plugin_v2.NeutronDbPluginV2,
|
|||||||
LOG.debug(_('_send_update_network_request: %s'), network['id'])
|
LOG.debug(_('_send_update_network_request: %s'), network['id'])
|
||||||
db_session = context.session
|
db_session = context.session
|
||||||
profile = n1kv_db_v2.get_network_profile(
|
profile = n1kv_db_v2.get_network_profile(
|
||||||
db_session, network[n1kv_profile.PROFILE_ID])
|
db_session, network[n1kv.PROFILE_ID])
|
||||||
n1kvclient = n1kv_client.Client()
|
n1kvclient = n1kv_client.Client()
|
||||||
body = {'publishName': network['name'],
|
body = {'publishName': network['name'],
|
||||||
'id': network['id'],
|
'id': network['id'],
|
||||||
@ -800,9 +800,9 @@ class N1kvNeutronPluginV2(db_base_plugin_v2.NeutronDbPluginV2,
|
|||||||
'delSegments': []}
|
'delSegments': []}
|
||||||
if network[providernet.NETWORK_TYPE] == c_const.NETWORK_TYPE_TRUNK:
|
if network[providernet.NETWORK_TYPE] == c_const.NETWORK_TYPE_TRUNK:
|
||||||
self._populate_member_segments(context, network, add_segments,
|
self._populate_member_segments(context, network, add_segments,
|
||||||
n1kv_profile.SEGMENT_ADD)
|
n1kv.SEGMENT_ADD)
|
||||||
self._populate_member_segments(context, network, del_segments,
|
self._populate_member_segments(context, network, del_segments,
|
||||||
n1kv_profile.SEGMENT_DEL)
|
n1kv.SEGMENT_DEL)
|
||||||
body['mode'] = c_const.NETWORK_TYPE_TRUNK
|
body['mode'] = c_const.NETWORK_TYPE_TRUNK
|
||||||
body['segmentType'] = profile['sub_type']
|
body['segmentType'] = profile['sub_type']
|
||||||
body['addSegments'] = network['add_segment_list']
|
body['addSegments'] = network['add_segment_list']
|
||||||
@ -840,7 +840,7 @@ class N1kvNeutronPluginV2(db_base_plugin_v2.NeutronDbPluginV2,
|
|||||||
n1kvclient.delete_bridge_domain(name)
|
n1kvclient.delete_bridge_domain(name)
|
||||||
elif network[providernet.NETWORK_TYPE] == c_const.NETWORK_TYPE_TRUNK:
|
elif network[providernet.NETWORK_TYPE] == c_const.NETWORK_TYPE_TRUNK:
|
||||||
profile = self.get_network_profile(
|
profile = self.get_network_profile(
|
||||||
context, network[n1kv_profile.PROFILE_ID])
|
context, network[n1kv.PROFILE_ID])
|
||||||
if profile['sub_type'] == c_const.NETWORK_TYPE_OVERLAY:
|
if profile['sub_type'] == c_const.NETWORK_TYPE_OVERLAY:
|
||||||
profile_name = (network['id'] +
|
profile_name = (network['id'] +
|
||||||
c_const.ENCAPSULATION_PROFILE_SUFFIX)
|
c_const.ENCAPSULATION_PROFILE_SUFFIX)
|
||||||
@ -905,18 +905,18 @@ class N1kvNeutronPluginV2(db_base_plugin_v2.NeutronDbPluginV2,
|
|||||||
try:
|
try:
|
||||||
vm_network = n1kv_db_v2.get_vm_network(
|
vm_network = n1kv_db_v2.get_vm_network(
|
||||||
context.session,
|
context.session,
|
||||||
port[n1kv_profile.PROFILE_ID],
|
port[n1kv.PROFILE_ID],
|
||||||
port['network_id'])
|
port['network_id'])
|
||||||
except cisco_exceptions.VMNetworkNotFound:
|
except cisco_exceptions.VMNetworkNotFound:
|
||||||
policy_profile = n1kv_db_v2.get_policy_profile(
|
policy_profile = n1kv_db_v2.get_policy_profile(
|
||||||
context.session, port[n1kv_profile.PROFILE_ID])
|
context.session, port[n1kv.PROFILE_ID])
|
||||||
vm_network_name = (c_const.VM_NETWORK_NAME_PREFIX +
|
vm_network_name = (c_const.VM_NETWORK_NAME_PREFIX +
|
||||||
str(port[n1kv_profile.PROFILE_ID]) +
|
str(port[n1kv.PROFILE_ID]) +
|
||||||
"_" + str(port['network_id']))
|
"_" + str(port['network_id']))
|
||||||
port_count = 1
|
port_count = 1
|
||||||
n1kv_db_v2.add_vm_network(context.session,
|
n1kv_db_v2.add_vm_network(context.session,
|
||||||
vm_network_name,
|
vm_network_name,
|
||||||
port[n1kv_profile.PROFILE_ID],
|
port[n1kv.PROFILE_ID],
|
||||||
port['network_id'],
|
port['network_id'],
|
||||||
port_count)
|
port_count)
|
||||||
n1kvclient = n1kv_client.Client()
|
n1kvclient = n1kv_client.Client()
|
||||||
@ -958,7 +958,7 @@ class N1kvNeutronPluginV2(db_base_plugin_v2.NeutronDbPluginV2,
|
|||||||
LOG.debug(_('_send_delete_port_request: %s'), id)
|
LOG.debug(_('_send_delete_port_request: %s'), id)
|
||||||
port = self.get_port(context, id)
|
port = self.get_port(context, id)
|
||||||
vm_network = n1kv_db_v2.get_vm_network(context.session,
|
vm_network = n1kv_db_v2.get_vm_network(context.session,
|
||||||
port[n1kv_profile.PROFILE_ID],
|
port[n1kv.PROFILE_ID],
|
||||||
port['network_id'])
|
port['network_id'])
|
||||||
vm_network['port_count'] -= 1
|
vm_network['port_count'] -= 1
|
||||||
n1kv_db_v2.update_vm_network_port_count(
|
n1kv_db_v2.update_vm_network_port_count(
|
||||||
@ -967,7 +967,7 @@ class N1kvNeutronPluginV2(db_base_plugin_v2.NeutronDbPluginV2,
|
|||||||
n1kvclient.delete_n1kv_port(vm_network['name'], id)
|
n1kvclient.delete_n1kv_port(vm_network['name'], id)
|
||||||
if vm_network['port_count'] == 0:
|
if vm_network['port_count'] == 0:
|
||||||
n1kv_db_v2.delete_vm_network(context.session,
|
n1kv_db_v2.delete_vm_network(context.session,
|
||||||
port[n1kv_profile.PROFILE_ID],
|
port[n1kv.PROFILE_ID],
|
||||||
port['network_id'])
|
port['network_id'])
|
||||||
n1kvclient.delete_vm_network(vm_network['name'])
|
n1kvclient.delete_vm_network(vm_network['name'])
|
||||||
|
|
||||||
@ -1015,14 +1015,14 @@ class N1kvNeutronPluginV2(db_base_plugin_v2.NeutronDbPluginV2,
|
|||||||
if network_type == c_const.NETWORK_TYPE_MULTI_SEGMENT:
|
if network_type == c_const.NETWORK_TYPE_MULTI_SEGMENT:
|
||||||
segment_pairs = (
|
segment_pairs = (
|
||||||
self._parse_multi_segments(context, network['network'],
|
self._parse_multi_segments(context, network['network'],
|
||||||
n1kv_profile.SEGMENT_ADD))
|
n1kv.SEGMENT_ADD))
|
||||||
LOG.debug(_('Seg list %s '), segment_pairs)
|
LOG.debug(_('Seg list %s '), segment_pairs)
|
||||||
elif network_type == c_const.NETWORK_TYPE_TRUNK:
|
elif network_type == c_const.NETWORK_TYPE_TRUNK:
|
||||||
network_profile = self.get_network_profile(context,
|
network_profile = self.get_network_profile(context,
|
||||||
profile_id)
|
profile_id)
|
||||||
segment_pairs = (
|
segment_pairs = (
|
||||||
self._parse_trunk_segments(context, network['network'],
|
self._parse_trunk_segments(context, network['network'],
|
||||||
n1kv_profile.SEGMENT_ADD,
|
n1kv.SEGMENT_ADD,
|
||||||
physical_network,
|
physical_network,
|
||||||
network_profile['sub_type']
|
network_profile['sub_type']
|
||||||
))
|
))
|
||||||
@ -1093,12 +1093,12 @@ class N1kvNeutronPluginV2(db_base_plugin_v2.NeutronDbPluginV2,
|
|||||||
if binding.network_type == c_const.NETWORK_TYPE_MULTI_SEGMENT:
|
if binding.network_type == c_const.NETWORK_TYPE_MULTI_SEGMENT:
|
||||||
add_segments = (
|
add_segments = (
|
||||||
self._parse_multi_segments(context, network['network'],
|
self._parse_multi_segments(context, network['network'],
|
||||||
n1kv_profile.SEGMENT_ADD))
|
n1kv.SEGMENT_ADD))
|
||||||
n1kv_db_v2.add_multi_segment_binding(session,
|
n1kv_db_v2.add_multi_segment_binding(session,
|
||||||
net['id'], add_segments)
|
net['id'], add_segments)
|
||||||
del_segments = (
|
del_segments = (
|
||||||
self._parse_multi_segments(context, network['network'],
|
self._parse_multi_segments(context, network['network'],
|
||||||
n1kv_profile.SEGMENT_DEL))
|
n1kv.SEGMENT_DEL))
|
||||||
self._send_add_multi_segment_request(context, net['id'],
|
self._send_add_multi_segment_request(context, net['id'],
|
||||||
add_segments)
|
add_segments)
|
||||||
self._send_del_multi_segment_request(context, net['id'],
|
self._send_del_multi_segment_request(context, net['id'],
|
||||||
@ -1110,14 +1110,14 @@ class N1kvNeutronPluginV2(db_base_plugin_v2.NeutronDbPluginV2,
|
|||||||
binding.profile_id)
|
binding.profile_id)
|
||||||
add_segments = (
|
add_segments = (
|
||||||
self._parse_trunk_segments(context, network['network'],
|
self._parse_trunk_segments(context, network['network'],
|
||||||
n1kv_profile.SEGMENT_ADD,
|
n1kv.SEGMENT_ADD,
|
||||||
binding.physical_network,
|
binding.physical_network,
|
||||||
network_profile['sub_type']))
|
network_profile['sub_type']))
|
||||||
n1kv_db_v2.add_trunk_segment_binding(session,
|
n1kv_db_v2.add_trunk_segment_binding(session,
|
||||||
net['id'], add_segments)
|
net['id'], add_segments)
|
||||||
del_segments = (
|
del_segments = (
|
||||||
self._parse_trunk_segments(context, network['network'],
|
self._parse_trunk_segments(context, network['network'],
|
||||||
n1kv_profile.SEGMENT_DEL,
|
n1kv.SEGMENT_DEL,
|
||||||
binding.physical_network,
|
binding.physical_network,
|
||||||
network_profile['sub_type']))
|
network_profile['sub_type']))
|
||||||
n1kv_db_v2.del_trunk_segment_binding(session,
|
n1kv_db_v2.del_trunk_segment_binding(session,
|
||||||
@ -1226,8 +1226,8 @@ class N1kvNeutronPluginV2(db_base_plugin_v2.NeutronDbPluginV2,
|
|||||||
port['port']['n1kv:profile_id'] = p_profile['id']
|
port['port']['n1kv:profile_id'] = p_profile['id']
|
||||||
|
|
||||||
profile_id_set = False
|
profile_id_set = False
|
||||||
if n1kv_profile.PROFILE_ID in port['port']:
|
if n1kv.PROFILE_ID in port['port']:
|
||||||
profile_id = port['port'].get(n1kv_profile.PROFILE_ID)
|
profile_id = port['port'].get(n1kv.PROFILE_ID)
|
||||||
profile_id_set = attributes.is_attr_set(profile_id)
|
profile_id_set = attributes.is_attr_set(profile_id)
|
||||||
|
|
||||||
if not profile_id_set:
|
if not profile_id_set:
|
||||||
|
@ -27,7 +27,7 @@ import neutron.db.api as db
|
|||||||
from neutron.plugins.cisco.db import n1kv_db_v2
|
from neutron.plugins.cisco.db import n1kv_db_v2
|
||||||
from neutron.plugins.cisco.db import network_db_v2 as cdb
|
from neutron.plugins.cisco.db import network_db_v2 as cdb
|
||||||
from neutron.plugins.cisco import extensions
|
from neutron.plugins.cisco import extensions
|
||||||
from neutron.plugins.cisco.extensions import n1kv_profile
|
from neutron.plugins.cisco.extensions import n1kv
|
||||||
from neutron.plugins.cisco.extensions import network_profile
|
from neutron.plugins.cisco.extensions import network_profile
|
||||||
from neutron.plugins.cisco.n1kv import n1kv_client
|
from neutron.plugins.cisco.n1kv import n1kv_client
|
||||||
from neutron.plugins.cisco.n1kv import n1kv_neutron_plugin
|
from neutron.plugins.cisco.n1kv import n1kv_neutron_plugin
|
||||||
@ -212,9 +212,9 @@ class N1kvPluginTestCase(test_plugin.NeutronDbPluginV2TestCase):
|
|||||||
self.saved_attr_map[resource] = attrs.copy()
|
self.saved_attr_map[resource] = attrs.copy()
|
||||||
# Update the RESOURCE_ATTRIBUTE_MAP with n1kv specific extended attrs.
|
# Update the RESOURCE_ATTRIBUTE_MAP with n1kv specific extended attrs.
|
||||||
attributes.RESOURCE_ATTRIBUTE_MAP["networks"].update(
|
attributes.RESOURCE_ATTRIBUTE_MAP["networks"].update(
|
||||||
n1kv_profile.EXTENDED_ATTRIBUTES_2_0["networks"])
|
n1kv.EXTENDED_ATTRIBUTES_2_0["networks"])
|
||||||
attributes.RESOURCE_ATTRIBUTE_MAP["ports"].update(
|
attributes.RESOURCE_ATTRIBUTE_MAP["ports"].update(
|
||||||
n1kv_profile.EXTENDED_ATTRIBUTES_2_0["ports"])
|
n1kv.EXTENDED_ATTRIBUTES_2_0["ports"])
|
||||||
self.addCleanup(self.restore_resource_attribute_map)
|
self.addCleanup(self.restore_resource_attribute_map)
|
||||||
self.addCleanup(db.clear_db)
|
self.addCleanup(db.clear_db)
|
||||||
super(N1kvPluginTestCase, self).setUp(self._plugin_name,
|
super(N1kvPluginTestCase, self).setUp(self._plugin_name,
|
||||||
@ -307,32 +307,32 @@ class TestN1kvHTTPResponse(test_plugin.TestV2HTTPResponse,
|
|||||||
class TestN1kvPorts(test_plugin.TestPortsV2,
|
class TestN1kvPorts(test_plugin.TestPortsV2,
|
||||||
N1kvPluginTestCase):
|
N1kvPluginTestCase):
|
||||||
|
|
||||||
def test_create_port_with_default_n1kv_profile_id(self):
|
def test_create_port_with_default_n1kv_policy_profile_id(self):
|
||||||
"""Test port create without passing policy profile id."""
|
"""Test port create without passing policy profile id."""
|
||||||
with self.port() as port:
|
with self.port() as port:
|
||||||
db_session = db.get_session()
|
db_session = db.get_session()
|
||||||
pp = n1kv_db_v2.get_policy_profile(
|
pp = n1kv_db_v2.get_policy_profile(
|
||||||
db_session, port['port'][n1kv_profile.PROFILE_ID])
|
db_session, port['port'][n1kv.PROFILE_ID])
|
||||||
self.assertEqual(pp['name'], 'service_profile')
|
self.assertEqual(pp['name'], 'service_profile')
|
||||||
|
|
||||||
def test_create_port_with_n1kv_profile_id(self):
|
def test_create_port_with_n1kv_policy_profile_id(self):
|
||||||
"""Test port create with policy profile id."""
|
"""Test port create with policy profile id."""
|
||||||
profile_obj = self._make_test_policy_profile(name='test_profile')
|
profile_obj = self._make_test_policy_profile(name='test_profile')
|
||||||
with self.network() as network:
|
with self.network() as network:
|
||||||
data = {'port': {n1kv_profile.PROFILE_ID: profile_obj.id,
|
data = {'port': {n1kv.PROFILE_ID: profile_obj.id,
|
||||||
'tenant_id': self.tenant_id,
|
'tenant_id': self.tenant_id,
|
||||||
'network_id': network['network']['id']}}
|
'network_id': network['network']['id']}}
|
||||||
port_req = self.new_create_request('ports', data)
|
port_req = self.new_create_request('ports', data)
|
||||||
port = self.deserialize(self.fmt,
|
port = self.deserialize(self.fmt,
|
||||||
port_req.get_response(self.api))
|
port_req.get_response(self.api))
|
||||||
self.assertEqual(port['port'][n1kv_profile.PROFILE_ID],
|
self.assertEqual(port['port'][n1kv.PROFILE_ID],
|
||||||
profile_obj.id)
|
profile_obj.id)
|
||||||
self._delete('ports', port['port']['id'])
|
self._delete('ports', port['port']['id'])
|
||||||
|
|
||||||
def test_update_port_with_n1kv_profile_id(self):
|
def test_update_port_with_n1kv_policy_profile_id(self):
|
||||||
"""Test port update failure while updating policy profile id."""
|
"""Test port update failure while updating policy profile id."""
|
||||||
with self.port() as port:
|
with self.port() as port:
|
||||||
data = {'port': {n1kv_profile.PROFILE_ID: 'some-profile-uuid'}}
|
data = {'port': {n1kv.PROFILE_ID: 'some-profile-uuid'}}
|
||||||
port_req = self.new_update_request('ports',
|
port_req = self.new_update_request('ports',
|
||||||
data,
|
data,
|
||||||
port['port']['id'])
|
port['port']['id'])
|
||||||
@ -346,31 +346,31 @@ class TestN1kvNetworks(test_plugin.TestNetworksV2,
|
|||||||
|
|
||||||
def _prepare_net_data(self, net_profile_id):
|
def _prepare_net_data(self, net_profile_id):
|
||||||
return {'network': {'name': 'net1',
|
return {'network': {'name': 'net1',
|
||||||
n1kv_profile.PROFILE_ID: net_profile_id,
|
n1kv.PROFILE_ID: net_profile_id,
|
||||||
'tenant_id': self.tenant_id}}
|
'tenant_id': self.tenant_id}}
|
||||||
|
|
||||||
def test_create_network_with_default_n1kv_profile_id(self):
|
def test_create_network_with_default_n1kv_network_profile_id(self):
|
||||||
"""Test network create without passing network profile id."""
|
"""Test network create without passing network profile id."""
|
||||||
with self.network() as network:
|
with self.network() as network:
|
||||||
db_session = db.get_session()
|
db_session = db.get_session()
|
||||||
np = n1kv_db_v2.get_network_profile(
|
np = n1kv_db_v2.get_network_profile(
|
||||||
db_session, network['network'][n1kv_profile.PROFILE_ID])
|
db_session, network['network'][n1kv.PROFILE_ID])
|
||||||
self.assertEqual(np['name'], 'default_network_profile')
|
self.assertEqual(np['name'], 'default_network_profile')
|
||||||
|
|
||||||
def test_create_network_with_n1kv_profile_id(self):
|
def test_create_network_with_n1kv_network_profile_id(self):
|
||||||
"""Test network create with network profile id."""
|
"""Test network create with network profile id."""
|
||||||
profile_obj = self._make_test_profile(name='test_profile')
|
profile_obj = self._make_test_profile(name='test_profile')
|
||||||
data = self._prepare_net_data(profile_obj.id)
|
data = self._prepare_net_data(profile_obj.id)
|
||||||
network_req = self.new_create_request('networks', data)
|
network_req = self.new_create_request('networks', data)
|
||||||
network = self.deserialize(self.fmt,
|
network = self.deserialize(self.fmt,
|
||||||
network_req.get_response(self.api))
|
network_req.get_response(self.api))
|
||||||
self.assertEqual(network['network'][n1kv_profile.PROFILE_ID],
|
self.assertEqual(network['network'][n1kv.PROFILE_ID],
|
||||||
profile_obj.id)
|
profile_obj.id)
|
||||||
|
|
||||||
def test_update_network_with_n1kv_profile_id(self):
|
def test_update_network_with_n1kv_network_profile_id(self):
|
||||||
"""Test network update failure while updating network profile id."""
|
"""Test network update failure while updating network profile id."""
|
||||||
with self.network() as network:
|
with self.network() as network:
|
||||||
data = {'network': {n1kv_profile.PROFILE_ID: 'some-profile-uuid'}}
|
data = {'network': {n1kv.PROFILE_ID: 'some-profile-uuid'}}
|
||||||
network_req = self.new_update_request('networks',
|
network_req = self.new_update_request('networks',
|
||||||
data,
|
data,
|
||||||
network['network']['id'])
|
network['network']['id'])
|
||||||
|
Loading…
x
Reference in New Issue
Block a user