Merge "Gracefully handle bad request exception"

This commit is contained in:
Zuul 2024-10-28 13:20:35 +00:00 committed by Gerrit Code Review
commit e8d29df979
3 changed files with 18 additions and 1 deletions

View File

@ -2349,7 +2349,6 @@ class NodesController(rest.RestController):
@pecan.expose() @pecan.expose()
def _lookup(self, ident, *remainder): def _lookup(self, ident, *remainder):
if ident in self._subcontroller_map: if ident in self._subcontroller_map:
pecan.abort(http_client.NOT_FOUND) pecan.abort(http_client.NOT_FOUND)
@ -2357,6 +2356,8 @@ class NodesController(rest.RestController):
ident = args.uuid_or_name('node', ident) ident = args.uuid_or_name('node', ident)
except exception.InvalidParameterValue as e: except exception.InvalidParameterValue as e:
pecan.abort(http_client.BAD_REQUEST, e.args[0]) pecan.abort(http_client.BAD_REQUEST, e.args[0])
except exception.InvalidUuidOrName as e:
pecan.abort(http_client.BAD_REQUEST, e.args[0])
if not remainder: if not remainder:
return return
if ((remainder[0] == 'portgroups' if ((remainder[0] == 'portgroups'

View File

@ -147,6 +147,8 @@ class PortgroupsController(pecan.rest.RestController):
ident = args.uuid_or_name('portgroup', ident) ident = args.uuid_or_name('portgroup', ident)
except exception.InvalidParameterValue as e: except exception.InvalidParameterValue as e:
pecan.abort(http_client.BAD_REQUEST, e.args[0]) pecan.abort(http_client.BAD_REQUEST, e.args[0])
except exception.InvalidUuidOrName as e:
pecan.abort(http_client.BAD_REQUEST, e.args[0])
if not remainder: if not remainder:
return return
subcontroller = self._subcontroller_map.get(remainder[0]) subcontroller = self._subcontroller_map.get(remainder[0])

View File

@ -2581,6 +2581,20 @@ class TestListNodes(test_api_base.BaseApiTest):
mock_vdi.assert_called_once_with(mock.ANY, mock.ANY, mock_vdi.assert_called_once_with(mock.ANY, mock.ANY,
node.uuid, 'test-topic') node.uuid, 'test-topic')
@mock.patch.object(api_utils, 'get_rpc_node', autospec=True)
def test_validate_invalid_uuid_or_name(self, mock_rpc_node):
invalid_ident = '1234~1234~1234'
mock_rpc_node.side_effect = exception.InvalidUuidOrName(
name=invalid_ident)
ret = self.get_json('/nodes/%s' % invalid_ident,
headers={api_base.Version.string: "1.5"},
expect_errors=True)
self.assertEqual(http_client.BAD_REQUEST, ret.status_code)
self.assertIn('Expected a logical name or UUID',
ret.json['error_message'])
@mock.patch.object(rpcapi.ConductorAPI, 'get_indicator_state', @mock.patch.object(rpcapi.ConductorAPI, 'get_indicator_state',
autospec=True) autospec=True)
def test_get_indicator_state(self, mock_gis): def test_get_indicator_state(self, mock_gis):