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:
Miguel Lavalle 2018-05-29 18:17:47 -05:00
parent f7b62a7f29
commit 03db94ebaa
12 changed files with 44 additions and 39 deletions

View File

@ -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,

View File

@ -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(

View File

@ -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

View File

@ -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', )

View File

@ -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'])

View File

@ -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

View File

@ -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

View File

@ -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',

View File

@ -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')

View File

@ -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(

View File

@ -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({

View File

@ -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({