test(standby): Ensure hardware call is mocked

- Currently it actually calls
  hardware.get_manager().get_os_install_device() == ack!
- Failed in some environments, but not travis-ci or virtualbox vms
This commit is contained in:
Jay Faulkner 2014-03-04 14:12:42 -08:00
parent 772ab43460
commit fb5fc7926a

View File

@ -218,17 +218,20 @@ class TestStandbyMode(unittest.TestCase):
self.assertFalse(verified) self.assertFalse(verified)
self.assertEqual(md5_mock.call_count, 1) self.assertEqual(md5_mock.call_count, 1)
@mock.patch('teeth_agent.hardware.get_manager', autospec=True)
@mock.patch('teeth_agent.standby._write_image', autospec=True) @mock.patch('teeth_agent.standby._write_image', autospec=True)
@mock.patch('teeth_agent.standby._download_image', autospec=True) @mock.patch('teeth_agent.standby._download_image', autospec=True)
def test_cache_image(self, download_mock, write_mock): def test_cache_image(self, download_mock, write_mock, hardware_mock):
image_info = self._build_fake_image_info() image_info = self._build_fake_image_info()
download_mock.return_value = None download_mock.return_value = None
write_mock.return_value = None write_mock.return_value = None
manager_mock = hardware_mock.return_value
manager_mock.get_os_install_device.return_value = 'manager'
async_result = self.agent_mode.cache_image('cache_image', async_result = self.agent_mode.cache_image('cache_image',
image_info=image_info) image_info=image_info)
async_result.join() async_result.join()
download_mock.assert_called_once_with(image_info) download_mock.assert_called_once_with(image_info)
write_mock.assert_called_once_with(image_info, None) write_mock.assert_called_once_with(image_info, 'manager')
self.assertEqual(self.agent_mode.cached_image_id, image_info['id']) self.assertEqual(self.agent_mode.cached_image_id, image_info['id'])
self.assertEqual('SUCCEEDED', async_result.command_status) self.assertEqual('SUCCEEDED', async_result.command_status)
self.assertEqual(None, async_result.command_result) self.assertEqual(None, async_result.command_result)