Merge "Raise QuotaResourceUnknown in the quota engine"

This commit is contained in:
Jenkins 2015-03-11 23:59:21 +00:00 committed by Gerrit Code Review
commit bed4d80b7e
4 changed files with 33 additions and 57 deletions

View File

@ -112,7 +112,7 @@ class DbQuotaDriver(object):
limit=limit) limit=limit)
context.session.add(tenant_quota) context.session.add(tenant_quota)
def _get_quotas(self, context, tenant_id, resources, keys): def _get_quotas(self, context, tenant_id, resources):
"""Retrieves the quotas for specific resources. """Retrieves the quotas for specific resources.
A helper method which retrieves the quotas for the specific A helper method which retrieves the quotas for the specific
@ -122,21 +122,10 @@ class DbQuotaDriver(object):
:param context: The request context, for access checks. :param context: The request context, for access checks.
:param tenant_id: the tenant_id to check quota. :param tenant_id: the tenant_id to check quota.
:param resources: A dictionary of the registered resources. :param resources: A dictionary of the registered resources.
:param keys: A list of the desired quotas to retrieve.
""" """
desired = set(keys)
sub_resources = dict((k, v) for k, v in resources.items()
if k in desired)
# Make sure we accounted for all of them...
if len(keys) != len(sub_resources):
unknown = desired - set(sub_resources.keys())
raise exceptions.QuotaResourceUnknown(unknown=sorted(unknown))
# Grab and return the quotas (without usages) # Grab and return the quotas (without usages)
quotas = DbQuotaDriver.get_tenant_quotas( quotas = DbQuotaDriver.get_tenant_quotas(
context, sub_resources, tenant_id) context, resources, tenant_id)
return dict((k, v) for k, v in quotas.items()) return dict((k, v) for k, v in quotas.items())
@ -147,10 +136,6 @@ class DbQuotaDriver(object):
synchronization function--this method checks that a set of synchronization function--this method checks that a set of
proposed values are permitted by the limit restriction. proposed values are permitted by the limit restriction.
This method will raise a QuotaResourceUnknown exception if a
given resource is unknown or if it is not a simple limit
resource.
If any of the proposed values is over the defined quota, an If any of the proposed values is over the defined quota, an
OverQuota exception will be raised with the sorted list of the OverQuota exception will be raised with the sorted list of the
resources which are too high. Otherwise, the method returns resources which are too high. Otherwise, the method returns
@ -169,7 +154,7 @@ class DbQuotaDriver(object):
raise exceptions.InvalidQuotaValue(unders=sorted(unders)) raise exceptions.InvalidQuotaValue(unders=sorted(unders))
# Get the applicable quotas # Get the applicable quotas
quotas = self._get_quotas(context, tenant_id, resources, values.keys()) quotas = self._get_quotas(context, tenant_id, resources)
# Check the quotas and construct a list of the resources that # Check the quotas and construct a list of the resources that
# would be put over limit by the desired values # would be put over limit by the desired values

View File

@ -66,7 +66,7 @@ class ConfDriver(object):
in neutron.conf. in neutron.conf.
""" """
def _get_quotas(self, context, resources, keys): def _get_quotas(self, context, resources):
"""Get quotas. """Get quotas.
A helper method which retrieves the quotas for the specific A helper method which retrieves the quotas for the specific
@ -75,20 +75,10 @@ class ConfDriver(object):
:param context: The request context, for access checks. :param context: The request context, for access checks.
:param resources: A dictionary of the registered resources. :param resources: A dictionary of the registered resources.
:param keys: A list of the desired quotas to retrieve.
""" """
# Filter resources
desired = set(keys)
sub_resources = dict((k, v) for k, v in resources.items()
if k in desired)
# Make sure we accounted for all of them...
if len(keys) != len(sub_resources):
unknown = desired - set(sub_resources.keys())
raise exceptions.QuotaResourceUnknown(unknown=sorted(unknown))
quotas = {} quotas = {}
for resource in sub_resources.values(): for resource in resources.values():
quotas[resource.name] = resource.default quotas[resource.name] = resource.default
return quotas return quotas
@ -100,10 +90,6 @@ class ConfDriver(object):
synchronization function--this method checks that a set of synchronization function--this method checks that a set of
proposed values are permitted by the limit restriction. proposed values are permitted by the limit restriction.
This method will raise a QuotaResourceUnknown exception if a
given resource is unknown or if it is not a simple limit
resource.
If any of the proposed values is over the defined quota, an If any of the proposed values is over the defined quota, an
OverQuota exception will be raised with the sorted list of the OverQuota exception will be raised with the sorted list of the
resources which are too high. Otherwise, the method returns resources which are too high. Otherwise, the method returns
@ -115,14 +101,13 @@ class ConfDriver(object):
:param values: A dictionary of the values to check against the :param values: A dictionary of the values to check against the
quota. quota.
""" """
# Ensure no value is less than zero # Ensure no value is less than zero
unders = [key for key, val in values.items() if val < 0] unders = [key for key, val in values.items() if val < 0]
if unders: if unders:
raise exceptions.InvalidQuotaValue(unders=sorted(unders)) raise exceptions.InvalidQuotaValue(unders=sorted(unders))
# Get the applicable quotas # Get the applicable quotas
quotas = self._get_quotas(context, resources, values.keys()) quotas = self._get_quotas(context, resources)
# Check the quotas and construct a list of the resources that # Check the quotas and construct a list of the resources that
# would be put over limit by the desired values # would be put over limit by the desired values
@ -284,16 +269,27 @@ class QuotaEngine(object):
the proposed value. the proposed value.
This method will raise a QuotaResourceUnknown exception if a This method will raise a QuotaResourceUnknown exception if a
given resource is unknown or if it is not a simple limit given resource is unknown or if it is not a countable resource.
resource.
If any of the proposed values is over the defined quota, an If any of the proposed values exceeds the respective quota defined
OverQuota exception will be raised with the sorted list of the for the tenant, an OverQuota exception will be raised.
resources which are too high. Otherwise, the method returns The exception will include a sorted list with the resources
nothing. which exceed the quota limit. Otherwise, the method returns nothing.
:param context: The request context, for access checks. :param context: Request context
:param tenant_id: Tenant for which the quota limit is being checked
:param values: Dict specifying requested deltas for each resource
""" """
# Verify that resources are managed by the quota engine
requested_resources = set(values.keys())
managed_resources = set([res for res in self._resources.keys()
if res in requested_resources])
# Make sure we accounted for all of them...
unknown_resources = requested_resources - managed_resources
if unknown_resources:
raise exceptions.QuotaResourceUnknown(
unknown=sorted(unknown_resources))
return self.get_driver().limit_check(context, tenant_id, return self.get_driver().limit_check(context, tenant_id,
self._resources, values) self._resources, values)

View File

@ -132,15 +132,3 @@ class TestDbQuotaDriver(testlib_api.SqlTestCase):
self.assertRaises(exceptions.InvalidQuotaValue, self.assertRaises(exceptions.InvalidQuotaValue,
self.plugin.limit_check, context.get_admin_context(), self.plugin.limit_check, context.get_admin_context(),
PROJECT, resources, values) PROJECT, resources, values)
def test_limit_check_wrong_values_size(self):
resource_1 = 'res_test_1'
resource_2 = 'res_test_2'
resources = {resource_1: TestResource(resource_1, 2)}
values = {resource_1: 1, resource_2: 1}
self.plugin.update_quota_limit(self.context, PROJECT, resource_1, 2)
self.assertRaises(exceptions.QuotaResourceUnknown,
self.plugin.limit_check, context.get_admin_context(),
PROJECT, resources, values)

View File

@ -302,6 +302,14 @@ class QuotaExtensionDbTestCase(QuotaExtensionTestCase):
tenant_id, tenant_id,
network=-2) network=-2)
def test_quotas_limit_check_with_not_registered_resource_fails(self):
tenant_id = 'tenant_id1'
self.assertRaises(exceptions.QuotaResourceUnknown,
quota.QUOTAS.limit_check,
context.get_admin_context(load_admin_roles=False),
tenant_id,
foobar=1)
def test_quotas_get_tenant_from_request_context(self): def test_quotas_get_tenant_from_request_context(self):
tenant_id = 'tenant_id1' tenant_id = 'tenant_id1'
env = {'neutron.context': context.Context('', tenant_id, env = {'neutron.context': context.Context('', tenant_id,
@ -393,8 +401,7 @@ class TestDbQuotaDriver(base.BaseTestCase):
quotas = driver._get_quotas(ctx, quotas = driver._get_quotas(ctx,
target_tenant, target_tenant,
default_quotas, default_quotas)
['network'])
self.assertEqual(quotas, foo_quotas) self.assertEqual(quotas, foo_quotas)
get_tenant_quotas.assert_called_once_with(ctx, get_tenant_quotas.assert_called_once_with(ctx,