Merge "network: handle forbidden exception from neutron"

This commit is contained in:
Jenkins 2016-07-28 15:36:16 +00:00 committed by Gerrit Code Review
commit 9d04ed7a83
3 changed files with 22 additions and 2 deletions

View File

@ -73,8 +73,8 @@ def _load_auth_plugin(conf):
class ClientWrapper(clientv20.Client): class ClientWrapper(clientv20.Client):
"""A Neutron client wrapper class. """A Neutron client wrapper class.
Wraps the callable methods, catches Unauthorized from Neutron and Wraps the callable methods, catches Unauthorized,Forbidden from Neutron and
convert it to a 401 for Nova clients. convert it to a 401,403 for Nova clients.
""" """
def __init__(self, base_client, admin): def __init__(self, base_client, admin):
# Expose all attributes from the base_client instance # Expose all attributes from the base_client instance
@ -108,6 +108,8 @@ class ClientWrapper(clientv20.Client):
"valid admin token, please verify Neutron " "valid admin token, please verify Neutron "
"admin credential located in nova.conf")) "admin credential located in nova.conf"))
raise exception.NeutronAdminCredentialConfigurationInvalid() raise exception.NeutronAdminCredentialConfigurationInvalid()
except neutron_client_exc.Forbidden as e:
raise exception.Forbidden(e)
return ret return ret
return wrapper return wrapper

View File

@ -73,6 +73,13 @@ class NetworksJsonTests(api_sample_base.ApiSampleTestBaseV21):
response = self._do_get('os-networks/%s' % uuid) response = self._do_get('os-networks/%s' % uuid)
self.assertEqual(401, response.status_code) self.assertEqual(401, response.status_code)
@mock.patch('nova.network.api.API.create',
side_effect=exception.Forbidden)
def test_network_create_forbidden(self, mock_create):
response = self._do_post("os-networks",
'network-create-req', {})
self.assertEqual(403, response.status_code)
def test_network_create(self): def test_network_create(self):
response = self._do_post("os-networks", response = self._do_post("os-networks",
'network-create-req', {}) 'network-create-req', {})

View File

@ -162,6 +162,17 @@ class TestNeutronClient(test.NoDBTestCase):
exception.NeutronAdminCredentialConfigurationInvalid, exception.NeutronAdminCredentialConfigurationInvalid,
client.list_networks) client.list_networks)
@mock.patch.object(client.Client, "create_port",
side_effect=exceptions.Forbidden())
def test_Forbidden(self, mock_create_port):
my_context = context.RequestContext('userid', uuids.my_tenant,
auth_token='token',
is_admin=False)
client = neutronapi.get_client(my_context)
self.assertRaises(
exception.Forbidden,
client.create_port)
def test_withtoken_context_is_admin(self): def test_withtoken_context_is_admin(self):
self.flags(url='http://anyhost/', group='neutron') self.flags(url='http://anyhost/', group='neutron')
self.flags(timeout=30, group='neutron') self.flags(timeout=30, group='neutron')