Use is_ovn_metadata_port from the ovn utils

Update the code to use the new is_ovn_metadata_port from utils.
Update the test such that mock port objects are subscriptable. This
is required for the `is_ovn_metadata_port`. I have utilized already
existing `Dictable` class. However, I have removed `__class__` as I
dont think this correct intention of this class. It was introduced
here [1] feel free to disagree.

[1]https://review.opendev.org/c/openstack/neutron/+/205181

Change-Id: Ie9598e6801b093b80d736b313941695c3ed52c02
This commit is contained in:
Miro Tomaska 2023-09-22 16:26:37 -04:00
parent 82f2a21d1c
commit 4c571cedbb
2 changed files with 25 additions and 29 deletions

View File

@ -42,6 +42,7 @@ from neutron.agent.linux import ip_lib
from neutron.agent.linux import iptables_manager
from neutron.cmd import runtime_checks as checks
from neutron.common import _constants as common_constants
from neutron.common.ovn import utils as ovn_utils
from neutron.common import utils as common_utils
from neutron.ipam import utils as ipam_utils
from neutron.privileged.agent.linux import dhcp as priv_dhcp
@ -1210,7 +1211,7 @@ class Dnsmasq(DhcpLocalProcess):
def _get_ovn_metadata_port_ip(self, subnet):
m_ports = [port for port in self.network.ports if
self._is_ovn_metadata_port(port, self.network.id)]
ovn_utils.is_ovn_metadata_port(port)]
if m_ports:
for fixed_ip in m_ports[0].fixed_ips:
if fixed_ip.subnet_id == subnet.id:
@ -1460,11 +1461,6 @@ class Dnsmasq(DhcpLocalProcess):
return True
return False
@staticmethod
def _is_ovn_metadata_port(port, network_id):
return (port.device_id == 'ovnmeta-' + network_id and
port.device_owner == constants.DEVICE_OWNER_DISTRIBUTED)
@classmethod
def should_enable_metadata(cls, conf, network):
"""Determine whether the metadata proxy is needed for a network
@ -1484,7 +1480,7 @@ class Dnsmasq(DhcpLocalProcess):
with 3rd party backends.
"""
for port in network.ports:
if cls._is_ovn_metadata_port(port, network.id):
if ovn_utils.is_ovn_metadata_port(port):
return False
all_subnets = cls._get_all_subnets(network)

View File

@ -74,10 +74,10 @@ class DhcpOpt(object):
# an instance as a dict.
class Dictable(object):
def __getitem__(self, k):
return self.__class__.__dict__.get(k)
return self.__dict__.get(k)
class FakeDhcpPort(object):
class FakeDhcpPort(Dictable):
def __init__(self):
self.id = 'aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaa'
self.admin_state_up = True
@ -90,7 +90,7 @@ class FakeDhcpPort(object):
self.extra_dhcp_opts = []
class FakeOvnMetadataPort(object):
class FakeOvnMetadataPort(Dictable):
def __init__(self):
self.id = 'aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaa'
self.admin_state_up = True
@ -103,7 +103,7 @@ class FakeOvnMetadataPort(object):
self.extra_dhcp_opts = []
class FakeReservedPort(object):
class FakeReservedPort(Dictable):
def __init__(self, id='reserved-aaaa-aaaa-aaaa-aaaaaaaaaaa'):
self.admin_state_up = True
self.device_owner = constants.DEVICE_OWNER_DHCP
@ -118,7 +118,7 @@ class FakeReservedPort(object):
self.id = id
class FakePort1(object):
class FakePort1(Dictable):
def __init__(self, domain='openstacklocal'):
self.id = 'eeeeeeee-eeee-eeee-eeee-eeeeeeeeeeee'
self.admin_state_up = True
@ -132,7 +132,7 @@ class FakePort1(object):
self.dns_assignment = [FakeDNSAssignment('192.168.0.2', domain=domain)]
class FakePort2(object):
class FakePort2(Dictable):
def __init__(self):
self.id = 'ffffffff-ffff-ffff-ffff-ffffffffffff'
self.admin_state_up = False
@ -146,7 +146,7 @@ class FakePort2(object):
self.extra_dhcp_opts = []
class FakePort3(object):
class FakePort3(Dictable):
def __init__(self):
self.id = '44444444-4444-4444-4444-444444444444'
self.admin_state_up = True
@ -163,7 +163,7 @@ class FakePort3(object):
self.extra_dhcp_opts = []
class FakePort4(object):
class FakePort4(Dictable):
def __init__(self):
self.id = 'gggggggg-gggg-gggg-gggg-gggggggggggg'
self.admin_state_up = False
@ -181,7 +181,7 @@ class FakePort4(object):
self.extra_dhcp_opts = []
class FakePort5(object):
class FakePort5(Dictable):
def __init__(self):
self.id = 'eeeeeeee-eeee-eeee-eeee-eeeeeeeeeee'
self.admin_state_up = True
@ -197,7 +197,7 @@ class FakePort5(object):
opt_value='test5')]
class FakePort6(object):
class FakePort6(Dictable):
def __init__(self):
self.id = 'ccccccccc-cccc-cccc-cccc-ccccccccc'
self.admin_state_up = True
@ -217,7 +217,7 @@ class FakePort6(object):
ip_version=constants.IP_VERSION_4)]
class FakeV6Port(object):
class FakeV6Port(Dictable):
def __init__(self, domain='openstacklocal'):
self.id = 'hhhhhhhh-hhhh-hhhh-hhhh-hhhhhhhhhhhh'
self.admin_state_up = True
@ -232,7 +232,7 @@ class FakeV6Port(object):
domain=domain)]
class FakeV6PortExtraOpt(object):
class FakeV6PortExtraOpt(Dictable):
def __init__(self):
self.id = 'hhhhhhhh-hhhh-hhhh-hhhh-hhhhhhhhhhhh'
self.admin_state_up = True
@ -253,7 +253,7 @@ class FakeV6PortExtraOpt(object):
ip_version=constants.IP_VERSION_6)]
class FakeV6PortMultipleFixedIpsSameSubnet(object):
class FakeV6PortMultipleFixedIpsSameSubnet(Dictable):
def __init__(self, domain='openstacklocal'):
self.id = 'hhhhhhhh-hhhh-hhhh-hhhh-hhhhhhhhhhhh'
self.admin_state_up = True
@ -272,7 +272,7 @@ class FakeV6PortMultipleFixedIpsSameSubnet(object):
domain=domain)]
class FakeDualPortWithV6ExtraOpt(object):
class FakeDualPortWithV6ExtraOpt(Dictable):
def __init__(self):
self.id = 'hhhhhhhh-hhhh-hhhh-hhhh-hhhhhhhhhhhh'
self.admin_state_up = True
@ -293,7 +293,7 @@ class FakeDualPortWithV6ExtraOpt(object):
ip_version=constants.IP_VERSION_6)]
class FakeDualPort(object):
class FakeDualPort(Dictable):
def __init__(self, domain='openstacklocal'):
self.id = 'hhhhhhhh-hhhh-hhhh-hhhh-hhhhhhhhhhhh'
self.admin_state_up = True
@ -311,7 +311,7 @@ class FakeDualPort(object):
domain=domain)]
class FakeRouterPort(object):
class FakeRouterPort(Dictable):
def __init__(self, dev_owner=constants.DEVICE_OWNER_ROUTER_INTF,
ip_address='192.168.0.1', domain='openstacklocal'):
self.id = 'rrrrrrrr-rrrr-rrrr-rrrr-rrrrrrrrrrrr'
@ -327,7 +327,7 @@ class FakeRouterPort(object):
for ip in self.fixed_ips]
class FakeRouterHAPort(object):
class FakeRouterHAPort(Dictable):
def __init__(self):
self.id = 'hahahaha-haha-haha-haha-hahahahahaha'
self.admin_state_up = True
@ -340,7 +340,7 @@ class FakeRouterHAPort(object):
'169.254.169.20', 'dddddddd-dddd-dddd-dddd-dddddddddddd')]
class FakeRouterPortNoDHCP(object):
class FakeRouterPortNoDHCP(Dictable):
def __init__(self, dev_owner=constants.DEVICE_OWNER_ROUTER_INTF,
ip_address='192.168.0.1', domain='openstacklocal'):
self.id = 'ssssssss-ssss-ssss-ssss-ssssssssssss'
@ -356,7 +356,7 @@ class FakeRouterPortNoDHCP(object):
for ip in self.fixed_ips]
class FakeRouterPort2(object):
class FakeRouterPort2(Dictable):
def __init__(self):
self.id = 'rrrrrrrr-rrrr-rrrr-rrrr-rrrrrrrrrrrr'
self.admin_state_up = True
@ -370,7 +370,7 @@ class FakeRouterPort2(object):
self.extra_dhcp_opts = []
class FakeRouterPortSegmentID(object):
class FakeRouterPortSegmentID(Dictable):
def __init__(self):
self.id = 'qqqqqqqq-qqqq-qqqq-qqqq-qqqqqqqqqqqq'
self.admin_state_up = True
@ -384,7 +384,7 @@ class FakeRouterPortSegmentID(object):
self.extra_dhcp_opts = []
class FakePortMultipleAgents1(object):
class FakePortMultipleAgents1(Dictable):
def __init__(self):
self.id = 'rrrrrrrr-rrrr-rrrr-rrrr-rrrrrrrrrrrr'
self.admin_state_up = True
@ -398,7 +398,7 @@ class FakePortMultipleAgents1(object):
self.extra_dhcp_opts = []
class FakePortMultipleAgents2(object):
class FakePortMultipleAgents2(Dictable):
def __init__(self):
self.id = 'aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa'
self.admin_state_up = True