Merge "[Fullstack] Drop all linuxbridge scenarios from fullstack tests"

This commit is contained in:
Zuul 2023-11-10 17:56:16 +00:00 committed by Gerrit Code Review
commit b1585c52dc
8 changed files with 3 additions and 117 deletions

View File

@ -188,7 +188,7 @@ class TestPlacementBandwidthReport(base.BaseFullStackTestCase):
scenarios = [ scenarios = [
(constants.AGENT_TYPE_OVS, (constants.AGENT_TYPE_OVS,
{'l2_agent_type': constants.AGENT_TYPE_OVS, {'l2_agent_type': constants.AGENT_TYPE_OVS,
'mech_drivers': 'openvswitch,linuxbridge', 'mech_drivers': 'openvswitch',
'placement_port': '8080'}), 'placement_port': '8080'}),
(constants.AGENT_TYPE_NIC_SWITCH, (constants.AGENT_TYPE_NIC_SWITCH,
{'l2_agent_type': constants.AGENT_TYPE_NIC_SWITCH, {'l2_agent_type': constants.AGENT_TYPE_NIC_SWITCH,

View File

@ -20,7 +20,6 @@ from oslo_utils import uuidutils
import testscenarios import testscenarios
from neutron.common import utils as common_utils from neutron.common import utils as common_utils
from neutron.tests import base as tests_base
from neutron.tests.common import net_helpers from neutron.tests.common import net_helpers
from neutron.tests.fullstack import base from neutron.tests.fullstack import base
from neutron.tests.fullstack.resources import config from neutron.tests.fullstack.resources import config
@ -150,22 +149,6 @@ class TestOvsConnectivitySameNetworkOnOvsBridgeControllerStop(
signal.SIGKILL) signal.SIGKILL)
class TestLinuxBridgeConnectivitySameNetwork(BaseConnectivitySameNetworkTest):
l2_agent_type = constants.AGENT_TYPE_LINUXBRIDGE
scenarios = [
('VXLAN', {'network_type': 'vxlan',
'l2_pop': False}),
('VLANs', {'network_type': 'vlan',
'l2_pop': False}),
('VXLAN and l2pop', {'network_type': 'vxlan',
'l2_pop': True})
]
def test_connectivity(self):
self._test_connectivity()
class _TestUninterruptedConnectivityOnL2AgentRestart( class _TestUninterruptedConnectivityOnL2AgentRestart(
BaseConnectivitySameNetworkTest): BaseConnectivitySameNetworkTest):
@ -210,20 +193,3 @@ class TestUninterruptedConnectivityOnL2AgentRestartOvs(
def test_l2_agent_restart(self, agent_restart_timeout=20): def test_l2_agent_restart(self, agent_restart_timeout=20):
self._test_l2_agent_restart(agent_restart_timeout) self._test_l2_agent_restart(agent_restart_timeout)
class TestUninterruptedConnectivityOnL2AgentRestartLB(
_TestUninterruptedConnectivityOnL2AgentRestart):
scenario = [('LB',
{'l2_agent_type': constants.AGENT_TYPE_LINUXBRIDGE})]
scenarios = (
testscenarios.multiply_scenarios(
scenario,
_TestUninterruptedConnectivityOnL2AgentRestart.network_scenarios)
)
@tests_base.unstable_test("bug 1928764")
def test_l2_agent_restart(self, agent_restart_timeout=20):
self._test_l2_agent_restart(agent_restart_timeout)

View File

@ -33,8 +33,6 @@ class BaseDhcpAgentTest(base.BaseFullStackTestCase):
scenarios = [ scenarios = [
(constants.AGENT_TYPE_OVS, (constants.AGENT_TYPE_OVS,
{'l2_agent_type': constants.AGENT_TYPE_OVS}), {'l2_agent_type': constants.AGENT_TYPE_OVS}),
(constants.AGENT_TYPE_LINUXBRIDGE,
{'l2_agent_type': constants.AGENT_TYPE_LINUXBRIDGE})
] ]
boot_vm_for_test = True boot_vm_for_test = True
dhcp_scheduler_class = None dhcp_scheduler_class = None

View File

@ -37,8 +37,6 @@ class PortShutDownTest(base.BaseFullStackTestCase):
num_hosts = 1 num_hosts = 1
scenarios = [ scenarios = [
(constants.AGENT_TYPE_LINUXBRIDGE,
{'l2_agent_type': constants.AGENT_TYPE_LINUXBRIDGE}),
(constants.AGENT_TYPE_OVS, (constants.AGENT_TYPE_OVS,
{'l2_agent_type': constants.AGENT_TYPE_OVS}) {'l2_agent_type': constants.AGENT_TYPE_OVS})
] ]

View File

@ -32,10 +32,6 @@ class TestPortsRebind(base.BaseFullStackTestCase):
('Open vSwitch Agent', { ('Open vSwitch Agent', {
'l2_agent_type': constants.AGENT_TYPE_OVS, 'l2_agent_type': constants.AGENT_TYPE_OVS,
'l2_mechdriver_name': 'openvswitch', 'l2_mechdriver_name': 'openvswitch',
}),
('Linux Bridge Agent', {
'l2_agent_type': constants.AGENT_TYPE_LINUXBRIDGE,
'l2_mechdriver_name': 'linuxbridge',
})] })]
def setUp(self): def setUp(self):
@ -170,9 +166,6 @@ class TestRouterPortRebind(TestPortsRebind):
5. Router's port created in p.3 should be now bound properly 5. Router's port created in p.3 should be now bound properly
""" """
if self.l2_agent_type == constants.AGENT_TYPE_LINUXBRIDGE:
self.skipTest("Bug 1798085")
gw_port = self.safe_client.client.list_ports( gw_port = self.safe_client.client.list_ports(
device_id=self.router['id'], device_id=self.router['id'],
device_owner=constants.DEVICE_OWNER_ROUTER_GW)['ports'][0] device_owner=constants.DEVICE_OWNER_ROUTER_GW)['ports'][0]

View File

@ -20,7 +20,6 @@ from neutron_lib.services.qos import constants as qos_consts
from neutronclient.common import exceptions from neutronclient.common import exceptions
from oslo_utils import uuidutils from oslo_utils import uuidutils
from neutron.agent.linux import tc_lib
from neutron.common import utils from neutron.common import utils
from neutron.tests.common.agents import l2_extensions from neutron.tests.common.agents import l2_extensions
from neutron.tests.fullstack import base from neutron.tests.fullstack import base
@ -30,11 +29,6 @@ from neutron.tests.fullstack.resources import machine
from neutron.tests.unit import testlib_api from neutron.tests.unit import testlib_api
from neutron.agent.common import ovs_lib from neutron.agent.common import ovs_lib
from neutron.conf.plugins.ml2.drivers import linuxbridge as \
linuxbridge_agent_config
from neutron.plugins.ml2.drivers.linuxbridge.agent import \
linuxbridge_neutron_agent as linuxbridge_agent
from neutron.services.qos.drivers.linuxbridge import driver as lb_drv
from neutron.services.qos.drivers.openvswitch import driver as ovs_drv from neutron.services.qos.drivers.openvswitch import driver as ovs_drv
@ -404,46 +398,6 @@ class TestBwLimitQoSOvs(_TestBwLimitQoS, base.BaseFullStackTestCase):
self.assertIsNone(qos_queues) self.assertIsNone(qos_queues)
class TestBwLimitQoSLinuxbridge(_TestBwLimitQoS, base.BaseFullStackTestCase):
l2_agent_type = constants.AGENT_TYPE_LINUXBRIDGE
scenarios = [
('egress', {'direction': constants.EGRESS_DIRECTION}),
('ingress', {'direction': constants.INGRESS_DIRECTION}),
]
@staticmethod
def _get_expected_burst_value(limit, direction):
# For egress bandwidth limit this value should be calculated as
# bandwidth_limit * qos_consts.DEFAULT_BURST_RATE
if direction == constants.EGRESS_DIRECTION:
return TestBwLimitQoSLinuxbridge._get_expected_egress_burst_value(
limit)
else:
return TestBwLimitQoSLinuxbridge._get_expected_ingress_burst_value(
limit)
@staticmethod
def _get_expected_ingress_burst_value(limit):
return int(
float(limit) /
float(linuxbridge_agent_config.DEFAULT_KERNEL_HZ_VALUE))
def _wait_for_bw_rule_applied(self, vm, limit, burst, direction):
port_name = linuxbridge_agent.LinuxBridgeManager.get_tap_device_name(
vm.neutron_port['id'])
tc = tc_lib.TcCommand(
port_name,
linuxbridge_agent_config.DEFAULT_KERNEL_HZ_VALUE,
namespace=vm.host.host_namespace
)
if direction == constants.EGRESS_DIRECTION:
utils.wait_until_true(
lambda: tc.get_filters_bw_limits() == (limit, burst))
elif direction == constants.INGRESS_DIRECTION:
utils.wait_until_true(
lambda: tc.get_tbf_bw_limits() == (limit, burst))
class _TestDscpMarkingQoS(BaseQoSRuleTestCase): class _TestDscpMarkingQoS(BaseQoSRuleTestCase):
number_of_hosts = 2 number_of_hosts = 2
@ -540,15 +494,6 @@ class TestDscpMarkingQoSOvs(_TestDscpMarkingQoS, base.BaseFullStackTestCase):
vm.bridge, vm.port.name, dscp_mark) vm.bridge, vm.port.name, dscp_mark)
class TestDscpMarkingQoSLinuxbridge(_TestDscpMarkingQoS,
base.BaseFullStackTestCase):
l2_agent_type = constants.AGENT_TYPE_LINUXBRIDGE
def _wait_for_dscp_marking_rule_applied(self, vm, dscp_mark):
l2_extensions.wait_until_dscp_marking_rule_applied_linuxbridge(
vm.host.host_namespace, vm.port.name, dscp_mark)
class _TestPacketRateLimitQoS(BaseQoSRuleTestCase): class _TestPacketRateLimitQoS(BaseQoSRuleTestCase):
number_of_hosts = 1 number_of_hosts = 1
@ -644,9 +589,6 @@ class TestQoSWithL2Population(base.BaseFullStackTestCase):
(constants.AGENT_TYPE_OVS, (constants.AGENT_TYPE_OVS,
{'mech_drivers': 'openvswitch', {'mech_drivers': 'openvswitch',
'supported_rules': ovs_drv.SUPPORTED_RULES}), 'supported_rules': ovs_drv.SUPPORTED_RULES}),
(constants.AGENT_TYPE_LINUXBRIDGE,
{'mech_drivers': 'linuxbridge',
'supported_rules': lb_drv.SUPPORTED_RULES})
] ]
def setUp(self): def setUp(self):

View File

@ -94,9 +94,6 @@ class TestSecurityGroupsSameNetwork(BaseSecurityGroupsSameNetworkTest):
network_type = 'vxlan' network_type = 'vxlan'
scenarios = [ scenarios = [
# TODO(njohnston): Re-add the linuxbridge scenario once it is stable
# The iptables_hybrid driver lacks isolation between agents and
# because of that using only one host is enough
('ovs-hybrid', { ('ovs-hybrid', {
'firewall_driver': 'iptables_hybrid', 'firewall_driver': 'iptables_hybrid',
'l2_agent_type': constants.AGENT_TYPE_OVS, 'l2_agent_type': constants.AGENT_TYPE_OVS,

View File

@ -11,7 +11,6 @@
# under the License. # under the License.
from neutron_lib import constants from neutron_lib import constants
from neutronclient.common import exceptions
from oslo_utils import uuidutils from oslo_utils import uuidutils
from neutron.tests.common.agents import l2_extensions from neutron.tests.common.agents import l2_extensions
@ -72,8 +71,7 @@ class TestSegmentationId(BaseSegmentationIdTest):
scenarios = [ scenarios = [
('Open vSwitch Agent', {'l2_agent_type': constants.AGENT_TYPE_OVS}), ('Open vSwitch Agent', {'l2_agent_type': constants.AGENT_TYPE_OVS}),
('Linux Bridge Agent', { ]
'l2_agent_type': constants.AGENT_TYPE_LINUXBRIDGE})]
num_hosts = 1 num_hosts = 1
def test_change_segmentation_id_no_ports_in_network(self): def test_change_segmentation_id_no_ports_in_network(self):
@ -103,13 +101,7 @@ class TestSegmentationId(BaseSegmentationIdTest):
self.safe_client.create_port(self.project_id, network['id'], self.safe_client.create_port(self.project_id, network['id'],
self.environment.hosts[0].hostname) self.environment.hosts[0].hostname)
if self.l2_agent_type == constants.AGENT_TYPE_LINUXBRIDGE: self._update_segmentation_id(network)
# Linuxbridge agent don't support update of segmentation_id for
# the network so this should raise an exception
self.assertRaises(exceptions.BadRequest,
self._update_segmentation_id, network)
else:
self._update_segmentation_id(network)
class TestSegmentationIdConnectivity(BaseSegmentationIdTest): class TestSegmentationIdConnectivity(BaseSegmentationIdTest):