Remove Flask mocking from tests
Do not mock `render_template` in tests. Instead let Flask producing full response, then inspect returned JSON object making sure the essential bits are present in the response as we expect them to. Change-Id: I76fd18b7e90f7a83f548f564e17559f3c8fedec1 Co-Authored-By: Aija Jaunteva <ajaunteva@gmail.com> Co-Authored-By: Dmitry Tantsur <divius.inside@gmail.com> Story: 2002745 Task: 22598
This commit is contained in:
parent
3211a9ba68
commit
9900ad87da
@ -27,25 +27,24 @@ class EmulatorTestCase(base.BaseTestCase):
|
|||||||
|
|
||||||
super(EmulatorTestCase, self).setUp()
|
super(EmulatorTestCase, self).setUp()
|
||||||
|
|
||||||
@mock.patch('flask.render_template', autospec=True)
|
def test_root_resource(self):
|
||||||
def test_root_resource(self, render_mock):
|
response = self.app.get('/redfish/v1/')
|
||||||
self.app.get('/redfish/v1/')
|
self.assertEqual(response.status_code, 200)
|
||||||
render_mock.assert_called_once_with('root.json')
|
self.assertEqual(True, bool(response.json))
|
||||||
|
|
||||||
@mock.patch('libvirt.openReadOnly', autospec=True)
|
@mock.patch('libvirt.openReadOnly', autospec=True)
|
||||||
@mock.patch('flask.render_template', autospec=True)
|
def test_collection_resource(self, libvirt_mock):
|
||||||
def test_collection_resource(self, render_mock, libvirt_mock):
|
|
||||||
conn_mock = libvirt_mock.return_value
|
conn_mock = libvirt_mock.return_value
|
||||||
conn_mock.listDefinedDomains.return_value = ['host0', 'host1']
|
conn_mock.listDefinedDomains.return_value = ['host0', 'host1']
|
||||||
|
|
||||||
self.app.get('/redfish/v1/Systems')
|
response = self.app.get('/redfish/v1/Systems')
|
||||||
render_mock.assert_called_once_with('system_collection.json',
|
self.assertEqual(response.status_code, 200)
|
||||||
system_count=2,
|
hosts = ['/redfish/v1/Systems/%s' % x.values()
|
||||||
systems=['host0', 'host1'])
|
for x in response.json['Members']]
|
||||||
|
self.assertEqual(hosts, hosts)
|
||||||
|
|
||||||
@mock.patch('libvirt.openReadOnly', autospec=True)
|
@mock.patch('libvirt.openReadOnly', autospec=True)
|
||||||
@mock.patch('flask.render_template', autospec=True)
|
def test_system_resource_get(self, libvirt_mock):
|
||||||
def test_system_resource_get(self, render_mock, libvirt_mock):
|
|
||||||
with open('sushy_tools/tests/unit/emulator/domain.xml', 'r') as f:
|
with open('sushy_tools/tests/unit/emulator/domain.xml', 'r') as f:
|
||||||
data = f.read()
|
data = f.read()
|
||||||
domain_mock = mock.Mock()
|
domain_mock = mock.Mock()
|
||||||
@ -58,12 +57,19 @@ class EmulatorTestCase(base.BaseTestCase):
|
|||||||
conn_mock = libvirt_mock.return_value
|
conn_mock = libvirt_mock.return_value
|
||||||
conn_mock.lookupByName.return_value = domain_mock
|
conn_mock.lookupByName.return_value = domain_mock
|
||||||
|
|
||||||
self.app.get('/redfish/v1/Systems/xxxx-yyyy-zzzz')
|
response = self.app.get('/redfish/v1/Systems/xxxx-yyyy-zzzz')
|
||||||
|
|
||||||
render_mock.assert_called_once_with(
|
self.assertEqual(response.status_code, 200)
|
||||||
'system.json', identity='xxxx-yyyy-zzzz', uuid='zzzz-yyyy-xxxx',
|
self.assertEqual(response.json['Id'], 'xxxx-yyyy-zzzz')
|
||||||
power_state='On', total_memory_gb=1, total_cpus=2,
|
self.assertEqual(response.json['UUID'], 'zzzz-yyyy-xxxx')
|
||||||
boot_source_target='Cd', boot_source_mode='Legacy')
|
self.assertEqual(response.json['PowerState'], 'On')
|
||||||
|
self.assertEqual(
|
||||||
|
response.json['MemorySummary']['TotalSystemMemoryGiB'], 1)
|
||||||
|
self.assertEqual(response.json['ProcessorSummary']['Count'], 2)
|
||||||
|
self.assertEqual(
|
||||||
|
response.json['Boot']['BootSourceOverrideTarget'], 'Cd')
|
||||||
|
self.assertEqual(
|
||||||
|
response.json['Boot']['BootSourceOverrideMode'], 'Legacy')
|
||||||
|
|
||||||
@mock.patch('libvirt.open', autospec=True)
|
@mock.patch('libvirt.open', autospec=True)
|
||||||
def test_system_resource_patch(self, libvirt_mock):
|
def test_system_resource_patch(self, libvirt_mock):
|
||||||
|
Loading…
x
Reference in New Issue
Block a user