Merge "br_int: Make removal of DVR flows more strict" into stable/pike
This commit is contained in:
commit
bd64409bbb
@ -134,7 +134,8 @@ class OVSIntegrationBridge(ovs_bridge.OVSAgentBridge):
|
|||||||
match = self._dvr_to_src_mac_match(ofp, ofpp,
|
match = self._dvr_to_src_mac_match(ofp, ofpp,
|
||||||
vlan_tag=vlan_tag, dst_mac=dst_mac)
|
vlan_tag=vlan_tag, dst_mac=dst_mac)
|
||||||
for table in (table_id, constants.TRANSIENT_TABLE):
|
for table in (table_id, constants.TRANSIENT_TABLE):
|
||||||
self.uninstall_flows(table_id=table, match=match)
|
self.uninstall_flows(
|
||||||
|
strict=True, priority=4, table_id=table, match=match)
|
||||||
|
|
||||||
def add_dvr_mac_vlan(self, mac, port):
|
def add_dvr_mac_vlan(self, mac, port):
|
||||||
self.install_goto(table_id=constants.LOCAL_SWITCHING,
|
self.install_goto(table_id=constants.LOCAL_SWITCHING,
|
||||||
|
@ -95,7 +95,9 @@ class OVSIntegrationBridge(ovs_bridge.OVSAgentBridge):
|
|||||||
def delete_dvr_to_src_mac(self, network_type, vlan_tag, dst_mac):
|
def delete_dvr_to_src_mac(self, network_type, vlan_tag, dst_mac):
|
||||||
table_id = self._dvr_to_src_mac_table_id(network_type)
|
table_id = self._dvr_to_src_mac_table_id(network_type)
|
||||||
for table in (table_id, constants.TRANSIENT_TABLE):
|
for table in (table_id, constants.TRANSIENT_TABLE):
|
||||||
self.delete_flows(table=table,
|
self.delete_flows(strict=True,
|
||||||
|
priority=4,
|
||||||
|
table=table,
|
||||||
dl_vlan=vlan_tag,
|
dl_vlan=vlan_tag,
|
||||||
dl_dst=dst_mac)
|
dl_dst=dst_mac)
|
||||||
|
|
||||||
|
@ -195,11 +195,17 @@ class OVSIntegrationBridgeTest(ovs_bridge_test_base.OVSBridgeTestBase):
|
|||||||
dst_mac=dst_mac)
|
dst_mac=dst_mac)
|
||||||
(dp, ofp, ofpp) = self._get_dp()
|
(dp, ofp, ofpp) = self._get_dp()
|
||||||
expected = [
|
expected = [
|
||||||
call.uninstall_flows(table_id=1,
|
call.uninstall_flows(
|
||||||
|
strict=True,
|
||||||
|
priority=4,
|
||||||
|
table_id=1,
|
||||||
match=ofpp.OFPMatch(
|
match=ofpp.OFPMatch(
|
||||||
eth_dst=dst_mac,
|
eth_dst=dst_mac,
|
||||||
vlan_vid=vlan_tag | ofp.OFPVID_PRESENT)),
|
vlan_vid=vlan_tag | ofp.OFPVID_PRESENT)),
|
||||||
call.uninstall_flows(table_id=60,
|
call.uninstall_flows(
|
||||||
|
strict=True,
|
||||||
|
priority=4,
|
||||||
|
table_id=60,
|
||||||
match=ofpp.OFPMatch(
|
match=ofpp.OFPMatch(
|
||||||
eth_dst=dst_mac,
|
eth_dst=dst_mac,
|
||||||
vlan_vid=vlan_tag | ofp.OFPVID_PRESENT)),
|
vlan_vid=vlan_tag | ofp.OFPVID_PRESENT)),
|
||||||
@ -257,11 +263,17 @@ class OVSIntegrationBridgeTest(ovs_bridge_test_base.OVSBridgeTestBase):
|
|||||||
dst_mac=dst_mac)
|
dst_mac=dst_mac)
|
||||||
(dp, ofp, ofpp) = self._get_dp()
|
(dp, ofp, ofpp) = self._get_dp()
|
||||||
expected = [
|
expected = [
|
||||||
call.uninstall_flows(table_id=2,
|
call.uninstall_flows(
|
||||||
|
strict=True,
|
||||||
|
priority=4,
|
||||||
|
table_id=2,
|
||||||
match=ofpp.OFPMatch(
|
match=ofpp.OFPMatch(
|
||||||
eth_dst=dst_mac,
|
eth_dst=dst_mac,
|
||||||
vlan_vid=vlan_tag | ofp.OFPVID_PRESENT)),
|
vlan_vid=vlan_tag | ofp.OFPVID_PRESENT)),
|
||||||
call.uninstall_flows(table_id=60,
|
call.uninstall_flows(
|
||||||
|
strict=True,
|
||||||
|
priority=4,
|
||||||
|
table_id=60,
|
||||||
match=ofpp.OFPMatch(
|
match=ofpp.OFPMatch(
|
||||||
eth_dst=dst_mac,
|
eth_dst=dst_mac,
|
||||||
vlan_vid=vlan_tag | ofp.OFPVID_PRESENT)),
|
vlan_vid=vlan_tag | ofp.OFPVID_PRESENT)),
|
||||||
|
@ -117,8 +117,12 @@ class OVSIntegrationBridgeTest(ovs_bridge_test_base.OVSBridgeTestBase):
|
|||||||
vlan_tag=vlan_tag,
|
vlan_tag=vlan_tag,
|
||||||
dst_mac=dst_mac)
|
dst_mac=dst_mac)
|
||||||
expected = [
|
expected = [
|
||||||
call.delete_flows(table=1, dl_dst=dst_mac, dl_vlan=vlan_tag),
|
call.delete_flows(
|
||||||
call.delete_flows(table=60, dl_dst=dst_mac, dl_vlan=vlan_tag),
|
strict=True, priority=4, table=1, dl_dst=dst_mac,
|
||||||
|
dl_vlan=vlan_tag),
|
||||||
|
call.delete_flows(
|
||||||
|
strict=True, priority=4, table=60, dl_dst=dst_mac,
|
||||||
|
dl_vlan=vlan_tag),
|
||||||
]
|
]
|
||||||
self.assertEqual(expected, self.mock.mock_calls)
|
self.assertEqual(expected, self.mock.mock_calls)
|
||||||
|
|
||||||
@ -155,8 +159,12 @@ class OVSIntegrationBridgeTest(ovs_bridge_test_base.OVSBridgeTestBase):
|
|||||||
vlan_tag=vlan_tag,
|
vlan_tag=vlan_tag,
|
||||||
dst_mac=dst_mac)
|
dst_mac=dst_mac)
|
||||||
expected = [
|
expected = [
|
||||||
call.delete_flows(table=2, dl_dst=dst_mac, dl_vlan=vlan_tag),
|
call.delete_flows(
|
||||||
call.delete_flows(table=60, dl_dst=dst_mac, dl_vlan=vlan_tag),
|
strict=True, priority=4, table=2, dl_dst=dst_mac,
|
||||||
|
dl_vlan=vlan_tag),
|
||||||
|
call.delete_flows(
|
||||||
|
strict=True, priority=4, table=60, dl_dst=dst_mac,
|
||||||
|
dl_vlan=vlan_tag),
|
||||||
]
|
]
|
||||||
self.assertEqual(expected, self.mock.mock_calls)
|
self.assertEqual(expected, self.mock.mock_calls)
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user