Fix TypeError: <MagicMock name='LinuxBridgeManager().local_ip'

This patch fixes an error that does not result in a test failure but
causes the following error to be logged in the test logs:

TypeError: <MagicMock name='LinuxBridgeManager().local_ip' id='666599248'>
is not JSON serializable

Related-Bug: #1234857

Change-Id: I65cdd997745d8b760031f8f32e3c10682ad2288e
This commit is contained in:
Aaron Rosen 2013-10-22 15:33:45 -07:00 committed by Gerrit Code Review
parent 39f6bba5c4
commit e07d536476

View File

@ -97,11 +97,6 @@ class TestLinuxBridgeAgent(base.BaseTestCase):
super(TestLinuxBridgeAgent, self).setUp() super(TestLinuxBridgeAgent, self).setUp()
cfg.CONF.set_override('rpc_backend', cfg.CONF.set_override('rpc_backend',
'neutron.openstack.common.rpc.impl_fake') 'neutron.openstack.common.rpc.impl_fake')
self.lbmgr_patcher = mock.patch('neutron.plugins.linuxbridge.agent.'
'linuxbridge_neutron_agent.'
'LinuxBridgeManager')
self.lbmgr_mock = self.lbmgr_patcher.start()
self.addCleanup(self.lbmgr_patcher.stop)
self.execute_p = mock.patch.object(ip_lib.IPWrapper, '_execute') self.execute_p = mock.patch.object(ip_lib.IPWrapper, '_execute')
self.execute = self.execute_p.start() self.execute = self.execute_p.start()
self.addCleanup(self.execute_p.stop) self.addCleanup(self.execute_p.stop)
@ -113,8 +108,6 @@ class TestLinuxBridgeAgent(base.BaseTestCase):
self.get_mac.return_value = '00:00:00:00:00:01' self.get_mac.return_value = '00:00:00:00:00:01'
def test_update_devices_failed(self): def test_update_devices_failed(self):
lbmgr_instance = self.lbmgr_mock.return_value
lbmgr_instance.update_devices.side_effect = RuntimeError
agent = linuxbridge_neutron_agent.LinuxBridgeNeutronAgentRPC({}, agent = linuxbridge_neutron_agent.LinuxBridgeNeutronAgentRPC({},
0, 0,
None) None)
@ -125,17 +118,18 @@ class TestLinuxBridgeAgent(base.BaseTestCase):
raise_exception[0] += 1 raise_exception[0] += 1
else: else:
raise RuntimeError() raise RuntimeError()
with mock.patch.object(agent.br_mgr,
with mock.patch.object(linuxbridge_neutron_agent.LOG, 'info') as log: "update_devices") as update_devices:
log.side_effect = info_mock update_devices.side_effect = RuntimeError
with testtools.ExpectedException(RuntimeError): with mock.patch.object(linuxbridge_neutron_agent.LOG,
agent.daemon_loop() 'info') as log:
self.assertEqual(3, log.call_count) log.side_effect = info_mock
with testtools.ExpectedException(RuntimeError):
agent.daemon_loop()
self.assertEqual(3, log.call_count)
def test_process_network_devices_failed(self): def test_process_network_devices_failed(self):
device_info = {'current': [1, 2, 3]} device_info = {'current': [1, 2, 3]}
lbmgr_instance = self.lbmgr_mock.return_value
lbmgr_instance.update_devices.return_value = device_info
agent = linuxbridge_neutron_agent.LinuxBridgeNeutronAgentRPC({}, agent = linuxbridge_neutron_agent.LinuxBridgeNeutronAgentRPC({},
0, 0,
None) None)
@ -147,15 +141,18 @@ class TestLinuxBridgeAgent(base.BaseTestCase):
else: else:
raise RuntimeError() raise RuntimeError()
with contextlib.nested( with mock.patch.object(agent.br_mgr,
mock.patch.object(linuxbridge_neutron_agent.LOG, 'info'), "update_devices") as update_devices:
mock.patch.object(agent, 'process_network_devices') update_devices.side_effect = device_info
) as (log, process_network_devices): with contextlib.nested(
log.side_effect = info_mock mock.patch.object(linuxbridge_neutron_agent.LOG, 'info'),
process_network_devices.side_effect = RuntimeError mock.patch.object(agent, 'process_network_devices')
with testtools.ExpectedException(RuntimeError): ) as (log, process_network_devices):
agent.daemon_loop() log.side_effect = info_mock
self.assertEqual(3, log.call_count) process_network_devices.side_effect = RuntimeError
with testtools.ExpectedException(RuntimeError):
agent.daemon_loop()
self.assertEqual(3, log.call_count)
class TestLinuxBridgeManager(base.BaseTestCase): class TestLinuxBridgeManager(base.BaseTestCase):