Pluralize binding relationship in Port
As a consequence of implementing multiple bindings for ports, [1] made the following attributes lists: - 'port_binding' in the in the SQLAlchemy Port model - 'binding' in the Port OVO This patch pluralizes their names to 'port_bindings' and 'bindings' respectively [1] Ie31d4e27e3f55edfe334c4029ca9ed685e684c39 Change-Id: I4ebe47cf9d51a700310aad8dcccc82fea3f00a16
This commit is contained in:
parent
f7b62a7f29
commit
03db94ebaa
@ -241,7 +241,7 @@ class CacheBackedPluginApi(PluginApi):
|
|||||||
mac_addr = str(netaddr.EUI(str(port_obj.mac_address),
|
mac_addr = str(netaddr.EUI(str(port_obj.mac_address),
|
||||||
dialect=netaddr.mac_unix_expanded))
|
dialect=netaddr.mac_unix_expanded))
|
||||||
binding = utils.get_port_binding_by_status_and_host(
|
binding = utils.get_port_binding_by_status_and_host(
|
||||||
port_obj.binding, constants.ACTIVE, raise_if_not_found=True,
|
port_obj.bindings, constants.ACTIVE, raise_if_not_found=True,
|
||||||
port_id=port_obj.id)
|
port_id=port_obj.id)
|
||||||
entry = {
|
entry = {
|
||||||
'device': device,
|
'device': device,
|
||||||
|
@ -284,7 +284,7 @@ class L3_DVRsch_db_mixin(l3agent_sch_db.L3AgentSchedulerDbMixin):
|
|||||||
query = context.session.query(
|
query = context.session.query(
|
||||||
models_v2.IPAllocation.subnet_id).distinct()
|
models_v2.IPAllocation.subnet_id).distinct()
|
||||||
query = query.join(models_v2.IPAllocation.port)
|
query = query.join(models_v2.IPAllocation.port)
|
||||||
query = query.join(models_v2.Port.port_binding)
|
query = query.join(models_v2.Port.port_bindings)
|
||||||
query = query.filter(ml2_models.PortBinding.host == host)
|
query = query.filter(ml2_models.PortBinding.host == host)
|
||||||
owner_filter = or_(
|
owner_filter = or_(
|
||||||
models_v2.Port.device_owner.startswith(
|
models_v2.Port.device_owner.startswith(
|
||||||
|
@ -283,7 +283,7 @@ class Port(base.NeutronDbObject):
|
|||||||
'allowed_address_pairs': obj_fields.ListOfObjectsField(
|
'allowed_address_pairs': obj_fields.ListOfObjectsField(
|
||||||
'AllowedAddressPair', nullable=True
|
'AllowedAddressPair', nullable=True
|
||||||
),
|
),
|
||||||
'binding': obj_fields.ListOfObjectsField(
|
'bindings': obj_fields.ListOfObjectsField(
|
||||||
'PortBinding', nullable=True
|
'PortBinding', nullable=True
|
||||||
),
|
),
|
||||||
'data_plane_status': obj_fields.ObjectField(
|
'data_plane_status': obj_fields.ObjectField(
|
||||||
@ -324,7 +324,7 @@ class Port(base.NeutronDbObject):
|
|||||||
|
|
||||||
synthetic_fields = [
|
synthetic_fields = [
|
||||||
'allowed_address_pairs',
|
'allowed_address_pairs',
|
||||||
'binding',
|
'bindings',
|
||||||
'binding_levels',
|
'binding_levels',
|
||||||
'data_plane_status',
|
'data_plane_status',
|
||||||
'dhcp_options',
|
'dhcp_options',
|
||||||
@ -337,7 +337,7 @@ class Port(base.NeutronDbObject):
|
|||||||
]
|
]
|
||||||
|
|
||||||
fields_need_translation = {
|
fields_need_translation = {
|
||||||
'binding': 'port_binding',
|
'bindings': 'port_bindings',
|
||||||
'dhcp_options': 'dhcp_opts',
|
'dhcp_options': 'dhcp_opts',
|
||||||
'distributed_bindings': 'distributed_port_binding',
|
'distributed_bindings': 'distributed_port_binding',
|
||||||
'security': 'port_security',
|
'security': 'port_security',
|
||||||
@ -479,10 +479,10 @@ class Port(base.NeutronDbObject):
|
|||||||
# Previous versions only support one port binding. The following
|
# Previous versions only support one port binding. The following
|
||||||
# lines look for the active port binding, which is the only one
|
# lines look for the active port binding, which is the only one
|
||||||
# needed in previous versions
|
# needed in previous versions
|
||||||
if 'binding' in primitive:
|
if 'bindings' in primitive:
|
||||||
original_binding = primitive['binding']
|
original_bindings = primitive.pop('bindings')
|
||||||
primitive['binding'] = None
|
primitive['binding'] = None
|
||||||
for a_binding in original_binding:
|
for a_binding in original_bindings:
|
||||||
if (a_binding['versioned_object.data']['status'] ==
|
if (a_binding['versioned_object.data']['status'] ==
|
||||||
constants.ACTIVE):
|
constants.ACTIVE):
|
||||||
primitive['binding'] = a_binding
|
primitive['binding'] = a_binding
|
||||||
|
@ -58,9 +58,7 @@ class PortBinding(model_base.BASEV2):
|
|||||||
port = orm.relationship(
|
port = orm.relationship(
|
||||||
models_v2.Port,
|
models_v2.Port,
|
||||||
load_on_pending=True,
|
load_on_pending=True,
|
||||||
# TODO(mlavalle) change name of the relationship to reflect that it is
|
backref=orm.backref("port_bindings",
|
||||||
# now an iterable
|
|
||||||
backref=orm.backref("port_binding",
|
|
||||||
lazy='joined',
|
lazy='joined',
|
||||||
cascade='delete'))
|
cascade='delete'))
|
||||||
revises_on_change = ('port', )
|
revises_on_change = ('port', )
|
||||||
|
@ -117,7 +117,7 @@ def _ml2_port_result_filter_hook(query, filters):
|
|||||||
if not values:
|
if not values:
|
||||||
return query
|
return query
|
||||||
bind_criteria = models.PortBinding.host.in_(values)
|
bind_criteria = models.PortBinding.host.in_(values)
|
||||||
return query.filter(models_v2.Port.port_binding.any(bind_criteria))
|
return query.filter(models_v2.Port.port_bindings.any(bind_criteria))
|
||||||
|
|
||||||
|
|
||||||
@resource_extend.has_resource_extenders
|
@resource_extend.has_resource_extenders
|
||||||
@ -247,7 +247,7 @@ class Ml2Plugin(db_base_plugin_v2.NeutronDbPluginV2,
|
|||||||
port_id = object_id
|
port_id = object_id
|
||||||
port = db.get_port(context, port_id)
|
port = db.get_port(context, port_id)
|
||||||
port_binding = utils.get_port_binding_by_status_and_host(
|
port_binding = utils.get_port_binding_by_status_and_host(
|
||||||
getattr(port, 'port_binding', []), const.ACTIVE)
|
getattr(port, 'port_bindings', []), const.ACTIVE)
|
||||||
if not port or not port_binding:
|
if not port or not port_binding:
|
||||||
LOG.debug("Port %s was deleted so its status cannot be updated.",
|
LOG.debug("Port %s was deleted so its status cannot be updated.",
|
||||||
port_id)
|
port_id)
|
||||||
@ -503,7 +503,7 @@ class Ml2Plugin(db_base_plugin_v2.NeutronDbPluginV2,
|
|||||||
try:
|
try:
|
||||||
port_db = self._get_port(plugin_context, port_id)
|
port_db = self._get_port(plugin_context, port_id)
|
||||||
cur_binding = utils.get_port_binding_by_status_and_host(
|
cur_binding = utils.get_port_binding_by_status_and_host(
|
||||||
port_db.port_binding, const.ACTIVE)
|
port_db.port_bindings, const.ACTIVE)
|
||||||
except exc.PortNotFound:
|
except exc.PortNotFound:
|
||||||
port_db, cur_binding = None, None
|
port_db, cur_binding = None, None
|
||||||
if not port_db or not cur_binding:
|
if not port_db or not cur_binding:
|
||||||
@ -551,7 +551,7 @@ class Ml2Plugin(db_base_plugin_v2.NeutronDbPluginV2,
|
|||||||
if new_binding.status == const.INACTIVE:
|
if new_binding.status == const.INACTIVE:
|
||||||
cur_context_binding = (
|
cur_context_binding = (
|
||||||
utils.get_port_binding_by_status_and_host(
|
utils.get_port_binding_by_status_and_host(
|
||||||
port_db.port_binding, const.INACTIVE,
|
port_db.port_bindings, const.INACTIVE,
|
||||||
host=new_binding.host))
|
host=new_binding.host))
|
||||||
cur_context = driver_context.PortContext(
|
cur_context = driver_context.PortContext(
|
||||||
self, plugin_context, port, network, cur_context_binding, None,
|
self, plugin_context, port, network, cur_context_binding, None,
|
||||||
@ -658,7 +658,7 @@ class Ml2Plugin(db_base_plugin_v2.NeutronDbPluginV2,
|
|||||||
def _ml2_extend_port_dict_binding(port_res, port_db):
|
def _ml2_extend_port_dict_binding(port_res, port_db):
|
||||||
plugin = directory.get_plugin()
|
plugin = directory.get_plugin()
|
||||||
port_binding = utils.get_port_binding_by_status_and_host(
|
port_binding = utils.get_port_binding_by_status_and_host(
|
||||||
port_db.port_binding, const.ACTIVE)
|
port_db.port_bindings, const.ACTIVE)
|
||||||
# None when called during unit tests for other plugins.
|
# None when called during unit tests for other plugins.
|
||||||
if port_binding:
|
if port_binding:
|
||||||
plugin._update_port_dict_binding(port_res, port_binding)
|
plugin._update_port_dict_binding(port_res, port_binding)
|
||||||
@ -1332,7 +1332,7 @@ class Ml2Plugin(db_base_plugin_v2.NeutronDbPluginV2,
|
|||||||
with db_api.context_manager.writer.using(context):
|
with db_api.context_manager.writer.using(context):
|
||||||
port_db = self._get_port(context, id)
|
port_db = self._get_port(context, id)
|
||||||
binding = utils.get_port_binding_by_status_and_host(
|
binding = utils.get_port_binding_by_status_and_host(
|
||||||
port_db.port_binding, const.ACTIVE)
|
port_db.port_bindings, const.ACTIVE)
|
||||||
if not binding:
|
if not binding:
|
||||||
raise exc.PortNotFound(port_id=id)
|
raise exc.PortNotFound(port_id=id)
|
||||||
mac_address_updated = self._check_mac_update_allowed(
|
mac_address_updated = self._check_mac_update_allowed(
|
||||||
@ -1551,7 +1551,7 @@ class Ml2Plugin(db_base_plugin_v2.NeutronDbPluginV2,
|
|||||||
try:
|
try:
|
||||||
port_db = self._get_port(context, id)
|
port_db = self._get_port(context, id)
|
||||||
binding = utils.get_port_binding_by_status_and_host(
|
binding = utils.get_port_binding_by_status_and_host(
|
||||||
port_db.port_binding, const.ACTIVE,
|
port_db.port_bindings, const.ACTIVE,
|
||||||
raise_if_not_found=True, port_id=id)
|
raise_if_not_found=True, port_id=id)
|
||||||
except exc.PortNotFound:
|
except exc.PortNotFound:
|
||||||
LOG.debug("The port '%s' was deleted", id)
|
LOG.debug("The port '%s' was deleted", id)
|
||||||
@ -1671,7 +1671,7 @@ class Ml2Plugin(db_base_plugin_v2.NeutronDbPluginV2,
|
|||||||
# concurrent port deletion.
|
# concurrent port deletion.
|
||||||
# It's not an error condition.
|
# It's not an error condition.
|
||||||
binding = utils.get_port_binding_by_status_and_host(
|
binding = utils.get_port_binding_by_status_and_host(
|
||||||
port_db.port_binding, const.ACTIVE)
|
port_db.port_bindings, const.ACTIVE)
|
||||||
if not binding:
|
if not binding:
|
||||||
LOG.info("Binding info for port %s was not found, "
|
LOG.info("Binding info for port %s was not found, "
|
||||||
"it might have been deleted already.",
|
"it might have been deleted already.",
|
||||||
@ -1715,7 +1715,7 @@ class Ml2Plugin(db_base_plugin_v2.NeutronDbPluginV2,
|
|||||||
bindlevelhost_match = host
|
bindlevelhost_match = host
|
||||||
else:
|
else:
|
||||||
binding = utils.get_port_binding_by_status_and_host(
|
binding = utils.get_port_binding_by_status_and_host(
|
||||||
port_db.port_binding, const.ACTIVE)
|
port_db.port_bindings, const.ACTIVE)
|
||||||
bindlevelhost_match = binding.host if binding else None
|
bindlevelhost_match = binding.host if binding else None
|
||||||
if not binding:
|
if not binding:
|
||||||
LOG.info("Binding info for port %s was not found, "
|
LOG.info("Binding info for port %s was not found, "
|
||||||
@ -1801,7 +1801,7 @@ class Ml2Plugin(db_base_plugin_v2.NeutronDbPluginV2,
|
|||||||
context.session.flush()
|
context.session.flush()
|
||||||
updated_port = self._make_port_dict(port)
|
updated_port = self._make_port_dict(port)
|
||||||
binding = utils.get_port_binding_by_status_and_host(
|
binding = utils.get_port_binding_by_status_and_host(
|
||||||
port.port_binding, const.ACTIVE, raise_if_not_found=True,
|
port.port_bindings, const.ACTIVE, raise_if_not_found=True,
|
||||||
port_id=port_id)
|
port_id=port_id)
|
||||||
levels = db.get_binding_levels(context, port.id, binding.host)
|
levels = db.get_binding_levels(context, port.id, binding.host)
|
||||||
mech_context = driver_context.PortContext(
|
mech_context = driver_context.PortContext(
|
||||||
@ -2047,14 +2047,14 @@ class Ml2Plugin(db_base_plugin_v2.NeutronDbPluginV2,
|
|||||||
with db_api.context_manager.writer.using(context):
|
with db_api.context_manager.writer.using(context):
|
||||||
port_db = self._get_port(context, port_id)
|
port_db = self._get_port(context, port_id)
|
||||||
self._validate_compute_port(port_db)
|
self._validate_compute_port(port_db)
|
||||||
if self._get_binding_for_host(port_db.port_binding,
|
if self._get_binding_for_host(port_db.port_bindings,
|
||||||
attrs[pbe_ext.HOST]):
|
attrs[pbe_ext.HOST]):
|
||||||
raise n_exc.PortBindingAlreadyExists(
|
raise n_exc.PortBindingAlreadyExists(
|
||||||
port_id=port_id, host=attrs[pbe_ext.HOST])
|
port_id=port_id, host=attrs[pbe_ext.HOST])
|
||||||
status = const.ACTIVE
|
status = const.ACTIVE
|
||||||
is_active_binding = True
|
is_active_binding = True
|
||||||
active_binding = utils.get_port_binding_by_status_and_host(
|
active_binding = utils.get_port_binding_by_status_and_host(
|
||||||
port_db.port_binding, const.ACTIVE)
|
port_db.port_bindings, const.ACTIVE)
|
||||||
if active_binding:
|
if active_binding:
|
||||||
status = const.INACTIVE
|
status = const.INACTIVE
|
||||||
is_active_binding = False
|
is_active_binding = False
|
||||||
@ -2128,8 +2128,8 @@ class Ml2Plugin(db_base_plugin_v2.NeutronDbPluginV2,
|
|||||||
with db_api.context_manager.writer.using(context):
|
with db_api.context_manager.writer.using(context):
|
||||||
port_db = self._get_port(context, port_id)
|
port_db = self._get_port(context, port_id)
|
||||||
self._validate_compute_port(port_db)
|
self._validate_compute_port(port_db)
|
||||||
original_binding = self._get_binding_for_host(port_db.port_binding,
|
original_binding = self._get_binding_for_host(
|
||||||
host)
|
port_db.port_bindings, host)
|
||||||
if not original_binding:
|
if not original_binding:
|
||||||
raise n_exc.PortBindingNotFound(port_id=port_id, host=host)
|
raise n_exc.PortBindingNotFound(port_id=port_id, host=host)
|
||||||
is_active_binding = (original_binding.status == const.ACTIVE)
|
is_active_binding = (original_binding.status == const.ACTIVE)
|
||||||
@ -2166,12 +2166,12 @@ class Ml2Plugin(db_base_plugin_v2.NeutronDbPluginV2,
|
|||||||
port_db = self._get_port(context, port_id)
|
port_db = self._get_port(context, port_id)
|
||||||
self._validate_compute_port(port_db)
|
self._validate_compute_port(port_db)
|
||||||
active_binding = utils.get_port_binding_by_status_and_host(
|
active_binding = utils.get_port_binding_by_status_and_host(
|
||||||
port_db.port_binding, const.ACTIVE)
|
port_db.port_bindings, const.ACTIVE)
|
||||||
if host == (active_binding and active_binding.host):
|
if host == (active_binding and active_binding.host):
|
||||||
raise n_exc.PortBindingAlreadyActive(port_id=port_id,
|
raise n_exc.PortBindingAlreadyActive(port_id=port_id,
|
||||||
host=host)
|
host=host)
|
||||||
inactive_binding = utils.get_port_binding_by_status_and_host(
|
inactive_binding = utils.get_port_binding_by_status_and_host(
|
||||||
port_db.port_binding, const.INACTIVE, host=host)
|
port_db.port_bindings, const.INACTIVE, host=host)
|
||||||
if not inactive_binding or inactive_binding.host != host:
|
if not inactive_binding or inactive_binding.host != host:
|
||||||
raise n_exc.PortBindingNotFound(port_id=port_id, host=host)
|
raise n_exc.PortBindingNotFound(port_id=port_id, host=host)
|
||||||
network = self.get_network(context, port_db['network_id'])
|
network = self.get_network(context, port_db['network_id'])
|
||||||
|
@ -96,7 +96,7 @@ def validate_log_type_for_port(log_type, port):
|
|||||||
log_plugin = directory.get_plugin(alias=plugin_const.LOG_API)
|
log_plugin = directory.get_plugin(alias=plugin_const.LOG_API)
|
||||||
drivers = log_plugin.driver_manager.drivers
|
drivers = log_plugin.driver_manager.drivers
|
||||||
port_binding = utils.get_port_binding_by_status_and_host(
|
port_binding = utils.get_port_binding_by_status_and_host(
|
||||||
port.binding, constants.ACTIVE, raise_if_not_found=True,
|
port.bindings, constants.ACTIVE, raise_if_not_found=True,
|
||||||
port_id=port['id'])
|
port_id=port['id'])
|
||||||
for driver in drivers:
|
for driver in drivers:
|
||||||
vif_type = port_binding.vif_type
|
vif_type = port_binding.vif_type
|
||||||
|
@ -137,7 +137,7 @@ class QosServiceDriverManager(object):
|
|||||||
|
|
||||||
def validate_rule_for_port(self, rule, port):
|
def validate_rule_for_port(self, rule, port):
|
||||||
port_binding = utils.get_port_binding_by_status_and_host(
|
port_binding = utils.get_port_binding_by_status_and_host(
|
||||||
port.binding, lib_constants.ACTIVE, raise_if_not_found=True,
|
port.bindings, lib_constants.ACTIVE, raise_if_not_found=True,
|
||||||
port_id=port['id'])
|
port_id=port['id'])
|
||||||
for driver in self._drivers:
|
for driver in self._drivers:
|
||||||
vif_type = port_binding.vif_type
|
vif_type = port_binding.vif_type
|
||||||
|
@ -62,7 +62,7 @@ object_data = {
|
|||||||
'NetworkPortSecurity': '1.0-b30802391a87945ee9c07582b4ff95e3',
|
'NetworkPortSecurity': '1.0-b30802391a87945ee9c07582b4ff95e3',
|
||||||
'NetworkRBAC': '1.0-c8a67f39809c5a3c8c7f26f2f2c620b2',
|
'NetworkRBAC': '1.0-c8a67f39809c5a3c8c7f26f2f2c620b2',
|
||||||
'NetworkSegment': '1.0-57b7f2960971e3b95ded20cbc59244a8',
|
'NetworkSegment': '1.0-57b7f2960971e3b95ded20cbc59244a8',
|
||||||
'Port': '1.4-c3937b92962d5b43a09a7de2f44e0ab7',
|
'Port': '1.4-1b6183bccfc2cd210919a1a72faefce1',
|
||||||
'PortBinding': '1.0-3306deeaa6deb01e33af06777d48d578',
|
'PortBinding': '1.0-3306deeaa6deb01e33af06777d48d578',
|
||||||
'PortBindingLevel': '1.1-50d47f63218f87581b6cd9a62db574e5',
|
'PortBindingLevel': '1.1-50d47f63218f87581b6cd9a62db574e5',
|
||||||
'PortDataPlaneStatus': '1.0-25be74bda46c749653a10357676c0ab2',
|
'PortDataPlaneStatus': '1.0-25be74bda46c749653a10357676c0ab2',
|
||||||
|
@ -446,9 +446,16 @@ class PortDbObjectTestCase(obj_test_base.BaseDbObjectTestCase,
|
|||||||
# Port has no active bindings, so binding attribute should be None
|
# Port has no active bindings, so binding attribute should be None
|
||||||
self.assertIsNone(port_v1_3['versioned_object.data']['binding'])
|
self.assertIsNone(port_v1_3['versioned_object.data']['binding'])
|
||||||
|
|
||||||
|
# bindings attribute in V1.4 port should have one inactive binding
|
||||||
|
primitive = port_v1_4.obj_to_primitive()
|
||||||
|
self.assertEqual(1,
|
||||||
|
len(primitive['versioned_object.data']['bindings']))
|
||||||
|
binding = primitive['versioned_object.data']['bindings'][0]
|
||||||
|
self.assertEqual(constants.INACTIVE,
|
||||||
|
binding['versioned_object.data']['status'])
|
||||||
|
|
||||||
# Port with no binding attribute should be handled without raising
|
# Port with no binding attribute should be handled without raising
|
||||||
# exception
|
# exception
|
||||||
primitive = port_v1_4.obj_to_primitive()
|
primitive['versioned_object.data'].pop('bindings')
|
||||||
primitive['versioned_object.data'].pop('binding')
|
|
||||||
port_v1_4_no_binding = port_v1_4.obj_from_primitive(primitive)
|
port_v1_4_no_binding = port_v1_4.obj_from_primitive(primitive)
|
||||||
port_v1_4_no_binding.obj_to_primitive(target_version='1.3')
|
port_v1_4_no_binding.obj_to_primitive(target_version='1.3')
|
||||||
|
@ -1808,7 +1808,7 @@ class TestMl2PortBinding(Ml2PluginV2TestCase,
|
|||||||
plugin = directory.get_plugin()
|
plugin = directory.get_plugin()
|
||||||
binding = utils.get_port_binding_by_status_and_host(
|
binding = utils.get_port_binding_by_status_and_host(
|
||||||
plugin._get_port(self.context,
|
plugin._get_port(self.context,
|
||||||
port['port']['id']).port_binding,
|
port['port']['id']).port_bindings,
|
||||||
constants.ACTIVE)
|
constants.ACTIVE)
|
||||||
binding['host'] = 'test'
|
binding['host'] = 'test'
|
||||||
mech_context = driver_context.PortContext(
|
mech_context = driver_context.PortContext(
|
||||||
@ -1831,7 +1831,7 @@ class TestMl2PortBinding(Ml2PluginV2TestCase,
|
|||||||
plugin = directory.get_plugin()
|
plugin = directory.get_plugin()
|
||||||
binding = utils.get_port_binding_by_status_and_host(
|
binding = utils.get_port_binding_by_status_and_host(
|
||||||
plugin._get_port(self.context,
|
plugin._get_port(self.context,
|
||||||
port['port']['id']).port_binding,
|
port['port']['id']).port_bindings,
|
||||||
constants.ACTIVE)
|
constants.ACTIVE)
|
||||||
binding['host'] = 'fake_host'
|
binding['host'] = 'fake_host'
|
||||||
binding['vif_type'] = port_vif_type
|
binding['vif_type'] = port_vif_type
|
||||||
@ -1948,7 +1948,7 @@ class TestMl2PortBinding(Ml2PluginV2TestCase,
|
|||||||
plugin = directory.get_plugin()
|
plugin = directory.get_plugin()
|
||||||
binding = utils.get_port_binding_by_status_and_host(
|
binding = utils.get_port_binding_by_status_and_host(
|
||||||
plugin._get_port(self.context,
|
plugin._get_port(self.context,
|
||||||
port['port']['id']).port_binding,
|
port['port']['id']).port_bindings,
|
||||||
constants.ACTIVE)
|
constants.ACTIVE)
|
||||||
with self.context.session.begin(subtransactions=True):
|
with self.context.session.begin(subtransactions=True):
|
||||||
binding.host = 'test'
|
binding.host = 'test'
|
||||||
@ -1970,7 +1970,7 @@ class TestMl2PortBinding(Ml2PluginV2TestCase,
|
|||||||
plugin = directory.get_plugin()
|
plugin = directory.get_plugin()
|
||||||
binding = utils.get_port_binding_by_status_and_host(
|
binding = utils.get_port_binding_by_status_and_host(
|
||||||
plugin._get_port(self.context,
|
plugin._get_port(self.context,
|
||||||
port['port']['id']).port_binding,
|
port['port']['id']).port_bindings,
|
||||||
constants.ACTIVE)
|
constants.ACTIVE)
|
||||||
binding['host'] = 'test'
|
binding['host'] = 'test'
|
||||||
mech_context = driver_context.PortContext(
|
mech_context = driver_context.PortContext(
|
||||||
@ -2959,7 +2959,7 @@ class TestML2Segments(Ml2PluginV2TestCase):
|
|||||||
with db_api.context_manager.writer.using(self.context):
|
with db_api.context_manager.writer.using(self.context):
|
||||||
binding = utils.get_port_binding_by_status_and_host(
|
binding = utils.get_port_binding_by_status_and_host(
|
||||||
plugin._get_port(self.context,
|
plugin._get_port(self.context,
|
||||||
port['port']['id']).port_binding,
|
port['port']['id']).port_bindings,
|
||||||
constants.ACTIVE)
|
constants.ACTIVE)
|
||||||
binding['host'] = 'host-ovs-no_filter'
|
binding['host'] = 'host-ovs-no_filter'
|
||||||
mech_context = driver_context.PortContext(
|
mech_context = driver_context.PortContext(
|
||||||
|
@ -105,7 +105,7 @@ class TestLogDriversLoggingTypeValidations(drv_mgr.TestLogDriversManagerBase):
|
|||||||
port_binding = ports.PortBinding(
|
port_binding = ports.PortBinding(
|
||||||
self.ctxt, port_id=port_id, vif_type=vif_type, vnic_type=vnic_type)
|
self.ctxt, port_id=port_id, vif_type=vif_type, vnic_type=vnic_type)
|
||||||
return ports.Port(
|
return ports.Port(
|
||||||
self.ctxt, id=uuidutils.generate_uuid(), binding=[port_binding])
|
self.ctxt, id=uuidutils.generate_uuid(), bindings=[port_binding])
|
||||||
|
|
||||||
def _test_validate_log_type_for_port(self, port, expected_result):
|
def _test_validate_log_type_for_port(self, port, expected_result):
|
||||||
driver_manager = self._create_manager_with_drivers({
|
driver_manager = self._create_manager_with_drivers({
|
||||||
|
@ -86,7 +86,7 @@ class TestQoSDriversRulesValidations(TestQosDriversManagerBase):
|
|||||||
port_binding = ports_object.PortBinding(
|
port_binding = ports_object.PortBinding(
|
||||||
self.ctxt, port_id=port_id, vif_type=vif_type, vnic_type=vnic_type)
|
self.ctxt, port_id=port_id, vif_type=vif_type, vnic_type=vnic_type)
|
||||||
return ports_object.Port(
|
return ports_object.Port(
|
||||||
self.ctxt, id=uuidutils.generate_uuid(), binding=[port_binding])
|
self.ctxt, id=uuidutils.generate_uuid(), bindings=[port_binding])
|
||||||
|
|
||||||
def _test_validate_rule_for_port(self, port, expected_result):
|
def _test_validate_rule_for_port(self, port, expected_result):
|
||||||
driver_manager = self._create_manager_with_drivers({
|
driver_manager = self._create_manager_with_drivers({
|
||||||
|
Loading…
Reference in New Issue
Block a user