Merge "Enforce autospec in some api controllers modules"
This commit is contained in:
commit
731f0768c4
@ -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)
|
||||||
|
@ -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
11
tox.ini
@ -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]
|
||||||
|
Loading…
Reference in New Issue
Block a user