Improve terminology in the Neutron tree

There is no real reason we should be using some of the
terms we do, they're outdated, and we're behind other
open-source projects in this respect. Let's switch to
using more inclusive terms in all possible places.

Change-Id: I99913107e803384b34cbd5ca588451b1cf64d594
This commit is contained in:
Brian Haley 2020-06-11 17:02:41 -04:00
parent 114ac0ae89
commit 055036ba2b
48 changed files with 416 additions and 392 deletions

View File

@ -16,15 +16,15 @@ SNAT high availability is implemented in a manner similar to the
:ref:`deploy-lb-ha-vrrp` and :ref:`deploy-ovs-ha-vrrp` examples where :ref:`deploy-lb-ha-vrrp` and :ref:`deploy-ovs-ha-vrrp` examples where
``keepalived`` uses VRRP to provide quick failover of SNAT services. ``keepalived`` uses VRRP to provide quick failover of SNAT services.
During normal operation, the master router periodically transmits *heartbeat* During normal operation, the primary router periodically transmits *heartbeat*
packets over a hidden project network that connects all HA routers for a packets over a hidden project network that connects all HA routers for a
particular project. particular project.
If the DVR/SNAT backup router stops receiving these packets, it assumes failure If the DVR/SNAT backup router stops receiving these packets, it assumes failure
of the master DVR/SNAT router and promotes itself to master router by of the primary DVR/SNAT router and promotes itself to primary router by
configuring IP addresses on the interfaces in the ``snat`` namespace. In configuring IP addresses on the interfaces in the ``snat`` namespace. In
environments with more than one backup router, the rules of VRRP are followed environments with more than one backup router, the rules of VRRP are followed
to select a new master router. to select a new primary router.
.. warning:: .. warning::

View File

@ -263,15 +263,15 @@ For more details, see the
Supported VNIC types Supported VNIC types
^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^^
The ``vnic_type_blacklist`` option is used to remove values from the mechanism driver's The ``vnic_type_prohibit_list`` option is used to remove values from the
``supported_vnic_types`` list. mechanism driver's ``supported_vnic_types`` list.
.. list-table:: Mechanism drivers and supported VNIC types .. list-table:: Mechanism drivers and supported VNIC types
:header-rows: 1 :header-rows: 1
* - mech driver / supported_vnic_types * - mech driver / supported_vnic_types
- supported VNIC types - supported VNIC types
- blacklisting available - prohibiting available
* - Linux bridge * - Linux bridge
- normal - normal
- no - no
@ -280,10 +280,10 @@ The ``vnic_type_blacklist`` option is used to remove values from the mechanism d
- no - no
* - Open vSwitch * - Open vSwitch
- normal, direct - normal, direct
- yes (ovs_driver vnic_type_blacklist, see: `Configuration Reference <../configuration/ml2-conf.html#ovs_driver>`__) - yes (ovs_driver vnic_type_prohibit_list, see: `Configuration Reference <../configuration/ml2-conf.html#ovs_driver>`__)
* - SRIOV * - SRIOV
- direct, macvtap, direct_physical - direct, macvtap, direct_physical
- yes (sriov_driver vnic_type_blacklist, see: `Configuration Reference <../configuration/ml2-conf.html#sriov_driver>`__) - yes (sriov_driver vnic_type_prohibit_list, see: `Configuration Reference <../configuration/ml2-conf.html#sriov_driver>`__)
Extension Drivers Extension Drivers

View File

@ -166,8 +166,8 @@ If a vnic_type is supported by default by multiple ML2 mechanism
drivers (e.g. ``vnic_type=direct`` by both ``openvswitch`` and drivers (e.g. ``vnic_type=direct`` by both ``openvswitch`` and
``sriovnicswitch``) and multiple agents' resources are also meant to be ``sriovnicswitch``) and multiple agents' resources are also meant to be
tracked by Placement, then the admin must decide which driver to take tracked by Placement, then the admin must decide which driver to take
ports of that vnic_type by blacklisting the vnic_type for the unwanted ports of that vnic_type by prohibiting the vnic_type for the unwanted
drivers. Use :oslo.config:option:`ovs_driver.vnic_type_blacklist` in this drivers. Use :oslo.config:option:`ovs_driver.vnic_type_prohibit_list` in this
case. Valid values are all the ``supported_vnic_types`` of the case. Valid values are all the ``supported_vnic_types`` of the
`respective mechanism drivers `respective mechanism drivers
<https://docs.openstack.org/neutron/latest/admin/config-ml2.html#supported-vnic-types>`_. <https://docs.openstack.org/neutron/latest/admin/config-ml2.html#supported-vnic-types>`_.
@ -177,10 +177,10 @@ case. Valid values are all the ``supported_vnic_types`` of the
.. code-block:: ini .. code-block:: ini
[ovs_driver] [ovs_driver]
vnic_type_blacklist = direct vnic_type_prohibit_list = direct
[sriov_driver] [sriov_driver]
#vnic_type_blacklist = direct #vnic_type_prohibit_list = direct
neutron-openvswitch-agent config neutron-openvswitch-agent config
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

View File

@ -87,7 +87,7 @@ Using SR-IOV interfaces
In order to enable SR-IOV, the following steps are required: In order to enable SR-IOV, the following steps are required:
#. Create Virtual Functions (Compute) #. Create Virtual Functions (Compute)
#. Whitelist PCI devices in nova-compute (Compute) #. Configure allow list for PCI devices in nova-compute (Compute)
#. Configure neutron-server (Controller) #. Configure neutron-server (Controller)
#. Configure nova-scheduler (Controller) #. Configure nova-scheduler (Controller)
#. Enable neutron sriov-agent (Compute) #. Enable neutron sriov-agent (Compute)
@ -223,8 +223,8 @@ network and has access to the private networks of all machines.
the ``sysfsutils`` tool. However, this is not available by default on the ``sysfsutils`` tool. However, this is not available by default on
many major distributions. many major distributions.
Whitelist PCI devices nova-compute (Compute) Configuring allow list for PCI devices nova-compute (Compute)
-------------------------------------------- -------------------------------------------------------------
#. Configure which PCI devices the ``nova-compute`` service may use. Edit #. Configure which PCI devices the ``nova-compute`` service may use. Edit
the ``nova.conf`` file: the ``nova.conf`` file:
@ -239,7 +239,7 @@ Whitelist PCI devices nova-compute (Compute)
``physnet2``. ``physnet2``.
Alternatively the ``[pci] passthrough_whitelist`` parameter also supports Alternatively the ``[pci] passthrough_whitelist`` parameter also supports
whitelisting by: allowing devices by:
- PCI address: The address uses the same syntax as in ``lspci`` and an - PCI address: The address uses the same syntax as in ``lspci`` and an
asterisk (``*``) can be used to match anything. asterisk (``*``) can be used to match anything.
@ -604,8 +604,8 @@ you must:
machines with no switch and the cards are plugged in back-to-back. A machines with no switch and the cards are plugged in back-to-back. A
subnet manager is required for the link on the cards to come up. subnet manager is required for the link on the cards to come up.
It is possible to have more than one subnet manager. In this case, one It is possible to have more than one subnet manager. In this case, one
of them will act as the master, and any other will act as a slave that of them will act as the primary, and any other will act as a backup that
will take over when the master subnet manager fails. will take over when the primary subnet manager fails.
#. Install the ``ebrctl`` utility on the compute nodes. #. Install the ``ebrctl`` utility on the compute nodes.

View File

@ -27,7 +27,7 @@ Architecture
:alt: High-availability using VRRP with Linux bridge - overview :alt: High-availability using VRRP with Linux bridge - overview
The following figure shows components and connectivity for one self-service The following figure shows components and connectivity for one self-service
network and one untagged (flat) network. The master router resides on network network and one untagged (flat) network. The primary router resides on network
node 1. In this particular case, the instance resides on the same compute node 1. In this particular case, the instance resides on the same compute
node as the DHCP agent for the network. If the DHCP agent resides on another node as the DHCP agent for the network. If the DHCP agent resides on another
compute node, the latter only contains a DHCP namespace and Linux bridge compute node, the latter only contains a DHCP namespace and Linux bridge
@ -178,6 +178,6 @@ Network traffic flow
~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~
This high-availability mechanism simply augments :ref:`deploy-ovs-selfservice` This high-availability mechanism simply augments :ref:`deploy-ovs-selfservice`
with failover of layer-3 services to another router if the master router with failover of layer-3 services to another router if the primary router
fails. Thus, you can reference :ref:`Self-service network traffic flow fails. Thus, you can reference :ref:`Self-service network traffic flow
<deploy-ovs-selfservice-networktrafficflow>` for normal operation. <deploy-ovs-selfservice-networktrafficflow>` for normal operation.

View File

@ -43,7 +43,7 @@ addition or deletion of the chassis, following approach can be considered:
* Find a list of chassis where router is scheduled and reschedule it * Find a list of chassis where router is scheduled and reschedule it
up to *MAX_GW_CHASSIS* gateways using list of available candidates. up to *MAX_GW_CHASSIS* gateways using list of available candidates.
Do not modify the master chassis association to not interrupt network flows. Do not modify the primary chassis association to not interrupt network flows.
Rescheduling is an event triggered operation which will occur whenever a Rescheduling is an event triggered operation which will occur whenever a
chassis is added or removed. When it happend, ``schedule_unhosted_gateways()`` chassis is added or removed. When it happend, ``schedule_unhosted_gateways()``
@ -58,7 +58,7 @@ southbound database table, would be the ones eligible for hosting the routers.
Rescheduling of router depends on current prorities set. Each chassis is given Rescheduling of router depends on current prorities set. Each chassis is given
a specific priority for the router's gateway and priority increases with a specific priority for the router's gateway and priority increases with
increasing value ( i.e. 1 < 2 < 3 ...). The highest prioritized chassis hosts increasing value ( i.e. 1 < 2 < 3 ...). The highest prioritized chassis hosts
gateway port. Other chassis are selected as slaves. gateway port. Other chassis are selected as backups.
There are two approaches for rescheduling supported by ovn driver right There are two approaches for rescheduling supported by ovn driver right
now: now:
@ -72,7 +72,7 @@ Few points to consider for the design:
C1 to C3 and C2 to C3. Rescheduling from C1 to C2 and vice-versa should not C1 to C3 and C2 to C3. Rescheduling from C1 to C2 and vice-versa should not
be allowed. be allowed.
* In order to reschedule the router's chassis, the ``master`` chassis for a * In order to reschedule the router's chassis, the ``primary`` chassis for a
gateway router will be left untouched. However, for the scenario where all gateway router will be left untouched. However, for the scenario where all
routers are scheduled in only one chassis which is available as gateway, routers are scheduled in only one chassis which is available as gateway,
the addition of the second gateway chassis would schedule the router the addition of the second gateway chassis would schedule the router
@ -89,11 +89,11 @@ Following scenarios are possible which have been considered in the design:
- System has 2 chassis C1 and C2 during installation. C1 goes down. - System has 2 chassis C1 and C2 during installation. C1 goes down.
- Behavior: In this case, all routers would be rescheduled to C2. - Behavior: In this case, all routers would be rescheduled to C2.
Once C1 is back up, routers would be rescheduled on it. However, Once C1 is back up, routers would be rescheduled on it. However,
since C2 is now the new master, routers on C1 would have lower priority. since C2 is now the new primary, routers on C1 would have lower priority.
* Case #3: * Case #3:
- System has 2 chassis C1 and C2 during installation. C3 is added to it. - System has 2 chassis C1 and C2 during installation. C3 is added to it.
- Behavior: In this case, routers would not move their master chassis - Behavior: In this case, routers would not move their primary chassis
associations. So routers which have their master on C1, would remain associations. So routers which have their primary on C1, would remain
there, and same for routers on C2. However, lower proritized candidates there, and same for routers on C2. However, lower proritized candidates
of existing gateways would be scheduled on the chassis C3, depending of existing gateways would be scheduled on the chassis C3, depending
on the type of used scheduler (Random or LeastLoaded). on the type of used scheduler (Random or LeastLoaded).
@ -102,23 +102,23 @@ Following scenarios are possible which have been considered in the design:
Rebalancing of Gateway Chassis Rebalancing of Gateway Chassis
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Rebalancing is the second part of the design and it assigns a new master to Rebalancing is the second part of the design and it assigns a new primary to
already scheduled router gateway ports. Downtime is expected in this already scheduled router gateway ports. Downtime is expected in this
operation. Rebalancing of routers can be achieved using external cli script. operation. Rebalancing of routers can be achieved using external cli script.
Similar approach has been implemeneted for DHCP rescheduling `[4]`_. Similar approach has been implemeneted for DHCP rescheduling `[4]`_.
The master chassis gateway could be moved only to other, previously scheduled The primary chassis gateway could be moved only to other, previously scheduled
gateway. Rebalancing of chassis occurs only if number of scheduled master gateway. Rebalancing of chassis occurs only if number of scheduled primary
chassis ports per each provider network hosted by given chassis is higher than chassis ports per each provider network hosted by given chassis is higher than
average number of hosted master gateway ports per chassis per provider network. average number of hosted primary gateway ports per chassis per provider network.
This dependency is determined by formula: This dependency is determined by formula:
avg_gw_per_chassis = num_gw_by_provider_net / num_chassis_with_provider_net avg_gw_per_chassis = num_gw_by_provider_net / num_chassis_with_provider_net
Where: Where:
- avg_gw_per_chassis - average number of scheduler master gateway chassis - avg_gw_per_chassis - average number of scheduler primary gateway chassis
withing same provider network. withing same provider network.
- num_gw_by_provider_net - number of master chassis gateways scheduled in - num_gw_by_provider_net - number of primary chassis gateways scheduled in
given provider networks. given provider networks.
- num_chassis_with_provider_net - number of chassis that has connectivity - num_chassis_with_provider_net - number of chassis that has connectivity
to given provider network. to given provider network.
@ -128,9 +128,9 @@ The rebalancing occurs only if:
num_gw_by_provider_net_by_chassis > avg_gw_per_chassis num_gw_by_provider_net_by_chassis > avg_gw_per_chassis
Where: Where:
- num_gw_by_provider_net_by_chassis - number of hosted master gateways - num_gw_by_provider_net_by_chassis - number of hosted primary gateways
by given provider network by given chassis by given provider network by given chassis
- avg_gw_per_chassis - average number of scheduler master gateway chassis - avg_gw_per_chassis - average number of scheduler primary gateway chassis
withing same provider network. withing same provider network.

View File

@ -88,8 +88,8 @@ class ExclusiveResourceProcessor(object):
Other instances may be created for the same ID while the first Other instances may be created for the same ID while the first
instance has exclusive access. If that happens then it doesn't block and instance has exclusive access. If that happens then it doesn't block and
wait for access. Instead, it signals to the master instance that an update wait for access. Instead, it signals to the primary instance that an
came in with the timestamp. update came in with the timestamp.
This way, a thread will not block to wait for access to a resource. This way, a thread will not block to wait for access to a resource.
Instead it effectively signals to the thread that is working on the Instead it effectively signals to the thread that is working on the
@ -102,27 +102,27 @@ class ExclusiveResourceProcessor(object):
as possible. The timestamp should not be recorded, however, until the as possible. The timestamp should not be recorded, however, until the
resource has been processed using the fetch data. resource has been processed using the fetch data.
""" """
_masters = {} _primaries = {}
_resource_timestamps = {} _resource_timestamps = {}
def __init__(self, id): def __init__(self, id):
self._id = id self._id = id
if id not in self._masters: if id not in self._primaries:
self._masters[id] = self self._primaries[id] = self
self._queue = queue.PriorityQueue(-1) self._queue = queue.PriorityQueue(-1)
self._master = self._masters[id] self._primary = self._primaries[id]
def _i_am_master(self): def _i_am_primary(self):
return self == self._master return self == self._primary
def __enter__(self): def __enter__(self):
return self return self
def __exit__(self, type, value, traceback): def __exit__(self, type, value, traceback):
if self._i_am_master(): if self._i_am_primary():
del self._masters[self._id] del self._primaries[self._id]
def _get_resource_data_timestamp(self): def _get_resource_data_timestamp(self):
return self._resource_timestamps.get(self._id, return self._resource_timestamps.get(self._id,
@ -140,16 +140,16 @@ class ExclusiveResourceProcessor(object):
resource is being processed. These updates have already bubbled to resource is being processed. These updates have already bubbled to
the front of the ResourceProcessingQueue. the front of the ResourceProcessingQueue.
""" """
self._master._queue.put(update) self._primary._queue.put(update)
def updates(self): def updates(self):
"""Processes the resource until updates stop coming """Processes the resource until updates stop coming
Only the master instance will process the resource. However, updates Only the primary instance will process the resource. However, updates
may come in from other workers while it is in progress. This method may come in from other workers while it is in progress. This method
loops until they stop coming. loops until they stop coming.
""" """
while self._i_am_master(): while self._i_am_primary():
if self._queue.empty(): if self._queue.empty():
return return
# Get the update from the queue even if it is old. # Get the update from the queue even if it is old.
@ -177,10 +177,10 @@ class ResourceProcessingQueue(object):
next_update = self._queue.get() next_update = self._queue.get()
with ExclusiveResourceProcessor(next_update.id) as rp: with ExclusiveResourceProcessor(next_update.id) as rp:
# Queue the update whether this worker is the master or not. # Queue the update whether this worker is the primary or not.
rp.queue_update(next_update) rp.queue_update(next_update)
# Here, if the current worker is not the master, the call to # Here, if the current worker is not the primary, the call to
# rp.updates() will not yield and so this will essentially be a # rp.updates() will not yield and so this will essentially be a
# noop. # noop.
for update in rp.updates(): for update in rp.updates():

View File

@ -63,7 +63,7 @@ class DvrEdgeHaRouter(dvr_edge_router.DvrEdgeRouter,
self._add_vip(fip_cidr, interface_name) self._add_vip(fip_cidr, interface_name)
self.set_ha_port() self.set_ha_port()
if (self.is_router_master() and self.ha_port and if (self.is_router_primary() and self.ha_port and
self.ha_port['status'] == constants.PORT_STATUS_ACTIVE): self.ha_port['status'] == constants.PORT_STATUS_ACTIVE):
return super(DvrEdgeHaRouter, self).add_centralized_floatingip( return super(DvrEdgeHaRouter, self).add_centralized_floatingip(
fip, fip_cidr) fip, fip_cidr)
@ -72,7 +72,7 @@ class DvrEdgeHaRouter(dvr_edge_router.DvrEdgeRouter,
def remove_centralized_floatingip(self, fip_cidr): def remove_centralized_floatingip(self, fip_cidr):
self._remove_vip(fip_cidr) self._remove_vip(fip_cidr)
if self.is_router_master(): if self.is_router_primary():
super(DvrEdgeHaRouter, self).remove_centralized_floatingip( super(DvrEdgeHaRouter, self).remove_centralized_floatingip(
fip_cidr) fip_cidr)

View File

@ -29,7 +29,7 @@ LOG = logging.getLogger(__name__)
KEEPALIVED_STATE_CHANGE_SERVER_BACKLOG = 4096 KEEPALIVED_STATE_CHANGE_SERVER_BACKLOG = 4096
TRANSLATION_MAP = {'master': constants.HA_ROUTER_STATE_ACTIVE, TRANSLATION_MAP = {'primary': constants.HA_ROUTER_STATE_ACTIVE,
'backup': constants.HA_ROUTER_STATE_STANDBY, 'backup': constants.HA_ROUTER_STATE_STANDBY,
'fault': constants.HA_ROUTER_STATE_STANDBY, 'fault': constants.HA_ROUTER_STATE_STANDBY,
'unknown': constants.HA_ROUTER_STATE_UNKNOWN} 'unknown': constants.HA_ROUTER_STATE_UNKNOWN}
@ -129,28 +129,28 @@ class AgentMixin(object):
This function will also update the metadata proxy, the radvd daemon, This function will also update the metadata proxy, the radvd daemon,
process the prefix delegation and inform to the L3 extensions. If the process the prefix delegation and inform to the L3 extensions. If the
HA router changes to "master", this transition will be delayed for at HA router changes to "primary", this transition will be delayed for at
least "ha_vrrp_advert_int" seconds. When the "master" router least "ha_vrrp_advert_int" seconds. When the "primary" router
transitions to "backup", "keepalived" will set the rest of HA routers transitions to "backup", "keepalived" will set the rest of HA routers
to "master" until it decides which one should be the only "master". to "primary" until it decides which one should be the only "primary".
The transition from "backup" to "master" and then to "backup" again, The transition from "backup" to "primary" and then to "backup" again,
should not be registered in the Neutron server. should not be registered in the Neutron server.
:param router_id: router ID :param router_id: router ID
:param state: ['master', 'backup'] :param state: ['primary', 'backup']
""" """
if not self._update_transition_state(router_id, state): if not self._update_transition_state(router_id, state):
eventlet.spawn_n(self._enqueue_state_change, router_id, state) eventlet.spawn_n(self._enqueue_state_change, router_id, state)
eventlet.sleep(0) eventlet.sleep(0)
def _enqueue_state_change(self, router_id, state): def _enqueue_state_change(self, router_id, state):
# NOTE(ralonsoh): move 'master' and 'backup' constants to n-lib # NOTE(ralonsoh): move 'primary' and 'backup' constants to n-lib
if state == 'master': if state == 'primary':
eventlet.sleep(self.conf.ha_vrrp_advert_int) eventlet.sleep(self.conf.ha_vrrp_advert_int)
if self._update_transition_state(router_id) != state: if self._update_transition_state(router_id) != state:
# If the current "transition state" is not the initial "state" sent # If the current "transition state" is not the initial "state" sent
# to update the router, that means the actual router state is the # to update the router, that means the actual router state is the
# same as the "transition state" (e.g.: backup-->master-->backup). # same as the "transition state" (e.g.: backup-->primary-->backup).
return return
ri = self._get_router_info(router_id) ri = self._get_router_info(router_id)
@ -164,7 +164,7 @@ class AgentMixin(object):
state_change_data) state_change_data)
# Set external gateway port link up or down according to state # Set external gateway port link up or down according to state
if state == 'master': if state == 'primary':
ri.set_external_gw_port_link_status(link_up=True, set_gw=True) ri.set_external_gw_port_link_status(link_up=True, set_gw=True)
elif state == 'backup': elif state == 'backup':
ri.set_external_gw_port_link_status(link_up=False) ri.set_external_gw_port_link_status(link_up=False)
@ -181,7 +181,7 @@ class AgentMixin(object):
if self.conf.enable_metadata_proxy: if self.conf.enable_metadata_proxy:
self._update_metadata_proxy(ri, router_id, state) self._update_metadata_proxy(ri, router_id, state)
self._update_radvd_daemon(ri, state) self._update_radvd_daemon(ri, state)
self.pd.process_ha_state(router_id, state == 'master') self.pd.process_ha_state(router_id, state == 'primary')
self.state_change_notifier.queue_event((router_id, state)) self.state_change_notifier.queue_event((router_id, state))
self.l3_ext_manager.ha_state_change(self.context, state_change_data) self.l3_ext_manager.ha_state_change(self.context, state_change_data)
@ -189,7 +189,7 @@ class AgentMixin(object):
if not self.use_ipv6: if not self.use_ipv6:
return return
ipv6_forwarding_enable = state == 'master' ipv6_forwarding_enable = state == 'primary'
if ri.router.get('distributed', False): if ri.router.get('distributed', False):
namespace = ri.ha_namespace namespace = ri.ha_namespace
else: else:
@ -202,7 +202,7 @@ class AgentMixin(object):
# If ipv6 is enabled on the platform, ipv6_gateway config flag is # If ipv6 is enabled on the platform, ipv6_gateway config flag is
# not set and external_network associated to the router does not # not set and external_network associated to the router does not
# include any IPv6 subnet, enable the gateway interface to accept # include any IPv6 subnet, enable the gateway interface to accept
# Router Advts from upstream router for default route on master # Router Advts from upstream router for default route on primary
# instances as well as ipv6 forwarding. Otherwise, disable them. # instances as well as ipv6 forwarding. Otherwise, disable them.
ex_gw_port_id = ri.ex_gw_port and ri.ex_gw_port['id'] ex_gw_port_id = ri.ex_gw_port and ri.ex_gw_port['id']
if ex_gw_port_id: if ex_gw_port_id:
@ -215,7 +215,7 @@ class AgentMixin(object):
# NOTE(slaweq): Since the metadata proxy is spawned in the qrouter # NOTE(slaweq): Since the metadata proxy is spawned in the qrouter
# namespace and not in the snat namespace, even standby DVR-HA # namespace and not in the snat namespace, even standby DVR-HA
# routers needs to serve metadata requests to local ports. # routers needs to serve metadata requests to local ports.
if state == 'master' or ri.router.get('distributed', False): if state == 'primary' or ri.router.get('distributed', False):
LOG.debug('Spawning metadata proxy for router %s', router_id) LOG.debug('Spawning metadata proxy for router %s', router_id)
self.metadata_driver.spawn_monitored_metadata_proxy( self.metadata_driver.spawn_monitored_metadata_proxy(
self.process_monitor, ri.ns_name, self.conf.metadata_port, self.process_monitor, ri.ns_name, self.conf.metadata_port,
@ -226,9 +226,9 @@ class AgentMixin(object):
self.process_monitor, ri.router_id, self.conf, ri.ns_name) self.process_monitor, ri.router_id, self.conf, ri.ns_name)
def _update_radvd_daemon(self, ri, state): def _update_radvd_daemon(self, ri, state):
# Radvd has to be spawned only on the Master HA Router. If there are # Radvd has to be spawned only on the primary HA Router. If there are
# any state transitions, we enable/disable radvd accordingly. # any state transitions, we enable/disable radvd accordingly.
if state == 'master': if state == 'primary':
ri.enable_radvd() ri.enable_radvd()
else: else:
ri.disable_radvd() ri.disable_radvd()

View File

@ -55,7 +55,7 @@ class HaRouterNamespace(namespaces.RouterNamespace):
It does so to prevent sending gratuitous ARPs for interfaces that got VIP It does so to prevent sending gratuitous ARPs for interfaces that got VIP
removed in the middle of processing. removed in the middle of processing.
It also disables ipv6 forwarding by default. Forwarding will be It also disables ipv6 forwarding by default. Forwarding will be
enabled during router configuration processing only for the master node. enabled during router configuration processing only for the primary node.
It has to be disabled on all other nodes to avoid sending MLD packets It has to be disabled on all other nodes to avoid sending MLD packets
which cause lost connectivity to Floating IPs. which cause lost connectivity to Floating IPs.
""" """
@ -96,12 +96,12 @@ class HaRouter(router.RouterInfo):
return self.router.get('ha_vr_id') return self.router.get('ha_vr_id')
def _check_and_set_real_state(self): def _check_and_set_real_state(self):
# When the physical host was down/up, the 'master' router may still # When the physical host was down/up, the 'primary' router may still
# have its original state in the _ha_state_path file. We directly # have its original state in the _ha_state_path file. We directly
# reset it to 'backup'. # reset it to 'backup'.
if (not self.keepalived_manager.check_processes() and if (not self.keepalived_manager.check_processes() and
os.path.exists(self.ha_state_path) and os.path.exists(self.ha_state_path) and
self.ha_state == 'master'): self.ha_state == 'primary'):
self.ha_state = 'backup' self.ha_state = 'backup'
@property @property
@ -110,7 +110,12 @@ class HaRouter(router.RouterInfo):
return self._ha_state return self._ha_state
try: try:
with open(self.ha_state_path, 'r') as f: with open(self.ha_state_path, 'r') as f:
self._ha_state = f.read() # TODO(haleyb): put old code back after a couple releases,
# Y perhaps, just for backwards-compat
# self._ha_state = f.read()
ha_state = f.read()
ha_state = 'primary' if ha_state == 'master' else ha_state
self._ha_state = ha_state
except (OSError, IOError): except (OSError, IOError):
LOG.debug('Error while reading HA state for %s', self.router_id) LOG.debug('Error while reading HA state for %s', self.router_id)
return self._ha_state or 'unknown' return self._ha_state or 'unknown'
@ -129,7 +134,7 @@ class HaRouter(router.RouterInfo):
def ha_namespace(self): def ha_namespace(self):
return self.ns_name return self.ns_name
def is_router_master(self): def is_router_primary(self):
"""this method is normally called before the ha_router object is fully """this method is normally called before the ha_router object is fully
initialized initialized
""" """
@ -298,14 +303,14 @@ class HaRouter(router.RouterInfo):
onlink_route_cidr in onlink_route_cidrs] onlink_route_cidr in onlink_route_cidrs]
def _should_delete_ipv6_lladdr(self, ipv6_lladdr): def _should_delete_ipv6_lladdr(self, ipv6_lladdr):
"""Only the master should have any IP addresses configured. """Only the primary should have any IP addresses configured.
Let keepalived manage IPv6 link local addresses, the same way we let Let keepalived manage IPv6 link local addresses, the same way we let
it manage IPv4 addresses. If the router is not in the master state, it manage IPv4 addresses. If the router is not in the primary state,
we must delete the address first as it is autoconfigured by the kernel. we must delete the address first as it is autoconfigured by the kernel.
""" """
manager = self.keepalived_manager manager = self.keepalived_manager
if manager.get_process().active: if manager.get_process().active:
if self.ha_state != 'master': if self.ha_state != 'primary':
conf = manager.get_conf_on_disk() conf = manager.get_conf_on_disk()
managed_by_keepalived = conf and ipv6_lladdr in conf managed_by_keepalived = conf and ipv6_lladdr in conf
if managed_by_keepalived: if managed_by_keepalived:
@ -317,7 +322,7 @@ class HaRouter(router.RouterInfo):
def _disable_ipv6_addressing_on_interface(self, interface_name): def _disable_ipv6_addressing_on_interface(self, interface_name):
"""Disable IPv6 link local addressing on the device and add it as """Disable IPv6 link local addressing on the device and add it as
a VIP to keepalived. This means that the IPv6 link local address a VIP to keepalived. This means that the IPv6 link local address
will only be present on the master. will only be present on the primary.
""" """
device = ip_lib.IPDevice(interface_name, namespace=self.ha_namespace) device = ip_lib.IPDevice(interface_name, namespace=self.ha_namespace)
ipv6_lladdr = ip_lib.get_ipv6_lladdr(device.link.address) ipv6_lladdr = ip_lib.get_ipv6_lladdr(device.link.address)
@ -446,7 +451,7 @@ class HaRouter(router.RouterInfo):
name=self.get_ha_device_name()) name=self.get_ha_device_name())
cidrs = (address['cidr'] for address in addresses) cidrs = (address['cidr'] for address in addresses)
ha_cidr = self._get_primary_vip() ha_cidr = self._get_primary_vip()
state = 'master' if ha_cidr in cidrs else 'backup' state = 'primary' if ha_cidr in cidrs else 'backup'
self.ha_state = state self.ha_state = state
callback(self.router_id, state) callback(self.router_id, state)
@ -468,10 +473,10 @@ class HaRouter(router.RouterInfo):
self._add_gateway_vip(ex_gw_port, interface_name) self._add_gateway_vip(ex_gw_port, interface_name)
self._disable_ipv6_addressing_on_interface(interface_name) self._disable_ipv6_addressing_on_interface(interface_name)
# Enable RA and IPv6 forwarding only for master instances. This will # Enable RA and IPv6 forwarding only for primary instances. This will
# prevent backup routers from sending packets to the upstream switch # prevent backup routers from sending packets to the upstream switch
# and disrupt connections. # and disrupt connections.
enable = self.ha_state == 'master' enable = self.ha_state == 'primary'
self._configure_ipv6_params_on_gw(ex_gw_port, self.ns_name, self._configure_ipv6_params_on_gw(ex_gw_port, self.ns_name,
interface_name, enable) interface_name, enable)
@ -486,11 +491,11 @@ class HaRouter(router.RouterInfo):
def external_gateway_removed(self, ex_gw_port, interface_name): def external_gateway_removed(self, ex_gw_port, interface_name):
self._clear_vips(interface_name) self._clear_vips(interface_name)
if self.ha_state == 'master': if self.ha_state == 'primary':
super(HaRouter, self).external_gateway_removed(ex_gw_port, super(HaRouter, self).external_gateway_removed(ex_gw_port,
interface_name) interface_name)
else: else:
# We are not the master node, so no need to delete ip addresses. # We are not the primary node, so no need to delete ip addresses.
self.driver.unplug(interface_name, self.driver.unplug(interface_name,
namespace=self.ns_name, namespace=self.ns_name,
prefix=router.EXTERNAL_DEV_PREFIX) prefix=router.EXTERNAL_DEV_PREFIX)
@ -526,13 +531,13 @@ class HaRouter(router.RouterInfo):
@runtime.synchronized('enable_radvd') @runtime.synchronized('enable_radvd')
def enable_radvd(self, internal_ports=None): def enable_radvd(self, internal_ports=None):
if (self.keepalived_manager.get_process().active and if (self.keepalived_manager.get_process().active and
self.ha_state == 'master'): self.ha_state == 'primary'):
super(HaRouter, self).enable_radvd(internal_ports) super(HaRouter, self).enable_radvd(internal_ports)
def external_gateway_link_up(self): def external_gateway_link_up(self):
# Check HA router ha_state for its gateway port link state. # Check HA router ha_state for its gateway port link state.
# 'backup' instance will not link up the gateway port. # 'backup' instance will not link up the gateway port.
return self.ha_state == 'master' return self.ha_state == 'primary'
def set_external_gw_port_link_status(self, link_up, set_gw=False): def set_external_gw_port_link_status(self, link_up, set_gw=False):
link_state = "up" if link_up else "down" link_state = "up" if link_up else "down"

View File

@ -84,7 +84,10 @@ class MonitorDaemon(daemon.Daemon):
continue continue
if event['name'] == self.interface and event['cidr'] == self.cidr: if event['name'] == self.interface and event['cidr'] == self.cidr:
new_state = 'master' if event['event'] == 'added' else 'backup' if event['event'] == 'added':
new_state = 'primary'
else:
new_state = 'backup'
self.write_state_change(new_state) self.write_state_change(new_state)
self.notify_agent(new_state) self.notify_agent(new_state)
elif event['name'] != self.interface and event['event'] == 'added': elif event['name'] != self.interface and event['event'] == 'added':
@ -103,7 +106,7 @@ class MonitorDaemon(daemon.Daemon):
ip = ip_lib.IPDevice(self.interface, self.namespace) ip = ip_lib.IPDevice(self.interface, self.namespace)
for address in ip.addr.list(): for address in ip.addr.list():
if address.get('cidr') == self.cidr: if address.get('cidr') == self.cidr:
state = 'master' state = 'primary'
self.write_state_change(state) self.write_state_change(state)
self.notify_agent(state) self.notify_agent(state)
break break

View File

@ -170,7 +170,7 @@ class RouterInfo(BaseRouterInfo):
return namespaces.RouterNamespace( return namespaces.RouterNamespace(
router_id, agent_conf, iface_driver, use_ipv6) router_id, agent_conf, iface_driver, use_ipv6)
def is_router_master(self): def is_router_primary(self):
return True return True
def _update_routing_table(self, operation, route, namespace): def _update_routing_table(self, operation, route, namespace):

View File

@ -35,7 +35,7 @@ PRIMARY_VIP_RANGE_SIZE = 24
KEEPALIVED_SERVICE_NAME = 'keepalived' KEEPALIVED_SERVICE_NAME = 'keepalived'
KEEPALIVED_EMAIL_FROM = 'neutron@openstack.local' KEEPALIVED_EMAIL_FROM = 'neutron@openstack.local'
KEEPALIVED_ROUTER_ID = 'neutron' KEEPALIVED_ROUTER_ID = 'neutron'
GARP_MASTER_DELAY = 60 GARP_PRIMARY_DELAY = 60
HEALTH_CHECK_NAME = 'ha_health_check' HEALTH_CHECK_NAME = 'ha_health_check'
LOG = logging.getLogger(__name__) LOG = logging.getLogger(__name__)
@ -167,7 +167,7 @@ class KeepalivedInstance(object):
def __init__(self, state, interface, vrouter_id, ha_cidrs, def __init__(self, state, interface, vrouter_id, ha_cidrs,
priority=HA_DEFAULT_PRIORITY, advert_int=None, priority=HA_DEFAULT_PRIORITY, advert_int=None,
mcast_src_ip=None, nopreempt=False, mcast_src_ip=None, nopreempt=False,
garp_master_delay=GARP_MASTER_DELAY, garp_primary_delay=GARP_PRIMARY_DELAY,
vrrp_health_check_interval=0, vrrp_health_check_interval=0,
ha_conf_dir=None): ha_conf_dir=None):
self.name = 'VR_%s' % vrouter_id self.name = 'VR_%s' % vrouter_id
@ -182,7 +182,7 @@ class KeepalivedInstance(object):
self.nopreempt = nopreempt self.nopreempt = nopreempt
self.advert_int = advert_int self.advert_int = advert_int
self.mcast_src_ip = mcast_src_ip self.mcast_src_ip = mcast_src_ip
self.garp_master_delay = garp_master_delay self.garp_primary_delay = garp_primary_delay
self.track_interfaces = [] self.track_interfaces = []
self.vips = [] self.vips = []
self.virtual_routes = KeepalivedInstanceRoutes() self.virtual_routes = KeepalivedInstanceRoutes()
@ -294,7 +294,7 @@ class KeepalivedInstance(object):
' interface %s' % self.interface, ' interface %s' % self.interface,
' virtual_router_id %s' % self.vrouter_id, ' virtual_router_id %s' % self.vrouter_id,
' priority %s' % self.priority, ' priority %s' % self.priority,
' garp_master_delay %s' % self.garp_master_delay]) ' garp_master_delay %s' % self.garp_primary_delay])
if self.nopreempt: if self.nopreempt:
config.append(' nopreempt') config.append(' nopreempt')
@ -380,7 +380,7 @@ class KeepalivedManager(object):
self.process_monitor = process_monitor self.process_monitor = process_monitor
self.conf_path = conf_path self.conf_path = conf_path
# configure throttler for spawn to introduce delay between SIGHUPs, # configure throttler for spawn to introduce delay between SIGHUPs,
# otherwise keepalived master may unnecessarily flip to slave # otherwise keepalived primary may unnecessarily flip to backup
if throttle_restart_value is not None: if throttle_restart_value is not None:
self._throttle_spawn(throttle_restart_value) self._throttle_spawn(throttle_restart_value)

View File

@ -56,8 +56,8 @@ class PrefixDelegation(object):
events.AFTER_DELETE) events.AFTER_DELETE)
self._get_sync_data() self._get_sync_data()
def _is_pd_master_router(self, router): def _is_pd_primary_router(self, router):
return router['master'] return router['primary']
@runtime.synchronized("l3-agent-pd") @runtime.synchronized("l3-agent-pd")
def enable_subnet(self, router_id, subnet_id, prefix, ri_ifname, mac): def enable_subnet(self, router_id, subnet_id, prefix, ri_ifname, mac):
@ -74,11 +74,11 @@ class PrefixDelegation(object):
if pd_info.sync: if pd_info.sync:
pd_info.mac = mac pd_info.mac = mac
pd_info.old_prefix = prefix pd_info.old_prefix = prefix
elif self._is_pd_master_router(router): elif self._is_pd_primary_router(router):
self._add_lla(router, pd_info.get_bind_lla_with_mask()) self._add_lla(router, pd_info.get_bind_lla_with_mask())
def _delete_pd(self, router, pd_info): def _delete_pd(self, router, pd_info):
if not self._is_pd_master_router(router): if not self._is_pd_primary_router(router):
return return
self._delete_lla(router, pd_info.get_bind_lla_with_mask()) self._delete_lla(router, pd_info.get_bind_lla_with_mask())
if pd_info.client_started: if pd_info.client_started:
@ -94,7 +94,7 @@ class PrefixDelegation(object):
if not pd_info: if not pd_info:
return return
self._delete_pd(router, pd_info) self._delete_pd(router, pd_info)
if self._is_pd_master_router(router): if self._is_pd_primary_router(router):
prefix_update[subnet_id] = n_const.PROVISIONAL_IPV6_PD_PREFIX prefix_update[subnet_id] = n_const.PROVISIONAL_IPV6_PD_PREFIX
LOG.debug("Update server with prefixes: %s", prefix_update) LOG.debug("Update server with prefixes: %s", prefix_update)
self.notifier(self.context, prefix_update) self.notifier(self.context, prefix_update)
@ -117,7 +117,7 @@ class PrefixDelegation(object):
if not router: if not router:
return return
router['gw_interface'] = gw_ifname router['gw_interface'] = gw_ifname
if not self._is_pd_master_router(router): if not self._is_pd_primary_router(router):
return return
prefix_update = {} prefix_update = {}
for pd_info in router['subnets'].values(): for pd_info in router['subnets'].values():
@ -141,7 +141,7 @@ class PrefixDelegation(object):
self.notifier(self.context, prefix_update) self.notifier(self.context, prefix_update)
def delete_router_pd(self, router): def delete_router_pd(self, router):
if not self._is_pd_master_router(router): if not self._is_pd_primary_router(router):
return return
prefix_update = {} prefix_update = {}
for subnet_id, pd_info in router['subnets'].items(): for subnet_id, pd_info in router['subnets'].items():
@ -260,13 +260,13 @@ class PrefixDelegation(object):
return False return False
@runtime.synchronized("l3-agent-pd") @runtime.synchronized("l3-agent-pd")
def process_ha_state(self, router_id, master): def process_ha_state(self, router_id, primary):
router = self.routers.get(router_id) router = self.routers.get(router_id)
if router is None or router['master'] == master: if router is None or router['primary'] == primary:
return return
router['master'] = master router['primary'] = primary
if master: if primary:
for pd_info in router['subnets'].values(): for pd_info in router['subnets'].values():
bind_lla_with_mask = pd_info.get_bind_lla_with_mask() bind_lla_with_mask = pd_info.get_bind_lla_with_mask()
self._add_lla(router, bind_lla_with_mask) self._add_lla(router, bind_lla_with_mask)
@ -285,7 +285,7 @@ class PrefixDelegation(object):
prefix_update = {} prefix_update = {}
for router_id, router in self.routers.items(): for router_id, router in self.routers.items():
if not (self._is_pd_master_router(router) and if not (self._is_pd_primary_router(router) and
router['gw_interface']): router['gw_interface']):
continue continue
@ -338,7 +338,7 @@ class PrefixDelegation(object):
for pd_info in sync_data: for pd_info in sync_data:
router_id = pd_info.router_id router_id = pd_info.router_id
if not self.routers.get(router_id): if not self.routers.get(router_id):
self.routers[router_id] = {'master': True, self.routers[router_id] = {'primary': True,
'gw_interface': None, 'gw_interface': None,
'ns_name': None, 'ns_name': None,
'subnets': {}} 'subnets': {}}
@ -356,8 +356,8 @@ def remove_router(resource, event, l3_agent, **kwargs):
del l3_agent.pd.routers[router_id] del l3_agent.pd.routers[router_id]
def get_router_entry(ns_name, master): def get_router_entry(ns_name, primary):
return {'master': master, return {'primary': primary,
'gw_interface': None, 'gw_interface': None,
'ns_name': ns_name, 'ns_name': ns_name,
'subnets': {}} 'subnets': {}}
@ -368,14 +368,14 @@ def add_router(resource, event, l3_agent, **kwargs):
added_router = kwargs['router'] added_router = kwargs['router']
router = l3_agent.pd.routers.get(added_router.router_id) router = l3_agent.pd.routers.get(added_router.router_id)
gw_ns_name = added_router.get_gw_ns_name() gw_ns_name = added_router.get_gw_ns_name()
master = added_router.is_router_master() primary = added_router.is_router_primary()
if not router: if not router:
l3_agent.pd.routers[added_router.router_id] = ( l3_agent.pd.routers[added_router.router_id] = (
get_router_entry(gw_ns_name, master)) get_router_entry(gw_ns_name, primary))
else: else:
# This will happen during l3 agent restart # This will happen during l3 agent restart
router['ns_name'] = gw_ns_name router['ns_name'] = gw_ns_name
router['master'] = master router['primary'] = primary
@runtime.synchronized("l3-agent-pd") @runtime.synchronized("l3-agent-pd")

View File

@ -174,7 +174,7 @@ DHCPV6_STATELESS_OPT = 'dhcpv6_stateless'
# When setting global DHCP options, these options will be ignored # When setting global DHCP options, these options will be ignored
# as they are required for basic network functions and will be # as they are required for basic network functions and will be
# set by Neutron. # set by Neutron.
GLOBAL_DHCP_OPTS_BLACKLIST = { GLOBAL_DHCP_OPTS_PROHIBIT_LIST = {
4: ['server_id', 'lease_time', 'mtu', 'router', 'server_mac', 4: ['server_id', 'lease_time', 'mtu', 'router', 'server_mac',
'dns_server', 'classless_static_route'], 'dns_server', 'classless_static_route'],
6: ['dhcpv6_stateless', 'dns_server', 'server_id']} 6: ['dhcpv6_stateless', 'dns_server', 'server_id']}

View File

@ -49,11 +49,11 @@ OPTS = [
'VRRP health checks. Recommended value is 5. ' 'VRRP health checks. Recommended value is 5. '
'This will cause pings to be sent to the gateway ' 'This will cause pings to be sent to the gateway '
'IP address(es) - requires ICMP_ECHO_REQUEST ' 'IP address(es) - requires ICMP_ECHO_REQUEST '
'to be enabled on the gateway. ' 'to be enabled on the gateway(s). '
'If gateway fails, all routers will be reported ' 'If a gateway fails, all routers will be reported '
'as master, and master election will be repeated ' 'as primary, and a primary election will be repeated '
'in round-robin fashion, until one of the router ' 'in a round-robin fashion, until one of the routers '
'restore the gateway connection.')), 'restores the gateway connection.')),
] ]

View File

@ -18,8 +18,9 @@ from neutron._i18n import _
sriov_driver_opts = [ sriov_driver_opts = [
cfg.ListOpt('vnic_type_blacklist', cfg.ListOpt('vnic_type_prohibit_list',
default=[], default=[],
deprecated_name='vnic_type_blacklist',
help=_("Comma-separated list of VNIC types for which support " help=_("Comma-separated list of VNIC types for which support "
"is administratively prohibited by the mechanism " "is administratively prohibited by the mechanism "
"driver. Please note that the supported vnic_types " "driver. Please note that the supported vnic_types "

View File

@ -18,8 +18,9 @@ from neutron._i18n import _
ovs_driver_opts = [ ovs_driver_opts = [
cfg.ListOpt('vnic_type_blacklist', cfg.ListOpt('vnic_type_prohibit_list',
default=[], default=[],
deprecated_name='vnic_type_blacklist',
help=_("Comma-separated list of VNIC types for which support " help=_("Comma-separated list of VNIC types for which support "
"is administratively prohibited by the mechanism " "is administratively prohibited by the mechanism "
"driver. Please note that the supported vnic_types " "driver. Please note that the supported vnic_types "

View File

@ -750,10 +750,10 @@ class L3_HA_NAT_db_mixin(l3_dvr_db.L3_NAT_with_dvr_db_mixin,
if ha_binding_state != constants.HA_ROUTER_STATE_ACTIVE: if ha_binding_state != constants.HA_ROUTER_STATE_ACTIVE:
continue continue
# For create router gateway, the gateway port may not be ACTIVE # For create router gateway, the gateway port may not be ACTIVE
# yet, so we return 'master' host directly. # yet, so we return 'primary' host directly.
if gateway_port_status != constants.PORT_STATUS_ACTIVE: if gateway_port_status != constants.PORT_STATUS_ACTIVE:
return ha_binding_agent.host return ha_binding_agent.host
# Do not let the original 'master' (current is backup) host, # Do not let the original 'primary' (current is backup) host,
# override the gateway port binding host. # override the gateway port binding host.
if (gateway_port_status == constants.PORT_STATUS_ACTIVE and if (gateway_port_status == constants.PORT_STATUS_ACTIVE and
ha_binding_agent.host == gateway_port_binding_host): ha_binding_agent.host == gateway_port_binding_host):

View File

@ -458,7 +458,7 @@ class LinuxBridgeManager(amb.CommonAgentManagerBase):
# Check if the interface is part of the bridge # Check if the interface is part of the bridge
if not bridge_device.owns_interface(interface): if not bridge_device.owns_interface(interface):
try: try:
# Check if the interface is not enslaved in another bridge # Check if the interface is attached to another bridge
bridge = bridge_lib.BridgeDevice.get_interface_bridge( bridge = bridge_lib.BridgeDevice.get_interface_bridge(
interface) interface)
if bridge: if bridge:

View File

@ -138,19 +138,20 @@ class AgentMechanismDriverBase(api.MechanismDriver, metaclass=abc.ABCMeta):
return True. Otherwise, it must return False. return True. Otherwise, it must return False.
""" """
def blacklist_supported_vnic_types(self, vnic_types, blacklist): def prohibit_list_supported_vnic_types(self, vnic_types, prohibit_list):
"""Validate the blacklist and blacklist the supported_vnic_types """Validate the prohibit_list and prohibit the supported_vnic_types
:param vnic_types: The supported_vnic_types list :param vnic_types: The supported_vnic_types list
:param blacklist: The blacklist as in vnic_type_blacklist :param prohibit_list: The prohibit_list as in vnic_type_prohibit_list
:return The blacklisted vnic_types :return The prohibited vnic_types
""" """
if not blacklist: if not prohibit_list:
return vnic_types return vnic_types
# Not valid values in the blacklist: # Not valid values in the prohibit_list:
if not all(bl in vnic_types for bl in blacklist): if not all(bl in vnic_types for bl in prohibit_list):
raise ValueError(_("Not all of the items from vnic_type_blacklist " raise ValueError(_("Not all of the items from "
"vnic_type_prohibit_list "
"are valid vnic_types for %(agent)s mechanism " "are valid vnic_types for %(agent)s mechanism "
"driver. The valid values are: " "driver. The valid values are: "
"%(valid_vnics)s.") % "%(valid_vnics)s.") %
@ -158,11 +159,11 @@ class AgentMechanismDriverBase(api.MechanismDriver, metaclass=abc.ABCMeta):
'valid_vnics': vnic_types}) 'valid_vnics': vnic_types})
supported_vnic_types = [vnic_t for vnic_t in vnic_types if supported_vnic_types = [vnic_t for vnic_t in vnic_types if
vnic_t not in blacklist] vnic_t not in prohibit_list]
# Nothing left in the supported vnict types list: # Nothing left in the supported vnict types list:
if len(supported_vnic_types) < 1: if len(supported_vnic_types) < 1:
raise ValueError(_("All possible vnic_types were blacklisted for " raise ValueError(_("All possible vnic_types were prohibited for "
"%s mechanism driver!") % self.agent_type) "%s mechanism driver!") % self.agent_type)
return supported_vnic_types return supported_vnic_types

View File

@ -69,12 +69,12 @@ class SriovNicSwitchMechanismDriver(mech_agent.SimpleAgentMechanismDriverBase):
""" """
self.agent_type = agent_type self.agent_type = agent_type
# TODO(lajoskatona): move this blacklisting to # TODO(lajoskatona): move this prohibition to
# SimpleAgentMechanismDriverBase. By that e blacklisting and validation # SimpleAgentMechanismDriverBase. By that, prohibition and validation
# of the vnic_types would be available for all mechanism drivers. # of the vnic_types would be available for all mechanism drivers.
self.supported_vnic_types = self.blacklist_supported_vnic_types( self.supported_vnic_types = self.prohibit_list_supported_vnic_types(
vnic_types=supported_vnic_types, vnic_types=supported_vnic_types,
blacklist=cfg.CONF.SRIOV_DRIVER.vnic_type_blacklist prohibit_list=cfg.CONF.SRIOV_DRIVER.vnic_type_prohibit_list
) )
# NOTE(ndipanov): PF passthrough requires a different vif type # NOTE(ndipanov): PF passthrough requires a different vif type

View File

@ -69,14 +69,14 @@ class OpenvswitchMechanismDriver(mech_agent.SimpleAgentMechanismDriverBase):
portbindings.VIF_TYPE_OVS, portbindings.VIF_TYPE_OVS,
vif_details) vif_details)
# TODO(lajoskatona): move this blacklisting to # TODO(lajoskatona): move this prohibition to
# SimpleAgentMechanismDriverBase. By that e blacklisting and validation # SimpleAgentMechanismDriverBase. By that, prohibition and validation
# of the vnic_types would be available for all mechanism drivers. # of the vnic_types would be available for all mechanism drivers.
self.supported_vnic_types = self.blacklist_supported_vnic_types( self.supported_vnic_types = self.prohibit_list_supported_vnic_types(
vnic_types=[portbindings.VNIC_NORMAL, vnic_types=[portbindings.VNIC_NORMAL,
portbindings.VNIC_DIRECT, portbindings.VNIC_DIRECT,
portbindings.VNIC_SMARTNIC], portbindings.VNIC_SMARTNIC],
blacklist=cfg.CONF.OVS_DRIVER.vnic_type_blacklist prohibit_list=cfg.CONF.OVS_DRIVER.vnic_type_prohibit_list
) )
LOG.info("%s's supported_vnic_types: %s", LOG.info("%s's supported_vnic_types: %s",
self.agent_type, self.supported_vnic_types) self.agent_type, self.supported_vnic_types)

View File

@ -1754,7 +1754,7 @@ class OVNClient(object):
global_options = ovn_conf.get_global_dhcpv6_opts() global_options = ovn_conf.get_global_dhcpv6_opts()
for option, value in global_options.items(): for option, value in global_options.items():
if option in ovn_const.GLOBAL_DHCP_OPTS_BLACKLIST[ip_version]: if option in ovn_const.GLOBAL_DHCP_OPTS_PROHIBIT_LIST[ip_version]:
# This option is not allowed to be set with a global setting # This option is not allowed to be set with a global setting
LOG.debug('DHCP option %s is not permitted to be set in ' LOG.debug('DHCP option %s is not permitted to be set in '
'global options. This option will be ignored.', 'global options. This option will be ignored.',

View File

@ -220,7 +220,7 @@ class PortBindingChassisEvent(row_event.RowEvent):
When a chassisredirect port is updated with chassis, this event get When a chassisredirect port is updated with chassis, this event get
generated. We will update corresponding router's gateway port with generated. We will update corresponding router's gateway port with
the chassis's host_id. Later, users can check router's gateway port the chassis's host_id. Later, users can check router's gateway port
host_id to find the location of master HA router. host_id to find the location of primary HA router.
""" """
def __init__(self, driver): def __init__(self, driver):

View File

@ -379,7 +379,7 @@ class OVNL3RouterPlugin(service_base.ServicePluginBase,
# Remove any invalid gateway chassis from the list, otherwise # Remove any invalid gateway chassis from the list, otherwise
# we can have a situation where all existing_chassis are invalid # we can have a situation where all existing_chassis are invalid
existing_chassis = self._ovn.get_gateway_chassis_binding(g_name) existing_chassis = self._ovn.get_gateway_chassis_binding(g_name)
master = existing_chassis[0] if existing_chassis else None primary = existing_chassis[0] if existing_chassis else None
existing_chassis = self.scheduler.filter_existing_chassis( existing_chassis = self.scheduler.filter_existing_chassis(
nb_idl=self._ovn, gw_chassis=all_gw_chassis, nb_idl=self._ovn, gw_chassis=all_gw_chassis,
physnet=physnet, chassis_physnets=chassis_with_physnets, physnet=physnet, chassis_physnets=chassis_with_physnets,
@ -392,21 +392,21 @@ class OVNL3RouterPlugin(service_base.ServicePluginBase,
chassis = self.scheduler.select( chassis = self.scheduler.select(
self._ovn, self._sb_ovn, g_name, candidates=candidates, self._ovn, self._sb_ovn, g_name, candidates=candidates,
existing_chassis=existing_chassis) existing_chassis=existing_chassis)
if master and master != chassis[0]: if primary and primary != chassis[0]:
if master not in chassis: if primary not in chassis:
LOG.debug("Master gateway chassis %(old)s " LOG.debug("Primary gateway chassis %(old)s "
"has been removed from the system. Moving " "has been removed from the system. Moving "
"gateway %(gw)s to other chassis %(new)s.", "gateway %(gw)s to other chassis %(new)s.",
{'gw': g_name, {'gw': g_name,
'old': master, 'old': primary,
'new': chassis[0]}) 'new': chassis[0]})
else: else:
LOG.debug("Gateway %s is hosted at %s.", g_name, master) LOG.debug("Gateway %s is hosted at %s.", g_name, primary)
# NOTE(mjozefcz): It means scheduler moved master chassis # NOTE(mjozefcz): It means scheduler moved primary chassis
# to other gw based on scheduling method. But we don't # to other gw based on scheduling method. But we don't
# want network flap - so moving actual master to be on # want network flap - so moving actual primary to be on
# the top. # the top.
index = chassis.index(master) index = chassis.index(primary)
chassis[0], chassis[index] = chassis[index], chassis[0] chassis[0], chassis[index] = chassis[index], chassis[0]
# NOTE(dalvarez): Let's commit the changes in separate transactions # NOTE(dalvarez): Let's commit the changes in separate transactions
# as we will rely on those for scheduling subsequent gateways. # as we will rely on those for scheduling subsequent gateways.

View File

@ -453,15 +453,15 @@ class TestHAL3Agent(TestL3Agent):
with open(keepalived_state_file, "r") as fd: with open(keepalived_state_file, "r") as fd:
return fd.read() return fd.read()
def _get_state_file_for_master_agent(self, router_id): def _get_state_file_for_primary_agent(self, router_id):
for host in self.environment.hosts: for host in self.environment.hosts:
keepalived_state_file = os.path.join( keepalived_state_file = os.path.join(
host.neutron_config.state_path, "ha_confs", router_id, "state") host.neutron_config.state_path, "ha_confs", router_id, "state")
if self._get_keepalived_state(keepalived_state_file) == "master": if self._get_keepalived_state(keepalived_state_file) == "primary":
return keepalived_state_file return keepalived_state_file
def test_keepalived_multiple_sighups_does_not_forfeit_mastership(self): def test_keepalived_multiple_sighups_does_not_forfeit_primary(self):
"""Setup a complete "Neutron stack" - both an internal and an external """Setup a complete "Neutron stack" - both an internal and an external
network+subnet, and a router connected to both. network+subnet, and a router connected to both.
""" """
@ -479,7 +479,7 @@ class TestHAL3Agent(TestL3Agent):
self._is_ha_router_active_on_one_agent, self._is_ha_router_active_on_one_agent,
router['id']), router['id']),
timeout=90) timeout=90)
keepalived_state_file = self._get_state_file_for_master_agent( keepalived_state_file = self._get_state_file_for_primary_agent(
router['id']) router['id'])
self.assertIsNotNone(keepalived_state_file) self.assertIsNotNone(keepalived_state_file)
network = self.safe_client.create_network(tenant_id) network = self.safe_client.create_network(tenant_id)
@ -498,8 +498,9 @@ class TestHAL3Agent(TestL3Agent):
tenant_id, ext_net['id'], vm.ip, vm.neutron_port['id']) tenant_id, ext_net['id'], vm.ip, vm.neutron_port['id'])
# Check that the keepalived's state file has not changed and is still # Check that the keepalived's state file has not changed and is still
# master. This will indicate that the Throttler works. We want to check # primary. This will indicate that the Throttler works. We want to
# for ha_vrrp_advert_int (the default is 2 seconds), plus a bit more. # check for ha_vrrp_advert_int (the default is 2 seconds), plus a bit
# more.
time_to_stop = (time.time() + time_to_stop = (time.time() +
(common_utils.DEFAULT_THROTTLER_VALUE * (common_utils.DEFAULT_THROTTLER_VALUE *
ha_router.THROTTLER_MULTIPLIER * 1.3)) ha_router.THROTTLER_MULTIPLIER * 1.3))
@ -507,7 +508,7 @@ class TestHAL3Agent(TestL3Agent):
if time.time() > time_to_stop: if time.time() > time_to_stop:
break break
self.assertEqual( self.assertEqual(
"master", "primary",
self._get_keepalived_state(keepalived_state_file)) self._get_keepalived_state(keepalived_state_file))
@tests_base.unstable_test("bug 1798475") @tests_base.unstable_test("bug 1798475")

View File

@ -202,7 +202,7 @@ class L3AgentTestFramework(base.BaseSudoTestCase):
n, len([line for line in out.strip().split('\n') if line])) n, len([line for line in out.strip().split('\n') if line]))
if ha: if ha:
common_utils.wait_until_true(lambda: router.ha_state == 'master') common_utils.wait_until_true(lambda: router.ha_state == 'primary')
with self.assert_max_execution_time(100): with self.assert_max_execution_time(100):
assert_num_of_conntrack_rules(0) assert_num_of_conntrack_rules(0)
@ -322,7 +322,7 @@ class L3AgentTestFramework(base.BaseSudoTestCase):
router.process() router.process()
if enable_ha: if enable_ha:
common_utils.wait_until_true(lambda: router.ha_state == 'master') common_utils.wait_until_true(lambda: router.ha_state == 'primary')
# Keepalived notifies of a state transition when it starts, # Keepalived notifies of a state transition when it starts,
# not when it ends. Thus, we have to wait until keepalived finishes # not when it ends. Thus, we have to wait until keepalived finishes
@ -629,34 +629,34 @@ class L3AgentTestFramework(base.BaseSudoTestCase):
return (router1, router2) return (router1, router2)
def _get_master_and_slave_routers(self, router1, router2, def _get_primary_and_backup_routers(self, router1, router2,
check_external_device=True): check_external_device=True):
try: try:
common_utils.wait_until_true( common_utils.wait_until_true(
lambda: router1.ha_state == 'master') lambda: router1.ha_state == 'primary')
if check_external_device: if check_external_device:
common_utils.wait_until_true( common_utils.wait_until_true(
lambda: self._check_external_device(router1)) lambda: self._check_external_device(router1))
master_router = router1 primary_router = router1
slave_router = router2 backup_router = router2
except common_utils.WaitTimeout: except common_utils.WaitTimeout:
common_utils.wait_until_true( common_utils.wait_until_true(
lambda: router2.ha_state == 'master') lambda: router2.ha_state == 'primary')
if check_external_device: if check_external_device:
common_utils.wait_until_true( common_utils.wait_until_true(
lambda: self._check_external_device(router2)) lambda: self._check_external_device(router2))
master_router = router2 primary_router = router2
slave_router = router1 backup_router = router1
common_utils.wait_until_true( common_utils.wait_until_true(
lambda: master_router.ha_state == 'master') lambda: primary_router.ha_state == 'primary')
if check_external_device: if check_external_device:
common_utils.wait_until_true( common_utils.wait_until_true(
lambda: self._check_external_device(master_router)) lambda: self._check_external_device(primary_router))
common_utils.wait_until_true( common_utils.wait_until_true(
lambda: slave_router.ha_state == 'backup') lambda: backup_router.ha_state == 'backup')
return master_router, slave_router return primary_router, backup_router
def fail_ha_router(self, router): def fail_ha_router(self, router):
device_name = router.get_ha_device_name() device_name = router.get_ha_device_name()

View File

@ -585,7 +585,7 @@ class TestDvrRouter(DvrRouterTestFramework, framework.L3AgentTestFramework):
interface_name = router.get_external_device_name(port['id']) interface_name = router.get_external_device_name(port['id'])
self._assert_no_ip_addresses_on_interface(router.ha_namespace, self._assert_no_ip_addresses_on_interface(router.ha_namespace,
interface_name) interface_name)
utils.wait_until_true(lambda: router.ha_state == 'master') utils.wait_until_true(lambda: router.ha_state == 'primary')
# Keepalived notifies of a state transition when it starts, # Keepalived notifies of a state transition when it starts,
# not when it ends. Thus, we have to wait until keepalived finishes # not when it ends. Thus, we have to wait until keepalived finishes
@ -1348,7 +1348,7 @@ class TestDvrRouter(DvrRouterTestFramework, framework.L3AgentTestFramework):
snat_ports = router.get_snat_interfaces() snat_ports = router.get_snat_interfaces()
if not snat_ports: if not snat_ports:
return return
if router.is_router_master(): if router.is_router_primary():
centralized_floatingips = ( centralized_floatingips = (
router.router[lib_constants.FLOATINGIP_KEY]) router.router[lib_constants.FLOATINGIP_KEY])
for fip in centralized_floatingips: for fip in centralized_floatingips:
@ -1484,31 +1484,31 @@ class TestDvrRouter(DvrRouterTestFramework, framework.L3AgentTestFramework):
ha_port_ip="169.254.192.107", ha_port_ip="169.254.192.107",
ha_port_mac="12:34:56:78:3a:bb") ha_port_mac="12:34:56:78:3a:bb")
master, backup = self._get_master_and_slave_routers( primary, backup = self._get_primary_and_backup_routers(
router1, router2, check_external_device=False) router1, router2, check_external_device=False)
self._assert_ip_addresses_in_dvr_ha_snat_namespace(master) self._assert_ip_addresses_in_dvr_ha_snat_namespace(primary)
self._assert_no_ip_addresses_in_dvr_ha_snat_namespace(backup) self._assert_no_ip_addresses_in_dvr_ha_snat_namespace(backup)
master_ha_device = master.get_ha_device_name() primary_ha_device = primary.get_ha_device_name()
backup_ha_device = backup.get_ha_device_name() backup_ha_device = backup.get_ha_device_name()
self.assertTrue( self.assertTrue(
ip_lib.device_exists(master_ha_device, master.ha_namespace)) ip_lib.device_exists(primary_ha_device, primary.ha_namespace))
self.assertTrue( self.assertTrue(
ip_lib.device_exists(backup_ha_device, backup.ha_namespace)) ip_lib.device_exists(backup_ha_device, backup.ha_namespace))
new_master_router = copy.deepcopy(master.router) new_primary_router = copy.deepcopy(primary.router)
new_master_router['_ha_interface'] = None new_primary_router['_ha_interface'] = None
self.agent._process_updated_router(new_master_router) self.agent._process_updated_router(new_primary_router)
router_updated = self.agent.router_info[master.router_id] router_updated = self.agent.router_info[primary.router_id]
self.assertTrue(self._namespace_exists(router_updated.ns_name)) self.assertTrue(self._namespace_exists(router_updated.ns_name))
self._assert_snat_namespace_exists(router_updated) self._assert_snat_namespace_exists(router_updated)
snat_namespace_name = dvr_snat_ns.SnatNamespace.get_snat_ns_name( snat_namespace_name = dvr_snat_ns.SnatNamespace.get_snat_ns_name(
router_updated.router_id) router_updated.router_id)
self.assertFalse( self.assertFalse(
ip_lib.device_exists(master_ha_device, snat_namespace_name)) ip_lib.device_exists(primary_ha_device, snat_namespace_name))
utils.wait_until_true(lambda: backup.ha_state == 'master') utils.wait_until_true(lambda: backup.ha_state == 'primary')
self._assert_ip_addresses_in_dvr_ha_snat_namespace(backup) self._assert_ip_addresses_in_dvr_ha_snat_namespace(backup)
self.assertTrue( self.assertTrue(
ip_lib.device_exists(backup_ha_device, backup.ha_namespace)) ip_lib.device_exists(backup_ha_device, backup.ha_namespace))
@ -1535,18 +1535,18 @@ class TestDvrRouter(DvrRouterTestFramework, framework.L3AgentTestFramework):
ha_port_ip="169.254.192.101", ha_port_ip="169.254.192.101",
ha_port_mac="12:34:56:78:2b:bb") ha_port_mac="12:34:56:78:2b:bb")
master, backup = self._get_master_and_slave_routers( primary, backup = self._get_primary_and_backup_routers(
router1, router2, check_external_device=False) router1, router2, check_external_device=False)
self._assert_ip_addresses_in_dvr_ha_snat_namespace_with_fip(master) self._assert_ip_addresses_in_dvr_ha_snat_namespace_with_fip(primary)
self._assert_no_ip_addresses_in_dvr_ha_snat_namespace_with_fip(backup) self._assert_no_ip_addresses_in_dvr_ha_snat_namespace_with_fip(backup)
self.fail_ha_router(master) self.fail_ha_router(primary)
utils.wait_until_true(lambda: backup.ha_state == 'master') utils.wait_until_true(lambda: backup.ha_state == 'primary')
utils.wait_until_true(lambda: master.ha_state == 'backup') utils.wait_until_true(lambda: primary.ha_state == 'backup')
self._assert_ip_addresses_in_dvr_ha_snat_namespace_with_fip(backup) self._assert_ip_addresses_in_dvr_ha_snat_namespace_with_fip(backup)
self._assert_no_ip_addresses_in_dvr_ha_snat_namespace_with_fip(master) self._assert_no_ip_addresses_in_dvr_ha_snat_namespace_with_fip(primary)
def _test_dvr_ha_router_failover(self, enable_gw, vrrp_id=None): def _test_dvr_ha_router_failover(self, enable_gw, vrrp_id=None):
self._setup_dvr_ha_agents() self._setup_dvr_ha_agents()
@ -1561,19 +1561,19 @@ class TestDvrRouter(DvrRouterTestFramework, framework.L3AgentTestFramework):
ha_port_ip="169.254.192.103", ha_port_ip="169.254.192.103",
ha_port_mac="12:34:56:78:2b:dd") ha_port_mac="12:34:56:78:2b:dd")
master, backup = self._get_master_and_slave_routers( primary, backup = self._get_primary_and_backup_routers(
router1, router2, check_external_device=False) router1, router2, check_external_device=False)
self._assert_ip_addresses_in_dvr_ha_snat_namespace(master) self._assert_ip_addresses_in_dvr_ha_snat_namespace(primary)
self._assert_no_ip_addresses_in_dvr_ha_snat_namespace(backup) self._assert_no_ip_addresses_in_dvr_ha_snat_namespace(backup)
self.fail_ha_router(master) self.fail_ha_router(primary)
utils.wait_until_true(lambda: backup.ha_state == 'master') utils.wait_until_true(lambda: backup.ha_state == 'primary')
utils.wait_until_true(lambda: master.ha_state == 'backup') utils.wait_until_true(lambda: primary.ha_state == 'backup')
self._assert_ip_addresses_in_dvr_ha_snat_namespace(backup) self._assert_ip_addresses_in_dvr_ha_snat_namespace(backup)
self._assert_no_ip_addresses_in_dvr_ha_snat_namespace(master) self._assert_no_ip_addresses_in_dvr_ha_snat_namespace(primary)
def test_dvr_ha_router_failover_with_gw(self): def test_dvr_ha_router_failover_with_gw(self):
self._test_dvr_ha_router_failover(enable_gw=True, vrrp_id=10) self._test_dvr_ha_router_failover(enable_gw=True, vrrp_id=10)
@ -1607,7 +1607,7 @@ class TestDvrRouter(DvrRouterTestFramework, framework.L3AgentTestFramework):
r2_chsfr = mock.patch.object(self.failover_agent, r2_chsfr = mock.patch.object(self.failover_agent,
'check_ha_state_for_router').start() 'check_ha_state_for_router').start()
utils.wait_until_true(lambda: router1.ha_state == 'master') utils.wait_until_true(lambda: router1.ha_state == 'primary')
self.agent._process_updated_router(router1.router) self.agent._process_updated_router(router1.router)
self.assertTrue(r1_chsfr.called) self.assertTrue(r1_chsfr.called)

View File

@ -41,7 +41,7 @@ class L3HATestCase(framework.L3AgentTestFramework):
side_effect=self.change_router_state).start() side_effect=self.change_router_state).start()
router_info = self.generate_router_info(enable_ha=True) router_info = self.generate_router_info(enable_ha=True)
router = self.manage_router(self.agent, router_info) router = self.manage_router(self.agent, router_info)
common_utils.wait_until_true(lambda: router.ha_state == 'master') common_utils.wait_until_true(lambda: router.ha_state == 'primary')
self.fail_ha_router(router) self.fail_ha_router(router)
common_utils.wait_until_true(lambda: router.ha_state == 'backup') common_utils.wait_until_true(lambda: router.ha_state == 'backup')
@ -50,7 +50,7 @@ class L3HATestCase(framework.L3AgentTestFramework):
(enqueue_mock.call_count == 3 or enqueue_mock.call_count == 4)) (enqueue_mock.call_count == 3 or enqueue_mock.call_count == 4))
calls = [args[0] for args in enqueue_mock.call_args_list] calls = [args[0] for args in enqueue_mock.call_args_list]
self.assertEqual((router.router_id, 'backup'), calls[0]) self.assertEqual((router.router_id, 'backup'), calls[0])
self.assertEqual((router.router_id, 'master'), calls[1]) self.assertEqual((router.router_id, 'primary'), calls[1])
self.assertEqual((router.router_id, 'backup'), calls[-1]) self.assertEqual((router.router_id, 'backup'), calls[-1])
def _expected_rpc_report(self, expected): def _expected_rpc_report(self, expected):
@ -73,7 +73,7 @@ class L3HATestCase(framework.L3AgentTestFramework):
router2 = self.manage_router(self.agent, router_info) router2 = self.manage_router(self.agent, router_info)
common_utils.wait_until_true(lambda: router1.ha_state == 'backup') common_utils.wait_until_true(lambda: router1.ha_state == 'backup')
common_utils.wait_until_true(lambda: router2.ha_state == 'master') common_utils.wait_until_true(lambda: router2.ha_state == 'primary')
common_utils.wait_until_true( common_utils.wait_until_true(
lambda: self._expected_rpc_report( lambda: self._expected_rpc_report(
{router1.router_id: 'standby', router2.router_id: 'active'})) {router1.router_id: 'standby', router2.router_id: 'active'}))
@ -112,7 +112,7 @@ class L3HATestCase(framework.L3AgentTestFramework):
router_info = l3_test_common.prepare_router_data( router_info = l3_test_common.prepare_router_data(
enable_snat=True, enable_ha=True, dual_stack=True, enable_gw=False) enable_snat=True, enable_ha=True, dual_stack=True, enable_gw=False)
router = self.manage_router(self.agent, router_info) router = self.manage_router(self.agent, router_info)
common_utils.wait_until_true(lambda: router.ha_state == 'master') common_utils.wait_until_true(lambda: router.ha_state == 'primary')
if state == 'backup': if state == 'backup':
self.fail_ha_router(router) self.fail_ha_router(router)
common_utils.wait_until_true(lambda: router.ha_state == 'backup') common_utils.wait_until_true(lambda: router.ha_state == 'backup')
@ -121,23 +121,23 @@ class L3HATestCase(framework.L3AgentTestFramework):
router_info['gw_port'] = ex_port router_info['gw_port'] = ex_port
router.process() router.process()
self._assert_ipv6_accept_ra(router, expected_ra) self._assert_ipv6_accept_ra(router, expected_ra)
# As router is going first to master and than to backup mode, # As router is going first to primary and than to backup mode,
# ipv6_forwarding should be enabled on "all" interface always after # ipv6_forwarding should be enabled on "all" interface always after
# that transition # that transition
self._assert_ipv6_forwarding(router, expected_forwarding, self._assert_ipv6_forwarding(router, expected_forwarding,
True) True)
@testtools.skipUnless(netutils.is_ipv6_enabled(), "IPv6 is not enabled") @testtools.skipUnless(netutils.is_ipv6_enabled(), "IPv6 is not enabled")
def test_ipv6_router_advts_and_fwd_after_router_state_change_master(self): def test_ipv6_router_advts_and_fwd_after_router_state_change_primary(self):
# Check that RA and forwarding are enabled when there's no IPv6 # Check that RA and forwarding are enabled when there's no IPv6
# gateway. # gateway.
self._test_ipv6_router_advts_and_fwd_helper('master', self._test_ipv6_router_advts_and_fwd_helper('primary',
enable_v6_gw=False, enable_v6_gw=False,
expected_ra=True, expected_ra=True,
expected_forwarding=True) expected_forwarding=True)
# Check that RA is disabled and forwarding is enabled when an IPv6 # Check that RA is disabled and forwarding is enabled when an IPv6
# gateway is configured. # gateway is configured.
self._test_ipv6_router_advts_and_fwd_helper('master', self._test_ipv6_router_advts_and_fwd_helper('primary',
enable_v6_gw=True, enable_v6_gw=True,
expected_ra=False, expected_ra=False,
expected_forwarding=True) expected_forwarding=True)
@ -219,7 +219,7 @@ class L3HATestCase(framework.L3AgentTestFramework):
router_info = self.generate_router_info( router_info = self.generate_router_info(
ip_version=constants.IP_VERSION_6, enable_ha=True) ip_version=constants.IP_VERSION_6, enable_ha=True)
router1 = self.manage_router(self.agent, router_info) router1 = self.manage_router(self.agent, router_info)
common_utils.wait_until_true(lambda: router1.ha_state == 'master') common_utils.wait_until_true(lambda: router1.ha_state == 'primary')
common_utils.wait_until_true(lambda: router1.radvd.enabled) common_utils.wait_until_true(lambda: router1.radvd.enabled)
def _check_lla_status(router, expected): def _check_lla_status(router, expected):
@ -263,7 +263,7 @@ class L3HATestCase(framework.L3AgentTestFramework):
ipv6_subnet_modes=[slaac_mode], ipv6_subnet_modes=[slaac_mode],
interface_id=interface_id) interface_id=interface_id)
router.process() router.process()
common_utils.wait_until_true(lambda: router.ha_state == 'master') common_utils.wait_until_true(lambda: router.ha_state == 'primary')
# Verify that router internal interface is present and is configured # Verify that router internal interface is present and is configured
# with IP address from both the subnets. # with IP address from both the subnets.
@ -309,7 +309,7 @@ class L3HATestCase(framework.L3AgentTestFramework):
router = self.manage_router(self.agent, router_info) router = self.manage_router(self.agent, router_info)
ex_gw_port = router.get_ex_gw_port() ex_gw_port = router.get_ex_gw_port()
interface_name = router.get_external_device_interface_name(ex_gw_port) interface_name = router.get_external_device_interface_name(ex_gw_port)
common_utils.wait_until_true(lambda: router.ha_state == 'master') common_utils.wait_until_true(lambda: router.ha_state == 'primary')
self._add_fip(router, '172.168.1.20', fixed_address='10.0.0.3') self._add_fip(router, '172.168.1.20', fixed_address='10.0.0.3')
router.process() router.process()
router.router[constants.FLOATINGIP_KEY] = [] router.router[constants.FLOATINGIP_KEY] = []
@ -328,7 +328,7 @@ class L3HATestCase(framework.L3AgentTestFramework):
router1.router[constants.HA_INTERFACE_KEY]['status'] = ( router1.router[constants.HA_INTERFACE_KEY]['status'] = (
constants.PORT_STATUS_ACTIVE) constants.PORT_STATUS_ACTIVE)
self.agent._process_updated_router(router1.router) self.agent._process_updated_router(router1.router)
common_utils.wait_until_true(lambda: router1.ha_state == 'master') common_utils.wait_until_true(lambda: router1.ha_state == 'primary')
def test_ha_router_namespace_has_ip_nonlocal_bind_disabled(self): def test_ha_router_namespace_has_ip_nonlocal_bind_disabled(self):
router_info = self.generate_router_info(enable_ha=True) router_info = self.generate_router_info(enable_ha=True)
@ -362,7 +362,7 @@ class L3HATestCase(framework.L3AgentTestFramework):
router.router[constants.HA_INTERFACE_KEY]['status'] = ( router.router[constants.HA_INTERFACE_KEY]['status'] = (
constants.PORT_STATUS_ACTIVE) constants.PORT_STATUS_ACTIVE)
self.agent._process_updated_router(router.router) self.agent._process_updated_router(router.router)
common_utils.wait_until_true(lambda: router.ha_state == 'master') common_utils.wait_until_true(lambda: router.ha_state == 'primary')
self._wait_until_ipv6_forwarding_has_state( self._wait_until_ipv6_forwarding_has_state(
router.ns_name, external_device_name, 1) router.ns_name, external_device_name, 1)
@ -380,7 +380,7 @@ class L3HATestCase(framework.L3AgentTestFramework):
router.router[constants.HA_INTERFACE_KEY]['status'] = ( router.router[constants.HA_INTERFACE_KEY]['status'] = (
constants.PORT_STATUS_ACTIVE) constants.PORT_STATUS_ACTIVE)
self.agent._process_updated_router(router.router) self.agent._process_updated_router(router.router)
common_utils.wait_until_true(lambda: router.ha_state == 'master') common_utils.wait_until_true(lambda: router.ha_state == 'primary')
self._wait_until_ipv6_forwarding_has_state(router.ns_name, 'all', 1) self._wait_until_ipv6_forwarding_has_state(router.ns_name, 'all', 1)
@ -426,29 +426,29 @@ class L3HATestFailover(framework.L3AgentTestFramework):
def test_ha_router_failover(self): def test_ha_router_failover(self):
router1, router2 = self.create_ha_routers() router1, router2 = self.create_ha_routers()
master_router, slave_router = self._get_master_and_slave_routers( primary_router, backup_router = self._get_primary_and_backup_routers(
router1, router2) router1, router2)
self._assert_ipv6_accept_ra(master_router, True) self._assert_ipv6_accept_ra(primary_router, True)
self._assert_ipv6_forwarding(master_router, True, True) self._assert_ipv6_forwarding(primary_router, True, True)
self._assert_ipv6_accept_ra(slave_router, False) self._assert_ipv6_accept_ra(backup_router, False)
self._assert_ipv6_forwarding(slave_router, False, False) self._assert_ipv6_forwarding(backup_router, False, False)
self.fail_ha_router(router1) self.fail_ha_router(router1)
# NOTE: passing slave_router as first argument, because we expect # NOTE: passing backup_router as first argument, because we expect
# that this router should be the master # that this router should be the primary
new_master, new_slave = self._get_master_and_slave_routers( new_primary, new_backup = self._get_primary_and_backup_routers(
slave_router, master_router) backup_router, primary_router)
self.assertEqual(master_router, new_slave) self.assertEqual(primary_router, new_backup)
self.assertEqual(slave_router, new_master) self.assertEqual(backup_router, new_primary)
self._assert_ipv6_accept_ra(new_master, True) self._assert_ipv6_accept_ra(new_primary, True)
self._assert_ipv6_forwarding(new_master, True, True) self._assert_ipv6_forwarding(new_primary, True, True)
self._assert_ipv6_accept_ra(new_slave, False) self._assert_ipv6_accept_ra(new_backup, False)
# after transition from master -> slave, 'all' IPv6 forwarding should # after transition from primary -> backup, 'all' IPv6 forwarding should
# be enabled # be enabled
self._assert_ipv6_forwarding(new_slave, False, True) self._assert_ipv6_forwarding(new_backup, False, True)
def test_ha_router_lost_gw_connection(self): def test_ha_router_lost_gw_connection(self):
self.agent.conf.set_override( self.agent.conf.set_override(
@ -458,18 +458,18 @@ class L3HATestFailover(framework.L3AgentTestFramework):
router1, router2 = self.create_ha_routers() router1, router2 = self.create_ha_routers()
master_router, slave_router = self._get_master_and_slave_routers( primary_router, backup_router = self._get_primary_and_backup_routers(
router1, router2) router1, router2)
self.fail_gw_router_port(master_router) self.fail_gw_router_port(primary_router)
# NOTE: passing slave_router as first argument, because we expect # NOTE: passing backup_router as first argument, because we expect
# that this router should be the master # that this router should be the primary
new_master, new_slave = self._get_master_and_slave_routers( new_primary, new_backup = self._get_primary_and_backup_routers(
slave_router, master_router) backup_router, primary_router)
self.assertEqual(master_router, new_slave) self.assertEqual(primary_router, new_backup)
self.assertEqual(slave_router, new_master) self.assertEqual(backup_router, new_primary)
def test_both_ha_router_lost_gw_connection(self): def test_both_ha_router_lost_gw_connection(self):
self.agent.conf.set_override( self.agent.conf.set_override(
@ -479,24 +479,24 @@ class L3HATestFailover(framework.L3AgentTestFramework):
router1, router2 = self.create_ha_routers() router1, router2 = self.create_ha_routers()
master_router, slave_router = self._get_master_and_slave_routers( primary_router, backup_router = self._get_primary_and_backup_routers(
router1, router2) router1, router2)
self.fail_gw_router_port(master_router) self.fail_gw_router_port(primary_router)
self.fail_gw_router_port(slave_router) self.fail_gw_router_port(backup_router)
common_utils.wait_until_true( common_utils.wait_until_true(
lambda: master_router.ha_state == 'master') lambda: primary_router.ha_state == 'primary')
common_utils.wait_until_true( common_utils.wait_until_true(
lambda: slave_router.ha_state == 'master') lambda: backup_router.ha_state == 'primary')
self.restore_gw_router_port(master_router) self.restore_gw_router_port(primary_router)
new_master, new_slave = self._get_master_and_slave_routers( new_primary, new_backup = self._get_primary_and_backup_routers(
master_router, slave_router) primary_router, backup_router)
self.assertEqual(master_router, new_master) self.assertEqual(primary_router, new_primary)
self.assertEqual(slave_router, new_slave) self.assertEqual(backup_router, new_backup)
class LinuxBridgeL3HATestCase(L3HATestCase): class LinuxBridgeL3HATestCase(L3HATestCase):

View File

@ -157,7 +157,7 @@ class TestMonitorDaemon(base.BaseLoggingTestCase):
self._run_monitor() self._run_monitor()
msg = 'Wrote router %s state %s' msg = 'Wrote router %s state %s'
self.router.port.addr.add(self.cidr) self.router.port.addr.add(self.cidr)
self._search_in_file(self.log_file, msg % (self.router_id, 'master')) self._search_in_file(self.log_file, msg % (self.router_id, 'primary'))
self.router.port.addr.delete(self.cidr) self.router.port.addr.delete(self.cidr)
self._search_in_file(self.log_file, msg % (self.router_id, 'backup')) self._search_in_file(self.log_file, msg % (self.router_id, 'backup'))
@ -184,8 +184,8 @@ class TestMonitorDaemon(base.BaseLoggingTestCase):
msg = 'Initial status of router %s is %s' % (self.router_id, 'backup') msg = 'Initial status of router %s is %s' % (self.router_id, 'backup')
self._search_in_file(self.log_file, msg) self._search_in_file(self.log_file, msg)
def test_handle_initial_state_master(self): def test_handle_initial_state_primary(self):
self.router.port.addr.add(self.cidr) self.router.port.addr.add(self.cidr)
self._run_monitor() self._run_monitor()
msg = 'Initial status of router %s is %s' % (self.router_id, 'master') msg = 'Initial status of router %s is %s' % (self.router_id, 'primary')
self._search_in_file(self.log_file, msg) self._search_in_file(self.log_file, msg)

View File

@ -256,11 +256,11 @@ class TestVirtualPorts(base.TestOVNFunctionalBase):
virt_port = self._create_port() virt_port = self._create_port()
virt_ip = virt_port['fixed_ips'][0]['ip_address'] virt_ip = virt_port['fixed_ips'][0]['ip_address']
# Create the master port with the VIP address already set in # Create the primary port with the VIP address already set in
# the allowed_address_pairs field # the allowed_address_pairs field
master = self._create_port(allowed_address=virt_ip) primary = self._create_port(allowed_address=virt_ip)
# Assert the virt port has the type virtual and master is set # Assert the virt port has the type virtual and primary is set
# as parent # as parent
self._check_port_type(virt_port['id'], ovn_const.LSP_TYPE_VIRTUAL) self._check_port_type(virt_port['id'], ovn_const.LSP_TYPE_VIRTUAL)
ovn_vport = self._find_port_row(virt_port['id']) ovn_vport = self._find_port_row(virt_port['id'])
@ -268,7 +268,7 @@ class TestVirtualPorts(base.TestOVNFunctionalBase):
virt_ip, virt_ip,
ovn_vport.options[ovn_const.LSP_OPTIONS_VIRTUAL_IP_KEY]) ovn_vport.options[ovn_const.LSP_OPTIONS_VIRTUAL_IP_KEY])
self.assertEqual( self.assertEqual(
master['id'], primary['id'],
ovn_vport.options[ovn_const.LSP_OPTIONS_VIRTUAL_PARENTS_KEY]) ovn_vport.options[ovn_const.LSP_OPTIONS_VIRTUAL_PARENTS_KEY])
# Create the backport parent port # Create the backport parent port
@ -281,7 +281,7 @@ class TestVirtualPorts(base.TestOVNFunctionalBase):
virt_ip, virt_ip,
ovn_vport.options[ovn_const.LSP_OPTIONS_VIRTUAL_IP_KEY]) ovn_vport.options[ovn_const.LSP_OPTIONS_VIRTUAL_IP_KEY])
self.assertIn( self.assertIn(
master['id'], primary['id'],
ovn_vport.options[ovn_const.LSP_OPTIONS_VIRTUAL_PARENTS_KEY]) ovn_vport.options[ovn_const.LSP_OPTIONS_VIRTUAL_PARENTS_KEY])
self.assertIn( self.assertIn(
backup['id'], backup['id'],
@ -289,7 +289,7 @@ class TestVirtualPorts(base.TestOVNFunctionalBase):
@tests_base.unstable_test("bug 1865453") @tests_base.unstable_test("bug 1865453")
def test_virtual_port_update_address_pairs(self): def test_virtual_port_update_address_pairs(self):
master = self._create_port() primary = self._create_port()
backup = self._create_port() backup = self._create_port()
virt_port = self._create_port() virt_port = self._create_port()
virt_ip = virt_port['fixed_ips'][0]['ip_address'] virt_ip = virt_port['fixed_ips'][0]['ip_address']
@ -303,8 +303,8 @@ class TestVirtualPorts(base.TestOVNFunctionalBase):
self.assertNotIn(ovn_const.LSP_OPTIONS_VIRTUAL_IP_KEY, self.assertNotIn(ovn_const.LSP_OPTIONS_VIRTUAL_IP_KEY,
ovn_vport.options) ovn_vport.options)
# Set the virt IP to the allowed address pairs of the master port # Set the virt IP to the allowed address pairs of the primary port
self._set_allowed_address_pair(master['id'], virt_ip) self._set_allowed_address_pair(primary['id'], virt_ip)
# Assert the virt port is now updated # Assert the virt port is now updated
self._check_port_type(virt_port['id'], ovn_const.LSP_TYPE_VIRTUAL), self._check_port_type(virt_port['id'], ovn_const.LSP_TYPE_VIRTUAL),
@ -313,7 +313,7 @@ class TestVirtualPorts(base.TestOVNFunctionalBase):
virt_ip, virt_ip,
ovn_vport.options[ovn_const.LSP_OPTIONS_VIRTUAL_IP_KEY]) ovn_vport.options[ovn_const.LSP_OPTIONS_VIRTUAL_IP_KEY])
self.assertEqual( self.assertEqual(
master['id'], primary['id'],
ovn_vport.options[ovn_const.LSP_OPTIONS_VIRTUAL_PARENTS_KEY]) ovn_vport.options[ovn_const.LSP_OPTIONS_VIRTUAL_PARENTS_KEY])
# Set the virt IP to the allowed address pairs of the backup port # Set the virt IP to the allowed address pairs of the backup port
@ -326,14 +326,14 @@ class TestVirtualPorts(base.TestOVNFunctionalBase):
virt_ip, virt_ip,
ovn_vport.options[ovn_const.LSP_OPTIONS_VIRTUAL_IP_KEY]) ovn_vport.options[ovn_const.LSP_OPTIONS_VIRTUAL_IP_KEY])
self.assertIn( self.assertIn(
master['id'], primary['id'],
ovn_vport.options[ovn_const.LSP_OPTIONS_VIRTUAL_PARENTS_KEY]) ovn_vport.options[ovn_const.LSP_OPTIONS_VIRTUAL_PARENTS_KEY])
self.assertIn( self.assertIn(
backup['id'], backup['id'],
ovn_vport.options[ovn_const.LSP_OPTIONS_VIRTUAL_PARENTS_KEY]) ovn_vport.options[ovn_const.LSP_OPTIONS_VIRTUAL_PARENTS_KEY])
# Remove the address pairs from the master port # Remove the address pairs from the primary port
self._unset_allowed_address_pair(master['id']) self._unset_allowed_address_pair(primary['id'])
# Assert the virt port now only has the backup port as a parent # Assert the virt port now only has the backup port as a parent
self._check_port_type(virt_port['id'], ovn_const.LSP_TYPE_VIRTUAL), self._check_port_type(virt_port['id'], ovn_const.LSP_TYPE_VIRTUAL),
@ -359,13 +359,13 @@ class TestVirtualPorts(base.TestOVNFunctionalBase):
@tests_base.unstable_test("bug 1865453") @tests_base.unstable_test("bug 1865453")
def test_virtual_port_created_after(self): def test_virtual_port_created_after(self):
master = self._create_port(fixed_ip='10.0.0.11') primary = self._create_port(fixed_ip='10.0.0.11')
backup = self._create_port(fixed_ip='10.0.0.12') backup = self._create_port(fixed_ip='10.0.0.12')
virt_ip = '10.0.0.55' virt_ip = '10.0.0.55'
# Set the virt IP to the master and backup ports *before* creating # Set the virt IP to the primary and backup ports *before* creating
# the virtual port # the virtual port
self._set_allowed_address_pair(master['id'], virt_ip) self._set_allowed_address_pair(primary['id'], virt_ip)
self._set_allowed_address_pair(backup['id'], virt_ip) self._set_allowed_address_pair(backup['id'], virt_ip)
virt_port = self._create_port(fixed_ip=virt_ip) virt_port = self._create_port(fixed_ip=virt_ip)
@ -378,7 +378,7 @@ class TestVirtualPorts(base.TestOVNFunctionalBase):
virt_ip, virt_ip,
ovn_vport.options[ovn_const.LSP_OPTIONS_VIRTUAL_IP_KEY]) ovn_vport.options[ovn_const.LSP_OPTIONS_VIRTUAL_IP_KEY])
self.assertIn( self.assertIn(
master['id'], primary['id'],
ovn_vport.options[ovn_const.LSP_OPTIONS_VIRTUAL_PARENTS_KEY]) ovn_vport.options[ovn_const.LSP_OPTIONS_VIRTUAL_PARENTS_KEY])
self.assertIn( self.assertIn(
backup['id'], backup['id'],
@ -386,7 +386,7 @@ class TestVirtualPorts(base.TestOVNFunctionalBase):
@tests_base.unstable_test("bug 1865453") @tests_base.unstable_test("bug 1865453")
def test_virtual_port_delete_parents(self): def test_virtual_port_delete_parents(self):
master = self._create_port() primary = self._create_port()
backup = self._create_port() backup = self._create_port()
virt_port = self._create_port() virt_port = self._create_port()
virt_ip = virt_port['fixed_ips'][0]['ip_address'] virt_ip = virt_port['fixed_ips'][0]['ip_address']
@ -400,8 +400,8 @@ class TestVirtualPorts(base.TestOVNFunctionalBase):
self.assertNotIn(ovn_const.LSP_OPTIONS_VIRTUAL_IP_KEY, self.assertNotIn(ovn_const.LSP_OPTIONS_VIRTUAL_IP_KEY,
ovn_vport.options) ovn_vport.options)
# Set allowed address paris to the master and backup ports # Set allowed address paris to the primary and backup ports
self._set_allowed_address_pair(master['id'], virt_ip) self._set_allowed_address_pair(primary['id'], virt_ip)
self._set_allowed_address_pair(backup['id'], virt_ip) self._set_allowed_address_pair(backup['id'], virt_ip)
# Assert the virtual port is correct # Assert the virtual port is correct
@ -411,7 +411,7 @@ class TestVirtualPorts(base.TestOVNFunctionalBase):
virt_ip, virt_ip,
ovn_vport.options[ovn_const.LSP_OPTIONS_VIRTUAL_IP_KEY]) ovn_vport.options[ovn_const.LSP_OPTIONS_VIRTUAL_IP_KEY])
self.assertIn( self.assertIn(
master['id'], primary['id'],
ovn_vport.options[ovn_const.LSP_OPTIONS_VIRTUAL_PARENTS_KEY]) ovn_vport.options[ovn_const.LSP_OPTIONS_VIRTUAL_PARENTS_KEY])
self.assertIn( self.assertIn(
backup['id'], backup['id'],
@ -420,18 +420,18 @@ class TestVirtualPorts(base.TestOVNFunctionalBase):
# Delete the backup port # Delete the backup port
self._delete('ports', backup['id']) self._delete('ports', backup['id'])
# Assert the virt port now only has the master port as a parent # Assert the virt port now only has the primary port as a parent
ovn_vport = self._find_port_row(virt_port['id']) ovn_vport = self._find_port_row(virt_port['id'])
self.assertEqual(ovn_const.LSP_TYPE_VIRTUAL, ovn_vport.type) self.assertEqual(ovn_const.LSP_TYPE_VIRTUAL, ovn_vport.type)
self.assertEqual( self.assertEqual(
virt_ip, virt_ip,
ovn_vport.options[ovn_const.LSP_OPTIONS_VIRTUAL_IP_KEY]) ovn_vport.options[ovn_const.LSP_OPTIONS_VIRTUAL_IP_KEY])
self.assertEqual( self.assertEqual(
master['id'], primary['id'],
ovn_vport.options[ovn_const.LSP_OPTIONS_VIRTUAL_PARENTS_KEY]) ovn_vport.options[ovn_const.LSP_OPTIONS_VIRTUAL_PARENTS_KEY])
# Delete the master port # Delete the primary port
self._delete('ports', master['id']) self._delete('ports', primary['id'])
# Assert the virt port is not type virtual anymore and the virtual # Assert the virt port is not type virtual anymore and the virtual
# port options are cleared # port options are cleared

View File

@ -521,7 +521,7 @@ class TestRouter(base.TestOVNFunctionalBase):
self.l3_plugin.schedule_unhosted_gateways() self.l3_plugin.schedule_unhosted_gateways()
# As Chassis4 has been removed so all gateways that were # As Chassis4 has been removed so all gateways that were
# hosted there are now masters on chassis5 and have # hosted there are now primaries on chassis5 and have
# priority 1. # priority 1.
self.assertEqual({1: 20}, _get_result_dict()[chassis5]) self.assertEqual({1: 20}, _get_result_dict()[chassis5])

View File

@ -29,78 +29,78 @@ PRIORITY_RPC = 0
class TestExclusiveResourceProcessor(base.BaseTestCase): class TestExclusiveResourceProcessor(base.BaseTestCase):
def test_i_am_master(self): def test_i_am_primary(self):
master = queue.ExclusiveResourceProcessor(FAKE_ID) primary = queue.ExclusiveResourceProcessor(FAKE_ID)
not_master = queue.ExclusiveResourceProcessor(FAKE_ID) not_primary = queue.ExclusiveResourceProcessor(FAKE_ID)
master_2 = queue.ExclusiveResourceProcessor(FAKE_ID_2) primary_2 = queue.ExclusiveResourceProcessor(FAKE_ID_2)
not_master_2 = queue.ExclusiveResourceProcessor(FAKE_ID_2) not_primary_2 = queue.ExclusiveResourceProcessor(FAKE_ID_2)
self.assertTrue(master._i_am_master()) self.assertTrue(primary._i_am_primary())
self.assertFalse(not_master._i_am_master()) self.assertFalse(not_primary._i_am_primary())
self.assertTrue(master_2._i_am_master()) self.assertTrue(primary_2._i_am_primary())
self.assertFalse(not_master_2._i_am_master()) self.assertFalse(not_primary_2._i_am_primary())
master.__exit__(None, None, None) primary.__exit__(None, None, None)
master_2.__exit__(None, None, None) primary_2.__exit__(None, None, None)
def test_master(self): def test_primary(self):
master = queue.ExclusiveResourceProcessor(FAKE_ID) primary = queue.ExclusiveResourceProcessor(FAKE_ID)
not_master = queue.ExclusiveResourceProcessor(FAKE_ID) not_primary = queue.ExclusiveResourceProcessor(FAKE_ID)
master_2 = queue.ExclusiveResourceProcessor(FAKE_ID_2) primary_2 = queue.ExclusiveResourceProcessor(FAKE_ID_2)
not_master_2 = queue.ExclusiveResourceProcessor(FAKE_ID_2) not_primary_2 = queue.ExclusiveResourceProcessor(FAKE_ID_2)
self.assertEqual(master, master._master) self.assertEqual(primary, primary._primary)
self.assertEqual(master, not_master._master) self.assertEqual(primary, not_primary._primary)
self.assertEqual(master_2, master_2._master) self.assertEqual(primary_2, primary_2._primary)
self.assertEqual(master_2, not_master_2._master) self.assertEqual(primary_2, not_primary_2._primary)
master.__exit__(None, None, None) primary.__exit__(None, None, None)
master_2.__exit__(None, None, None) primary_2.__exit__(None, None, None)
def test__enter__(self): def test__enter__(self):
self.assertNotIn(FAKE_ID, queue.ExclusiveResourceProcessor._masters) self.assertNotIn(FAKE_ID, queue.ExclusiveResourceProcessor._primaries)
master = queue.ExclusiveResourceProcessor(FAKE_ID) primary = queue.ExclusiveResourceProcessor(FAKE_ID)
master.__enter__() primary.__enter__()
self.assertIn(FAKE_ID, queue.ExclusiveResourceProcessor._masters) self.assertIn(FAKE_ID, queue.ExclusiveResourceProcessor._primaries)
master.__exit__(None, None, None) primary.__exit__(None, None, None)
def test__exit__(self): def test__exit__(self):
master = queue.ExclusiveResourceProcessor(FAKE_ID) primary = queue.ExclusiveResourceProcessor(FAKE_ID)
not_master = queue.ExclusiveResourceProcessor(FAKE_ID) not_primary = queue.ExclusiveResourceProcessor(FAKE_ID)
master.__enter__() primary.__enter__()
self.assertIn(FAKE_ID, queue.ExclusiveResourceProcessor._masters) self.assertIn(FAKE_ID, queue.ExclusiveResourceProcessor._primaries)
not_master.__enter__() not_primary.__enter__()
not_master.__exit__(None, None, None) not_primary.__exit__(None, None, None)
self.assertIn(FAKE_ID, queue.ExclusiveResourceProcessor._masters) self.assertIn(FAKE_ID, queue.ExclusiveResourceProcessor._primaries)
master.__exit__(None, None, None) primary.__exit__(None, None, None)
self.assertNotIn(FAKE_ID, queue.ExclusiveResourceProcessor._masters) self.assertNotIn(FAKE_ID, queue.ExclusiveResourceProcessor._primaries)
def test_data_fetched_since(self): def test_data_fetched_since(self):
master = queue.ExclusiveResourceProcessor(FAKE_ID) primary = queue.ExclusiveResourceProcessor(FAKE_ID)
self.assertEqual(datetime.datetime.min, self.assertEqual(datetime.datetime.min,
master._get_resource_data_timestamp()) primary._get_resource_data_timestamp())
ts1 = datetime.datetime.utcnow() - datetime.timedelta(seconds=10) ts1 = datetime.datetime.utcnow() - datetime.timedelta(seconds=10)
ts2 = datetime.datetime.utcnow() ts2 = datetime.datetime.utcnow()
master.fetched_and_processed(ts2) primary.fetched_and_processed(ts2)
self.assertEqual(ts2, master._get_resource_data_timestamp()) self.assertEqual(ts2, primary._get_resource_data_timestamp())
master.fetched_and_processed(ts1) primary.fetched_and_processed(ts1)
self.assertEqual(ts2, master._get_resource_data_timestamp()) self.assertEqual(ts2, primary._get_resource_data_timestamp())
master.__exit__(None, None, None) primary.__exit__(None, None, None)
def test_updates(self): def test_updates(self):
master = queue.ExclusiveResourceProcessor(FAKE_ID) primary = queue.ExclusiveResourceProcessor(FAKE_ID)
not_master = queue.ExclusiveResourceProcessor(FAKE_ID) not_primary = queue.ExclusiveResourceProcessor(FAKE_ID)
master.queue_update(queue.ResourceUpdate(FAKE_ID, 0)) primary.queue_update(queue.ResourceUpdate(FAKE_ID, 0))
not_master.queue_update(queue.ResourceUpdate(FAKE_ID, 0)) not_primary.queue_update(queue.ResourceUpdate(FAKE_ID, 0))
for update in not_master.updates(): for update in not_primary.updates():
raise Exception("Only the master should process a resource") raise Exception("Only the primary should process a resource")
self.assertEqual(2, len([i for i in master.updates()])) self.assertEqual(2, len([i for i in primary.updates()]))
def test_hit_retry_limit(self): def test_hit_retry_limit(self):
tries = 1 tries = 1

View File

@ -230,7 +230,7 @@ class TestBasicRouterOperations(BasicRouterOperationsFramework):
non_existent_router = 42 non_existent_router = 42
# Make sure the exceptional code path has coverage # Make sure the exceptional code path has coverage
agent.enqueue_state_change(non_existent_router, 'master') agent.enqueue_state_change(non_existent_router, 'primary')
def _enqueue_state_change_transitions(self, transitions, num_called): def _enqueue_state_change_transitions(self, transitions, num_called):
self.conf.set_override('ha_vrrp_advert_int', 1) self.conf.set_override('ha_vrrp_advert_int', 1)
@ -252,17 +252,17 @@ class TestBasicRouterOperations(BasicRouterOperationsFramework):
else: else:
mock_get_router_info.assert_not_called() mock_get_router_info.assert_not_called()
def test_enqueue_state_change_from_none_to_master(self): def test_enqueue_state_change_from_none_to_primary(self):
self._enqueue_state_change_transitions(['master'], 1) self._enqueue_state_change_transitions(['primary'], 1)
def test_enqueue_state_change_from_none_to_backup(self): def test_enqueue_state_change_from_none_to_backup(self):
self._enqueue_state_change_transitions(['backup'], 1) self._enqueue_state_change_transitions(['backup'], 1)
def test_enqueue_state_change_from_none_to_master_to_backup(self): def test_enqueue_state_change_from_none_to_primary_to_backup(self):
self._enqueue_state_change_transitions(['master', 'backup'], 0) self._enqueue_state_change_transitions(['primary', 'backup'], 0)
def test_enqueue_state_change_from_none_to_backup_to_master(self): def test_enqueue_state_change_from_none_to_backup_to_primary(self):
self._enqueue_state_change_transitions(['backup', 'master'], 2) self._enqueue_state_change_transitions(['backup', 'primary'], 2)
def test_enqueue_state_change_metadata_disable(self): def test_enqueue_state_change_metadata_disable(self):
self.conf.set_override('enable_metadata_proxy', False) self.conf.set_override('enable_metadata_proxy', False)
@ -272,7 +272,7 @@ class TestBasicRouterOperations(BasicRouterOperationsFramework):
router_info = mock.MagicMock() router_info = mock.MagicMock()
agent.router_info[router.id] = router_info agent.router_info[router.id] = router_info
agent._update_metadata_proxy = mock.Mock() agent._update_metadata_proxy = mock.Mock()
agent.enqueue_state_change(router.id, 'master') agent.enqueue_state_change(router.id, 'primary')
eventlet.sleep(self.conf.ha_vrrp_advert_int + 2) eventlet.sleep(self.conf.ha_vrrp_advert_int + 2)
self.assertFalse(agent._update_metadata_proxy.call_count) self.assertFalse(agent._update_metadata_proxy.call_count)
@ -284,11 +284,11 @@ class TestBasicRouterOperations(BasicRouterOperationsFramework):
router_info.agent = agent router_info.agent = agent
agent.router_info[router.id] = router_info agent.router_info[router.id] = router_info
agent.l3_ext_manager.ha_state_change = mock.Mock() agent.l3_ext_manager.ha_state_change = mock.Mock()
agent.enqueue_state_change(router.id, 'master') agent.enqueue_state_change(router.id, 'primary')
eventlet.sleep(self.conf.ha_vrrp_advert_int + 2) eventlet.sleep(self.conf.ha_vrrp_advert_int + 2)
agent.l3_ext_manager.ha_state_change.assert_called_once_with( agent.l3_ext_manager.ha_state_change.assert_called_once_with(
agent.context, agent.context,
{'router_id': router.id, 'state': 'master', {'router_id': router.id, 'state': 'primary',
'host': agent.host}) 'host': agent.host})
def test_enqueue_state_change_router_active_ha(self): def test_enqueue_state_change_router_active_ha(self):
@ -300,7 +300,7 @@ class TestBasicRouterOperations(BasicRouterOperationsFramework):
) as spawn_metadata_proxy, mock.patch.object( ) as spawn_metadata_proxy, mock.patch.object(
agent.metadata_driver, 'destroy_monitored_metadata_proxy' agent.metadata_driver, 'destroy_monitored_metadata_proxy'
) as destroy_metadata_proxy: ) as destroy_metadata_proxy:
agent._update_metadata_proxy(router_info, "router_id", "master") agent._update_metadata_proxy(router_info, "router_id", "primary")
spawn_metadata_proxy.assert_called() spawn_metadata_proxy.assert_called()
destroy_metadata_proxy.assert_not_called() destroy_metadata_proxy.assert_not_called()
@ -337,7 +337,7 @@ class TestBasicRouterOperations(BasicRouterOperationsFramework):
router_info = l3router.RouterInfo(agent, _uuid(), {}, **self.ri_kwargs) router_info = l3router.RouterInfo(agent, _uuid(), {}, **self.ri_kwargs)
if gw_port_id: if gw_port_id:
router_info.ex_gw_port = {'id': gw_port_id} router_info.ex_gw_port = {'id': gw_port_id}
expected_forwarding_state = state == 'master' expected_forwarding_state = state == 'primary'
with mock.patch.object( with mock.patch.object(
router_info.driver, "configure_ipv6_forwarding" router_info.driver, "configure_ipv6_forwarding"
) as configure_ipv6_forwarding, mock.patch.object( ) as configure_ipv6_forwarding, mock.patch.object(
@ -345,7 +345,7 @@ class TestBasicRouterOperations(BasicRouterOperationsFramework):
) as configure_ipv6_on_gw: ) as configure_ipv6_on_gw:
agent._configure_ipv6_params(router_info, state) agent._configure_ipv6_params(router_info, state)
if state == 'master': if state == 'primary':
configure_ipv6_forwarding.assert_called_once_with( configure_ipv6_forwarding.assert_called_once_with(
router_info.ns_name, 'all', expected_forwarding_state) router_info.ns_name, 'all', expected_forwarding_state)
else: else:
@ -360,30 +360,30 @@ class TestBasicRouterOperations(BasicRouterOperationsFramework):
else: else:
configure_ipv6_on_gw.assert_not_called() configure_ipv6_on_gw.assert_not_called()
def test__configure_ipv6_params_master(self): def test__configure_ipv6_params_primary(self):
self._test__configure_ipv6_params_helper('master', gw_port_id=_uuid()) self._test__configure_ipv6_params_helper('primary', gw_port_id=_uuid())
def test__configure_ipv6_params_backup(self): def test__configure_ipv6_params_backup(self):
self._test__configure_ipv6_params_helper('backup', gw_port_id=_uuid()) self._test__configure_ipv6_params_helper('backup', gw_port_id=_uuid())
def test__configure_ipv6_params_master_no_gw_port(self): def test__configure_ipv6_params_primary_no_gw_port(self):
self._test__configure_ipv6_params_helper('master', gw_port_id=None) self._test__configure_ipv6_params_helper('primary', gw_port_id=None)
def test__configure_ipv6_params_backup_no_gw_port(self): def test__configure_ipv6_params_backup_no_gw_port(self):
self._test__configure_ipv6_params_helper('backup', gw_port_id=None) self._test__configure_ipv6_params_helper('backup', gw_port_id=None)
def test_check_ha_state_for_router_master_standby(self): def test_check_ha_state_for_router_primary_standby(self):
agent = l3_agent.L3NATAgent(HOSTNAME, self.conf) agent = l3_agent.L3NATAgent(HOSTNAME, self.conf)
router = mock.Mock() router = mock.Mock()
router.id = '1234' router.id = '1234'
router_info = mock.MagicMock() router_info = mock.MagicMock()
agent.router_info[router.id] = router_info agent.router_info[router.id] = router_info
router_info.ha_state = 'master' router_info.ha_state = 'primary'
with mock.patch.object(agent.state_change_notifier, with mock.patch.object(agent.state_change_notifier,
'queue_event') as queue_event: 'queue_event') as queue_event:
agent.check_ha_state_for_router( agent.check_ha_state_for_router(
router.id, lib_constants.HA_ROUTER_STATE_STANDBY) router.id, lib_constants.HA_ROUTER_STATE_STANDBY)
queue_event.assert_called_once_with((router.id, 'master')) queue_event.assert_called_once_with((router.id, 'primary'))
def test_check_ha_state_for_router_standby_standby(self): def test_check_ha_state_for_router_standby_standby(self):
agent = l3_agent.L3NATAgent(HOSTNAME, self.conf) agent = l3_agent.L3NATAgent(HOSTNAME, self.conf)
@ -3275,7 +3275,7 @@ class TestBasicRouterOperations(BasicRouterOperationsFramework):
ri.get_internal_device_name, ri.get_internal_device_name,
self.conf) self.conf)
if enable_ha: if enable_ha:
agent.pd.routers[router['id']]['master'] = False agent.pd.routers[router['id']]['primary'] = False
return agent, router, ri return agent, router, ri
def _pd_remove_gw_interface(self, intfs, agent, ri): def _pd_remove_gw_interface(self, intfs, agent, ri):

View File

@ -833,7 +833,7 @@ class TestDvrRouterOperations(base.BaseTestCase):
fip_cidr = '11.22.33.44/24' fip_cidr = '11.22.33.44/24'
ri = dvr_edge_ha_rtr.DvrEdgeHaRouter(HOSTNAME, [], **self.ri_kwargs) ri = dvr_edge_ha_rtr.DvrEdgeHaRouter(HOSTNAME, [], **self.ri_kwargs)
ri.is_router_master = mock.Mock(return_value=False) ri.is_router_primary = mock.Mock(return_value=False)
ri._add_vip = mock.Mock() ri._add_vip = mock.Mock()
interface_name = ri.get_snat_external_device_interface_name( interface_name = ri.get_snat_external_device_interface_name(
ri.get_ex_gw_port()) ri.get_ex_gw_port())
@ -844,7 +844,7 @@ class TestDvrRouterOperations(base.BaseTestCase):
router[lib_constants.HA_INTERFACE_KEY]['status'] = 'DOWN' router[lib_constants.HA_INTERFACE_KEY]['status'] = 'DOWN'
self._set_ri_kwargs(agent, router['id'], router) self._set_ri_kwargs(agent, router['id'], router)
ri_1 = dvr_edge_ha_rtr.DvrEdgeHaRouter(HOSTNAME, [], **self.ri_kwargs) ri_1 = dvr_edge_ha_rtr.DvrEdgeHaRouter(HOSTNAME, [], **self.ri_kwargs)
ri_1.is_router_master = mock.Mock(return_value=True) ri_1.is_router_primary = mock.Mock(return_value=True)
ri_1._add_vip = mock.Mock() ri_1._add_vip = mock.Mock()
interface_name = ri_1.get_snat_external_device_interface_name( interface_name = ri_1.get_snat_external_device_interface_name(
ri_1.get_ex_gw_port()) ri_1.get_ex_gw_port())
@ -855,7 +855,7 @@ class TestDvrRouterOperations(base.BaseTestCase):
router[lib_constants.HA_INTERFACE_KEY]['status'] = 'ACTIVE' router[lib_constants.HA_INTERFACE_KEY]['status'] = 'ACTIVE'
self._set_ri_kwargs(agent, router['id'], router) self._set_ri_kwargs(agent, router['id'], router)
ri_2 = dvr_edge_ha_rtr.DvrEdgeHaRouter(HOSTNAME, [], **self.ri_kwargs) ri_2 = dvr_edge_ha_rtr.DvrEdgeHaRouter(HOSTNAME, [], **self.ri_kwargs)
ri_2.is_router_master = mock.Mock(return_value=True) ri_2.is_router_primary = mock.Mock(return_value=True)
ri_2._add_vip = mock.Mock() ri_2._add_vip = mock.Mock()
interface_name = ri_2.get_snat_external_device_interface_name( interface_name = ri_2.get_snat_external_device_interface_name(
ri_2.get_ex_gw_port()) ri_2.get_ex_gw_port())
@ -877,14 +877,14 @@ class TestDvrRouterOperations(base.BaseTestCase):
fip_cidr = '11.22.33.44/24' fip_cidr = '11.22.33.44/24'
ri = dvr_edge_ha_rtr.DvrEdgeHaRouter(HOSTNAME, [], **self.ri_kwargs) ri = dvr_edge_ha_rtr.DvrEdgeHaRouter(HOSTNAME, [], **self.ri_kwargs)
ri.is_router_master = mock.Mock(return_value=False) ri.is_router_primary = mock.Mock(return_value=False)
ri._remove_vip = mock.Mock() ri._remove_vip = mock.Mock()
ri.remove_centralized_floatingip(fip_cidr) ri.remove_centralized_floatingip(fip_cidr)
ri._remove_vip.assert_called_once_with(fip_cidr) ri._remove_vip.assert_called_once_with(fip_cidr)
super_remove_centralized_floatingip.assert_not_called() super_remove_centralized_floatingip.assert_not_called()
ri1 = dvr_edge_ha_rtr.DvrEdgeHaRouter(HOSTNAME, [], **self.ri_kwargs) ri1 = dvr_edge_ha_rtr.DvrEdgeHaRouter(HOSTNAME, [], **self.ri_kwargs)
ri1.is_router_master = mock.Mock(return_value=True) ri1.is_router_primary = mock.Mock(return_value=True)
ri1._remove_vip = mock.Mock() ri1._remove_vip = mock.Mock()
ri1.remove_centralized_floatingip(fip_cidr) ri1.remove_centralized_floatingip(fip_cidr)
ri1._remove_vip.assert_called_once_with(fip_cidr) ri1._remove_vip.assert_called_once_with(fip_cidr)
@ -922,7 +922,7 @@ class TestDvrRouterOperations(base.BaseTestCase):
ri._ha_state_path = self.get_temp_file_path('router_ha_state') ri._ha_state_path = self.get_temp_file_path('router_ha_state')
with open(ri._ha_state_path, "w") as f: with open(ri._ha_state_path, "w") as f:
f.write("master") f.write("primary")
ri._create_snat_namespace = mock.Mock() ri._create_snat_namespace = mock.Mock()
ri.update_initial_state = mock.Mock() ri.update_initial_state = mock.Mock()

View File

@ -138,8 +138,8 @@ class TestBasicRouterOperations(base.BaseTestCase):
lib_fixtures.OpenFixture('ha_state', read_return)).mock_open lib_fixtures.OpenFixture('ha_state', read_return)).mock_open
self.assertEqual(expected, ri.ha_state) self.assertEqual(expected, ri.ha_state)
def test_ha_state_master(self): def test_ha_state_primary(self):
self._test_ha_state('master', 'master') self._test_ha_state('primary', 'primary')
def test_ha_state_unknown(self): def test_ha_state_unknown(self):
# an empty state file should yield 'unknown' # an empty state file should yield 'unknown'

View File

@ -183,26 +183,26 @@ class FakePortContext(api.PortContext):
class MechDriverConfFixture(config_fixture.Config): class MechDriverConfFixture(config_fixture.Config):
def __init__(self, conf=cfg.CONF, blacklist_cfg=None, def __init__(self, conf=cfg.CONF, prohibit_list_cfg=None,
registration_func=None): registration_func=None):
"""ConfigFixture for vnic_type_blacklist """ConfigFixture for vnic_type_prohibit_list
:param conf: The driver configuration object :param conf: The driver configuration object
:param blacklist_cfg: A dictionary in the form :param prohibit_list_cfg: A dictionary in the form
{'group': {'opt': 'value'}}, i.e.: {'group': {'opt': 'value'}}, i.e.:
{'OVS_DRIVER': {'vnic_type_blacklist': {'OVS_DRIVER': {'vnic_type_prohibit_list':
['foo']}} ['foo']}}
:param registration_func: The method which do the config group's :param registration_func: The method which do the config group's
registration. registration.
""" """
super(MechDriverConfFixture, self).__init__(conf) super(MechDriverConfFixture, self).__init__(conf)
self.blacklist_cfg = blacklist_cfg self.prohibit_list_cfg = prohibit_list_cfg
self.registration_func = registration_func self.registration_func = registration_func
def setUp(self): def setUp(self):
super(MechDriverConfFixture, self).setUp() super(MechDriverConfFixture, self).setUp()
self.registration_func(self.conf) self.registration_func(self.conf)
for group, option in self.blacklist_cfg.items(): for group, option in self.prohibit_list_cfg.items():
self.config(group=group, **option) self.config(group=group, **option)

View File

@ -234,9 +234,9 @@ class SriovSwitchMechVnicTypesTestCase(SriovNicSwitchMechanismBaseTestCase):
portbindings.VNIC_DIRECT, portbindings.VNIC_DIRECT,
portbindings.VNIC_MACVTAP, portbindings.VNIC_MACVTAP,
portbindings.VNIC_DIRECT_PHYSICAL] portbindings.VNIC_DIRECT_PHYSICAL]
self.blacklist_cfg = { self.prohibit_list_cfg = {
'SRIOV_DRIVER': { 'SRIOV_DRIVER': {
'vnic_type_blacklist': [] 'vnic_type_prohibit_list': []
} }
} }
super(SriovSwitchMechVnicTypesTestCase, self).setUp() super(SriovSwitchMechVnicTypesTestCase, self).setUp()
@ -250,13 +250,13 @@ class SriovSwitchMechVnicTypesTestCase(SriovNicSwitchMechanismBaseTestCase):
self.override_vnic_types, self.override_vnic_types,
self.driver_with_vnic_types.supported_vnic_types) self.driver_with_vnic_types.supported_vnic_types)
def test_vnic_type_blacklist_valid_item(self): def test_vnic_type_prohibit_list_valid_item(self):
self.blacklist_cfg['SRIOV_DRIVER']['vnic_type_blacklist'] = \ self.prohibit_list_cfg['SRIOV_DRIVER']['vnic_type_prohibit_list'] = \
[portbindings.VNIC_MACVTAP] [portbindings.VNIC_MACVTAP]
fake_conf = cfg.CONF fake_conf = cfg.CONF
fake_conf_fixture = base.MechDriverConfFixture( fake_conf_fixture = base.MechDriverConfFixture(
fake_conf, self.blacklist_cfg, fake_conf, self.prohibit_list_cfg,
mech_sriov_conf.register_sriov_mech_driver_opts) mech_sriov_conf.register_sriov_mech_driver_opts)
self.useFixture(fake_conf_fixture) self.useFixture(fake_conf_fixture)
@ -268,26 +268,27 @@ class SriovSwitchMechVnicTypesTestCase(SriovNicSwitchMechanismBaseTestCase):
self.assertEqual(len(self.default_supported_vnics) - 1, self.assertEqual(len(self.default_supported_vnics) - 1,
len(supported_vnic_types)) len(supported_vnic_types))
def test_vnic_type_blacklist_not_valid_item(self): def test_vnic_type_prohibit_list_not_valid_item(self):
self.blacklist_cfg['SRIOV_DRIVER']['vnic_type_blacklist'] = ['foo'] self.prohibit_list_cfg['SRIOV_DRIVER']['vnic_type_prohibit_list'] = \
['foo']
fake_conf = cfg.CONF fake_conf = cfg.CONF
fake_conf_fixture = base.MechDriverConfFixture( fake_conf_fixture = base.MechDriverConfFixture(
fake_conf, self.blacklist_cfg, fake_conf, self.prohibit_list_cfg,
mech_sriov_conf.register_sriov_mech_driver_opts) mech_sriov_conf.register_sriov_mech_driver_opts)
self.useFixture(fake_conf_fixture) self.useFixture(fake_conf_fixture)
self.assertRaises(ValueError, self.assertRaises(ValueError,
mech_driver.SriovNicSwitchMechanismDriver) mech_driver.SriovNicSwitchMechanismDriver)
def test_vnic_type_blacklist_all_items(self): def test_vnic_type_prohibit_list_all_items(self):
self.blacklist_cfg['SRIOV_DRIVER']['vnic_type_blacklist'] = \ self.prohibit_list_cfg['SRIOV_DRIVER']['vnic_type_prohibit_list'] = \
[portbindings.VNIC_DIRECT, [portbindings.VNIC_DIRECT,
portbindings.VNIC_MACVTAP, portbindings.VNIC_MACVTAP,
portbindings.VNIC_DIRECT_PHYSICAL] portbindings.VNIC_DIRECT_PHYSICAL]
fake_conf = cfg.CONF fake_conf = cfg.CONF
fake_conf_fixture = base.MechDriverConfFixture( fake_conf_fixture = base.MechDriverConfFixture(
fake_conf, self.blacklist_cfg, fake_conf, self.prohibit_list_cfg,
mech_sriov_conf.register_sriov_mech_driver_opts) mech_sriov_conf.register_sriov_mech_driver_opts)
self.useFixture(fake_conf_fixture) self.useFixture(fake_conf_fixture)

View File

@ -335,9 +335,9 @@ class OpenvswitchMechVnicTypesTestCase(OpenvswitchMechanismBaseTestCase):
portbindings.VNIC_SMARTNIC] portbindings.VNIC_SMARTNIC]
def setUp(self): def setUp(self):
self.blacklist_cfg = { self.prohibit_list_cfg = {
'OVS_DRIVER': { 'OVS_DRIVER': {
'vnic_type_blacklist': [] 'vnic_type_prohibit_list': []
} }
} }
self.default_supported_vnics = self.supported_vnics self.default_supported_vnics = self.supported_vnics
@ -347,13 +347,13 @@ class OpenvswitchMechVnicTypesTestCase(OpenvswitchMechanismBaseTestCase):
self.assertEqual(self.default_supported_vnics, self.assertEqual(self.default_supported_vnics,
self.driver.supported_vnic_types) self.driver.supported_vnic_types)
def test_vnic_type_blacklist_valid_item(self): def test_vnic_type_prohibit_list_valid_item(self):
self.blacklist_cfg['OVS_DRIVER']['vnic_type_blacklist'] = \ self.prohibit_list_cfg['OVS_DRIVER']['vnic_type_prohibit_list'] = \
[portbindings.VNIC_DIRECT] [portbindings.VNIC_DIRECT]
fake_conf = cfg.CONF fake_conf = cfg.CONF
fake_conf_fixture = base.MechDriverConfFixture( fake_conf_fixture = base.MechDriverConfFixture(
fake_conf, self.blacklist_cfg, fake_conf, self.prohibit_list_cfg,
mech_ovs_conf.register_ovs_mech_driver_opts) mech_ovs_conf.register_ovs_mech_driver_opts)
self.useFixture(fake_conf_fixture) self.useFixture(fake_conf_fixture)
@ -364,24 +364,25 @@ class OpenvswitchMechVnicTypesTestCase(OpenvswitchMechanismBaseTestCase):
self.assertEqual(len(self.default_supported_vnics) - 1, self.assertEqual(len(self.default_supported_vnics) - 1,
len(supported_vnic_types)) len(supported_vnic_types))
def test_vnic_type_blacklist_not_valid_item(self): def test_vnic_type_prohibit_list_not_valid_item(self):
self.blacklist_cfg['OVS_DRIVER']['vnic_type_blacklist'] = ['foo'] self.prohibit_list_cfg['OVS_DRIVER']['vnic_type_prohibit_list'] = \
['foo']
fake_conf = cfg.CONF fake_conf = cfg.CONF
fake_conf_fixture = base.MechDriverConfFixture( fake_conf_fixture = base.MechDriverConfFixture(
fake_conf, self.blacklist_cfg, fake_conf, self.prohibit_list_cfg,
mech_ovs_conf.register_ovs_mech_driver_opts) mech_ovs_conf.register_ovs_mech_driver_opts)
self.useFixture(fake_conf_fixture) self.useFixture(fake_conf_fixture)
self.assertRaises(ValueError, self.assertRaises(ValueError,
mech_openvswitch.OpenvswitchMechanismDriver) mech_openvswitch.OpenvswitchMechanismDriver)
def test_vnic_type_blacklist_all_items(self): def test_vnic_type_prohibit_list_all_items(self):
self.blacklist_cfg['OVS_DRIVER']['vnic_type_blacklist'] = \ self.prohibit_list_cfg['OVS_DRIVER']['vnic_type_prohibit_list'] = \
self.supported_vnics self.supported_vnics
fake_conf = cfg.CONF fake_conf = cfg.CONF
fake_conf_fixture = base.MechDriverConfFixture( fake_conf_fixture = base.MechDriverConfFixture(
fake_conf, self.blacklist_cfg, fake_conf, self.prohibit_list_cfg,
mech_ovs_conf.register_ovs_mech_driver_opts) mech_ovs_conf.register_ovs_mech_driver_opts)
self.useFixture(fake_conf_fixture) self.useFixture(fake_conf_fixture)

View File

@ -1415,7 +1415,7 @@ class TestOVNL3RouterPlugin(test_mech_driver.Ml2PluginV2TestCase):
self.nb_idl().get_gateway_chassis_binding.side_effect = ( self.nb_idl().get_gateway_chassis_binding.side_effect = (
existing_port_bindings) existing_port_bindings)
# for 1. port schedule untouched, add only 3'rd chassis # for 1. port schedule untouched, add only 3'rd chassis
# for 2. port master scheduler somewhere else # for 2. port primary scheduler somewhere else
# for 3. port schedule all # for 3. port schedule all
self.mock_schedule.side_effect = [ self.mock_schedule.side_effect = [
['chassis1', 'chassis2', 'chassis3'], ['chassis1', 'chassis2', 'chassis3'],
@ -1435,7 +1435,7 @@ class TestOVNL3RouterPlugin(test_mech_driver.Ml2PluginV2TestCase):
'lrp-foo-2', [], ['chassis2']), 'lrp-foo-2', [], ['chassis2']),
mock.call(self.nb_idl(), self.sb_idl(), mock.call(self.nb_idl(), self.sb_idl(),
'lrp-foo-3', [], [])]) 'lrp-foo-3', [], [])])
# make sure that for second port master chassis stays untouched # make sure that for second port primary chassis stays untouched
self.nb_idl().update_lrouter_port.assert_has_calls([ self.nb_idl().update_lrouter_port.assert_has_calls([
mock.call('lrp-foo-1', mock.call('lrp-foo-1',
gateway_chassis=['chassis1', 'chassis2', 'chassis3']), gateway_chassis=['chassis1', 'chassis2', 'chassis3']),

View File

@ -1,9 +1,9 @@
--- ---
features: features:
- Keepalived VRRP health check functionality to enable verification of - Keepalived VRRP health check functionality to enable verification of
connectivity from the "master" router to all gateways. Activation of this connectivity from the "primary" router to all gateways. Activation of this
feature enables gateway connectivity validation and rescheduling of the feature enables gateway connectivity validation and rescheduling of the
"master" router to another node when connectivity is lost. If all routers "primary" router to another node when connectivity is lost. If all routers
lose connectivity to the gateways, the election process will be repeated lose connectivity to the gateways, the election process will be repeated
round-robin until one of the routers restores its gateway connection. In round-robin until one of the routers restores its gateway connection. In
the mean time, all of the routers will be reported as "master". the mean time, all of the routers will be reported as "primary".

View File

@ -0,0 +1,10 @@
---
deprecations:
- |
Terminology such as ``master`` and ``slave`` have been replaced with
more inclusive words, such as ``primary`` and ``backup`` wherever
possible.
The configuration option ``vnic_type_blacklist`` has been deprecated
for both the OpenvSwitch and SRIOV mechanism drivers, and replaced with
``vnic_type_prohibit_list``. They will be removed in a future release.

View File

@ -2,8 +2,8 @@
other: other:
- | - |
Add new configuration group ``ovs_driver`` and new configuration option Add new configuration group ``ovs_driver`` and new configuration option
under it ``vnic_type_blacklist``, to make the previously hardcoded under it ``vnic_type_prohibit_list``, to make the previously hardcoded
``supported_vnic_types`` parameter of the OpenvswitchMechanismDriver ``supported_vnic_types`` parameter of the OpenvswitchMechanismDriver
configurable. configurable.
The ``vnic_types`` listed in the blacklist will be removed from the The ``vnic_types`` listed in the prohibit list will be removed from the
supported_vnic_types list. supported_vnic_types list.

View File

@ -2,8 +2,8 @@
other: other:
- | - |
Add new configuration group ``sriov_driver`` and new configuration option Add new configuration group ``sriov_driver`` and new configuration option
under it ``vnic_type_blacklist``, to make the previously hardcoded under it ``vnic_type_prohibit_list``, to make the previously hardcoded
``supported_vnic_types`` parameter of the SriovNicSwitchMechanismDriver ``supported_vnic_types`` parameter of the SriovNicSwitchMechanismDriver
configurable. configurable.
The ``vnic_types`` listed in the blacklist will be removed from the The ``vnic_types`` listed in the prohibit list will be removed from the
supported_vnic_types list. supported_vnic_types list.

View File

@ -5,7 +5,7 @@ upgrade:
security group rules based on the protocol given, instead of security group rules based on the protocol given, instead of
relying on the backend firewall driver to do this enforcement, relying on the backend firewall driver to do this enforcement,
typically silently ignoring the port option in the rule. The typically silently ignoring the port option in the rule. The
valid set of whitelisted protocols that support ports are TCP, valid set of allowed protocols that support ports are TCP,
UDP, UDPLITE, SCTP and DCCP. Ports used with other protocols UDP, UDPLITE, SCTP and DCCP. Ports used with other protocols
will now generate an HTTP 400 error. For more information, see will now generate an HTTP 400 error. For more information, see
bug `1818385 <https://bugs.launchpad.net/neutron/+bug/1818385>`_. bug `1818385 <https://bugs.launchpad.net/neutron/+bug/1818385>`_.

View File

@ -200,7 +200,7 @@ import_exceptions = neutron._i18n
[testenv:bandit] [testenv:bandit]
envdir = {toxworkdir}/shared envdir = {toxworkdir}/shared
# B104: Possible binding to all interfaces # B104: Possible binding to all interfaces
# B303: blacklist calls: md5, sha1 # B303: prohibit list calls: md5, sha1
# B311: Standard pseudo-random generators are not suitable for security/cryptographic purpose # B311: Standard pseudo-random generators are not suitable for security/cryptographic purpose
# B604: any_other_function_with_shell_equals_true # B604: any_other_function_with_shell_equals_true
deps = -r{toxinidir}/test-requirements.txt deps = -r{toxinidir}/test-requirements.txt

View File

@ -217,13 +217,13 @@
tempest_test_regex: "" tempest_test_regex: ""
# TODO(slaweq): remove tests from # TODO(slaweq): remove tests from
# tempest.scenario.test_network_v6.TestGettingAddress module from # tempest.scenario.test_network_v6.TestGettingAddress module from
# blacklist when bug https://bugs.launchpad.net/neutron/+bug/1863577 will # prohibit list when bug https://bugs.launchpad.net/neutron/+bug/1863577
# be fixed # will be fixed
# TODO(mjozefcz): The test test_port_security_macspoofing_port # TODO(mjozefcz): The test test_port_security_macspoofing_port
# and related bug https://bugs.launchpad.net/tempest/+bug/1728886 # and related bug https://bugs.launchpad.net/tempest/+bug/1728886
# are fixed in Core-OVN, but tempest-slow job uses stable release of # are fixed in Core-OVN, but tempest-slow job uses stable release of
# core OVN now and thats why it is still failing in this job. # core OVN now and thats why it is still failing in this job.
# Remove this blacklist when OVN 20.06 will be releaseed and consumed. # Remove this prohibit list when OVN 20.06 will be releaseed and consumed.
# In addition: on next PTG we will discuss the rules of running specific # In addition: on next PTG we will discuss the rules of running specific
# jobs with OVN master and OVN release branches. Please consider # jobs with OVN master and OVN release branches. Please consider
# specyfing explicitely the version of OVN in tempest-slow jobs. # specyfing explicitely the version of OVN in tempest-slow jobs.