Enforce autospec in some api controllers modules

And modify corresponding filter in tox.ini for:
test_base.py
v1/test_allocation.py

Change-Id: I02f1ee5093872ca8521646cf49bbae5744a386ff
This commit is contained in:
Riccardo Pittau 2020-11-02 17:48:08 +01:00
parent 7ea6e41b26
commit 3e5f3df91c
3 changed files with 34 additions and 15 deletions

View File

@ -38,7 +38,8 @@ class TestBase(base.BaseApiTest):
class TestVersion(base.BaseApiTest): class TestVersion(base.BaseApiTest):
@mock.patch('ironic.api.controllers.base.Version.parse_headers') @mock.patch('ironic.api.controllers.base.Version.parse_headers',
autospec=True)
def test_init(self, mock_parse): def test_init(self, mock_parse):
a = mock.Mock() a = mock.Mock()
b = mock.Mock() b = mock.Mock()
@ -49,14 +50,16 @@ class TestVersion(base.BaseApiTest):
self.assertEqual(a, v.major) self.assertEqual(a, v.major)
self.assertEqual(b, v.minor) self.assertEqual(b, v.minor)
@mock.patch('ironic.api.controllers.base.Version.parse_headers') @mock.patch('ironic.api.controllers.base.Version.parse_headers',
autospec=True)
def test_repr(self, mock_parse): def test_repr(self, mock_parse):
mock_parse.return_value = (123, 456) mock_parse.return_value = (123, 456)
v = cbase.Version('test', mock.ANY, mock.ANY) v = cbase.Version('test', mock.ANY, mock.ANY)
result = "%s" % v result = "%s" % v
self.assertEqual('123.456', result) self.assertEqual('123.456', result)
@mock.patch('ironic.api.controllers.base.Version.parse_headers') @mock.patch('ironic.api.controllers.base.Version.parse_headers',
autospec=True)
def test_repr_with_strings(self, mock_parse): def test_repr_with_strings(self, mock_parse):
mock_parse.return_value = ('abc', 'def') mock_parse.return_value = ('abc', 'def')
v = cbase.Version('test', mock.ANY, mock.ANY) v = cbase.Version('test', mock.ANY, mock.ANY)

View File

@ -597,8 +597,9 @@ class TestPatch(test_api_base.BaseApiTest):
self.assertEqual(http_client.BAD_REQUEST, response.status_int) self.assertEqual(http_client.BAD_REQUEST, response.status_int)
self.assertTrue(response.json['error_message']) self.assertTrue(response.json['error_message'])
@mock.patch.object(notification_utils, '_emit_api_notification') @mock.patch.object(notification_utils, '_emit_api_notification',
@mock.patch.object(timeutils, 'utcnow') autospec=True)
@mock.patch.object(timeutils, 'utcnow', autospec=True)
def test_replace_singular(self, mock_utcnow, mock_notify): def test_replace_singular(self, mock_utcnow, mock_notify):
test_time = datetime.datetime(2000, 1, 1, 0, 0) test_time = datetime.datetime(2000, 1, 1, 0, 0)
@ -633,8 +634,9 @@ class TestPatch(test_api_base.BaseApiTest):
headers=self.headers) headers=self.headers)
self.assertIsNone(result['name']) self.assertIsNone(result['name'])
@mock.patch.object(notification_utils, '_emit_api_notification') @mock.patch.object(notification_utils, '_emit_api_notification',
@mock.patch.object(objects.Allocation, 'save') autospec=True)
@mock.patch.object(objects.Allocation, 'save', autospec=True)
def test_update_error(self, mock_save, mock_notify): def test_update_error(self, mock_save, mock_notify):
mock_save.side_effect = Exception() mock_save.side_effect = Exception()
allocation = obj_utils.create_test_allocation(self.context) allocation = obj_utils.create_test_allocation(self.context)
@ -764,7 +766,8 @@ class TestPost(test_api_base.BaseApiTest):
).mock ).mock
self.mock_get_topic_for_node.return_value = 'node-topic' self.mock_get_topic_for_node.return_value = 'node-topic'
@mock.patch.object(notification_utils, '_emit_api_notification') @mock.patch.object(notification_utils, '_emit_api_notification',
autospec=True)
@mock.patch.object(timeutils, 'utcnow', autospec=True) @mock.patch.object(timeutils, 'utcnow', autospec=True)
def test_create_allocation(self, mock_utcnow, mock_notify): def test_create_allocation(self, mock_utcnow, mock_notify):
adict = apiutils.allocation_post_data() adict = apiutils.allocation_post_data()
@ -836,8 +839,9 @@ class TestPost(test_api_base.BaseApiTest):
self.assertFalse(mock_warn.called) self.assertFalse(mock_warn.called)
self.assertFalse(mock_except.called) self.assertFalse(mock_except.called)
@mock.patch.object(notification_utils, '_emit_api_notification') @mock.patch.object(notification_utils, '_emit_api_notification',
@mock.patch.object(objects.Allocation, 'create') autospec=True)
@mock.patch.object(objects.Allocation, 'create', autospec=True)
def test_create_allocation_error(self, mock_create, mock_notify): def test_create_allocation_error(self, mock_create, mock_notify):
mock_create.side_effect = Exception() mock_create.side_effect = Exception()
adict = apiutils.allocation_post_data() adict = apiutils.allocation_post_data()
@ -1168,7 +1172,7 @@ class TestPost(test_api_base.BaseApiTest):
self.assertTrue(response.json['error_message']) self.assertTrue(response.json['error_message'])
@mock.patch.object(rpcapi.ConductorAPI, 'destroy_allocation') @mock.patch.object(rpcapi.ConductorAPI, 'destroy_allocation', autospec=True)
class TestDelete(test_api_base.BaseApiTest): class TestDelete(test_api_base.BaseApiTest):
headers = {api_base.Version.string: str(api_v1.max_version())} headers = {api_base.Version.string: str(api_v1.max_version())}
@ -1182,7 +1186,8 @@ class TestDelete(test_api_base.BaseApiTest):
fixtures.MockPatchObject(rpcapi.ConductorAPI, 'get_random_topic') fixtures.MockPatchObject(rpcapi.ConductorAPI, 'get_random_topic')
).mock ).mock
@mock.patch.object(notification_utils, '_emit_api_notification') @mock.patch.object(notification_utils, '_emit_api_notification',
autospec=True)
def test_delete_allocation_by_id(self, mock_notify, mock_destroy): def test_delete_allocation_by_id(self, mock_notify, mock_destroy):
self.delete('/allocations/%s' % self.allocation.uuid, self.delete('/allocations/%s' % self.allocation.uuid,
headers=self.headers) headers=self.headers)
@ -1198,7 +1203,8 @@ class TestDelete(test_api_base.BaseApiTest):
node_uuid=self.node.uuid), node_uuid=self.node.uuid),
]) ])
@mock.patch.object(notification_utils, '_emit_api_notification') @mock.patch.object(notification_utils, '_emit_api_notification',
autospec=True)
def test_delete_allocation_node_locked(self, mock_notify, mock_destroy): def test_delete_allocation_node_locked(self, mock_notify, mock_destroy):
self.node.reserve(self.context, 'fake', self.node.uuid) self.node.reserve(self.context, 'fake', self.node.uuid)
mock_destroy.side_effect = exception.NodeLocked(node='fake-node', mock_destroy.side_effect = exception.NodeLocked(node='fake-node',
@ -1248,7 +1254,8 @@ class TestDelete(test_api_base.BaseApiTest):
headers=self.headers) headers=self.headers)
self.assertEqual(http_client.NOT_FOUND, res.status_code) self.assertEqual(http_client.NOT_FOUND, res.status_code)
@mock.patch.object(notification_utils, '_emit_api_notification') @mock.patch.object(notification_utils, '_emit_api_notification',
autospec=True)
def test_delete_allocation_by_node(self, mock_notify, mock_destroy): def test_delete_allocation_by_node(self, mock_notify, mock_destroy):
self.delete('/nodes/%s/allocation' % self.node.uuid, self.delete('/nodes/%s/allocation' % self.node.uuid,
headers=self.headers) headers=self.headers)

11
tox.ini
View File

@ -128,7 +128,16 @@ enable-extensions=H106,H203,H204,H205,H210,H904
per-file-ignores = per-file-ignores =
ironic/cmd/__init__.py:E402 ironic/cmd/__init__.py:E402
ironic/tests/base.py:E402 ironic/tests/base.py:E402
ironic/tests/unit/api/controllers/*:H210 ironic/tests/unit/api/controllers/v1/test_utils.py:H210
ironic/tests/unit/api/controllers/v1/test_volume_target.py:H210
ironic/tests/unit/api/controllers/v1/test_volume_connector.py:H210
ironic/tests/unit/api/controllers/v1/test_driver.py:H210
ironic/tests/unit/api/controllers/v1/test_portgroup.py:H210
ironic/tests/unit/api/controllers/v1/test_chassis.py:H210
ironic/tests/unit/api/controllers/v1/test_node.py:H210
ironic/tests/unit/api/controllers/v1/test_types.py:H210
ironic/tests/unit/api/controllers/v1/test_notification_utils.py:H210
ironic/tests/unit/api/controllers/v1/test_port.py:H210
ironic/tests/unit/drivers/modules/test_console_utils.py:H210 ironic/tests/unit/drivers/modules/test_console_utils.py:H210
[hacking] [hacking]