Do state report after setting start_flag on OVS restart

This fixes race condition leading to lack of fdb entries
on agent after OVS restart, if agent managed to handle all ports
before sending state report with start_flag set to True.

Change-Id: I943f8d805630cdfbefff9cff1fb4bce89210618b
Closes-Bug: #1808136
(cherry picked from commit 3995abefb1)
This commit is contained in:
Oleg Bondarev 2018-12-12 15:11:43 +04:00
parent d36cb19813
commit 329de01d09
2 changed files with 9 additions and 2 deletions

View File

@ -2027,6 +2027,9 @@ class OVSNeutronAgent(l2population_rpc.L2populationRpcCallBackTunnelMixin,
self.setup_tunnel_br_flows() self.setup_tunnel_br_flows()
self.agent_state['start_flag'] = True self.agent_state['start_flag'] = True
tunnel_sync = True tunnel_sync = True
# Force state report to avoid race condition
# with l2pop fdb entries update
self._report_state()
if self.enable_distributed_routing: if self.enable_distributed_routing:
self.dvr_agent.reset_ovs_parameters(self.int_br, self.dvr_agent.reset_ovs_parameters(self.int_br,
self.tun_br, self.tun_br,

View File

@ -1949,7 +1949,9 @@ class TestOvsNeutronAgent(object):
'setup_tunnel_br_flows') as setup_tunnel_br_flows,\ 'setup_tunnel_br_flows') as setup_tunnel_br_flows,\
mock.patch.object( mock.patch.object(
self.mod_agent.OVSNeutronAgent, self.mod_agent.OVSNeutronAgent,
'_reset_tunnel_ofports') as reset_tunnel_ofports: '_reset_tunnel_ofports') as reset_tunnel_ofports,\
mock.patch.object(self.agent.state_rpc,
'report_state') as report_st:
log_exception.side_effect = Exception( log_exception.side_effect = Exception(
'Fake exception to get out of the loop') 'Fake exception to get out of the loop')
devices_not_ready = set() devices_not_ready = set()
@ -1997,7 +1999,9 @@ class TestOvsNeutronAgent(object):
self.assertTrue(setup_tunnel_br_flows.called) self.assertTrue(setup_tunnel_br_flows.called)
self.assertTrue(setup_tunnel_br.called) self.assertTrue(setup_tunnel_br.called)
if self.agent.enable_tunneling: if self.agent.enable_tunneling:
self.assertTrue(self.agent.agent_state.get('start_flag')) self.agent.agent_state['start_flag'] = True
report_st.assert_called_once_with(
self.agent.context, self.agent.agent_state, True)
def test_ovs_status(self): def test_ovs_status(self):
self._test_ovs_status(constants.OVS_NORMAL, self._test_ovs_status(constants.OVS_NORMAL,