Changes names of some quota values
Some variables which were actually per-tenant were incorrectly named with a _user. Corrected this confusion by making the old names deprecated and providing new per-tenant names. Closes Bug: #1232969 Change-Id: I541ed990c0cdd40b3805d2e2a166363d9ff2ad04
This commit is contained in:
parent
1cb7dc7792
commit
e6620ff00f
@ -25,8 +25,8 @@
|
|||||||
"trove_can_have_volume":true,
|
"trove_can_have_volume":true,
|
||||||
"trove_main_instance_has_volume": true,
|
"trove_main_instance_has_volume": true,
|
||||||
"trove_max_accepted_volume_size": 25,
|
"trove_max_accepted_volume_size": 25,
|
||||||
"trove_max_instances_per_user": 55,
|
"trove_max_instances_per_tenant": 55,
|
||||||
"trove_max_volumes_per_user": 100,
|
"trove_max_volumes_per_tenant": 100,
|
||||||
"use_reaper":false,
|
"use_reaper":false,
|
||||||
"root_removed_from_instance_api": true,
|
"root_removed_from_instance_api": true,
|
||||||
"root_timestamp_disabled": false,
|
"root_timestamp_disabled": false,
|
||||||
|
@ -104,10 +104,10 @@ block_device_mapping = vdb
|
|||||||
device_path = /dev/vdb
|
device_path = /dev/vdb
|
||||||
# Maximum volume size for an instance
|
# Maximum volume size for an instance
|
||||||
max_accepted_volume_size = 10
|
max_accepted_volume_size = 10
|
||||||
max_instances_per_user = 5
|
max_instances_per_tenant = 5
|
||||||
# Maximum volume capacity (in GB) spanning across all trove volumes per tenant
|
# Maximum volume capacity (in GB) spanning across all trove volumes per tenant
|
||||||
max_volumes_per_user = 100
|
max_volumes_per_tenant = 100
|
||||||
max_backups_per_user = 5
|
max_backups_per_tenant = 5
|
||||||
volume_time_out=30
|
volume_time_out=30
|
||||||
|
|
||||||
# Config options for rate limits
|
# Config options for rate limits
|
||||||
|
@ -71,9 +71,9 @@ nova_volume_service_type = volume
|
|||||||
nova_volume_service_name = Volume Service
|
nova_volume_service_name = Volume Service
|
||||||
device_path = /dev/vdb
|
device_path = /dev/vdb
|
||||||
max_accepted_volume_size = 25
|
max_accepted_volume_size = 25
|
||||||
max_instances_per_user = 55
|
max_instances_per_tenant = 55
|
||||||
max_volumes_per_user = 100
|
max_volumes_per_tenant = 100
|
||||||
max_backups_per_user = 5
|
max_backups_per_tenant = 5
|
||||||
volume_time_out=30
|
volume_time_out=30
|
||||||
|
|
||||||
# Config options for rate limits
|
# Config options for rate limits
|
||||||
|
@ -164,15 +164,19 @@ common_opts = [
|
|||||||
help='Maximum time (in seconds) to wait for a volume format.'),
|
help='Maximum time (in seconds) to wait for a volume format.'),
|
||||||
cfg.StrOpt('mount_options', default='defaults,noatime',
|
cfg.StrOpt('mount_options', default='defaults,noatime',
|
||||||
help='Options to use when mounting a volume.'),
|
help='Options to use when mounting a volume.'),
|
||||||
cfg.IntOpt('max_instances_per_user', default=5,
|
cfg.IntOpt('max_instances_per_tenant',
|
||||||
help='Default maximum number of instances per tenant.'),
|
default=5,
|
||||||
|
help='Default maximum number of instances per tenant.',
|
||||||
|
deprecated_name='max_instances_per_user'),
|
||||||
cfg.IntOpt('max_accepted_volume_size', default=5,
|
cfg.IntOpt('max_accepted_volume_size', default=5,
|
||||||
help='Default maximum volume size (in GB) for an instance.'),
|
help='Default maximum volume size (in GB) for an instance.'),
|
||||||
cfg.IntOpt('max_volumes_per_user', default=20,
|
cfg.IntOpt('max_volumes_per_tenant', default=20,
|
||||||
help='Default maximum volume capacity (in GB) spanning across '
|
help='Default maximum volume capacity (in GB) spanning across '
|
||||||
'all Trove volumes per tenant.'),
|
'all Trove volumes per tenant.',
|
||||||
cfg.IntOpt('max_backups_per_user', default=50,
|
deprecated_name='max_volumes_per_user'),
|
||||||
help='Default maximum number of backups created by a tenant.'),
|
cfg.IntOpt('max_backups_per_tenant', default=50,
|
||||||
|
help='Default maximum number of backups created by a tenant.',
|
||||||
|
deprecated_name='max_backups_per_user'),
|
||||||
cfg.StrOpt('quota_driver', default='trove.quota.quota.DbQuotaDriver',
|
cfg.StrOpt('quota_driver', default='trove.quota.quota.DbQuotaDriver',
|
||||||
help='Default driver to use for quota checks.'),
|
help='Default driver to use for quota checks.'),
|
||||||
cfg.StrOpt('taskmanager_queue', default='taskmanager',
|
cfg.StrOpt('taskmanager_queue', default='taskmanager',
|
||||||
|
@ -332,9 +332,11 @@ class QuotaEngine(object):
|
|||||||
QUOTAS = QuotaEngine()
|
QUOTAS = QuotaEngine()
|
||||||
|
|
||||||
''' Define all kind of resources here '''
|
''' Define all kind of resources here '''
|
||||||
resources = [Resource(Resource.INSTANCES, 'max_instances_per_user'),
|
|
||||||
Resource(Resource.BACKUPS, 'max_backups_per_user'),
|
resources = [Resource(Resource.INSTANCES,
|
||||||
Resource(Resource.VOLUMES, 'max_volumes_per_user')]
|
'max_instances_per_tenant'),
|
||||||
|
Resource(Resource.BACKUPS, 'max_backups_per_tenant'),
|
||||||
|
Resource(Resource.VOLUMES, 'max_volumes_per_tenant')]
|
||||||
|
|
||||||
QUOTAS.register_resources(resources)
|
QUOTAS.register_resources(resources)
|
||||||
|
|
||||||
|
@ -240,8 +240,8 @@ class CreateInstanceQuotaTest(unittest.TestCase):
|
|||||||
self.test_info.dbaas_datastore = CONFIG.dbaas_datastore
|
self.test_info.dbaas_datastore = CONFIG.dbaas_datastore
|
||||||
|
|
||||||
def tearDown(self):
|
def tearDown(self):
|
||||||
quota_dict = {'instances': CONFIG.trove_max_instances_per_user,
|
quota_dict = {'instances': CONFIG.trove_max_instances_per_tenant,
|
||||||
'volumes': CONFIG.trove_max_volumes_per_user}
|
'volumes': CONFIG.trove_max_volumes_per_tenant}
|
||||||
dbaas_admin.quota.update(self.test_info.user.tenant_id,
|
dbaas_admin.quota.update(self.test_info.user.tenant_id,
|
||||||
quota_dict)
|
quota_dict)
|
||||||
|
|
||||||
@ -283,7 +283,7 @@ class CreateInstanceQuotaTest(unittest.TestCase):
|
|||||||
self.test_info.volume = None
|
self.test_info.volume = None
|
||||||
|
|
||||||
if VOLUME_SUPPORT:
|
if VOLUME_SUPPORT:
|
||||||
assert_equal(CONFIG.trove_max_volumes_per_user,
|
assert_equal(CONFIG.trove_max_volumes_per_tenant,
|
||||||
verify_quota['volumes'])
|
verify_quota['volumes'])
|
||||||
self.test_info.volume = {'size':
|
self.test_info.volume = {'size':
|
||||||
CONFIG.get('trove_volume_size', 1)}
|
CONFIG.get('trove_volume_size', 1)}
|
||||||
|
@ -35,9 +35,10 @@ CONF = cfg.CONF
|
|||||||
|
|
||||||
GROUP = "dbaas.api.limits"
|
GROUP = "dbaas.api.limits"
|
||||||
DEFAULT_RATE = CONF.http_get_rate
|
DEFAULT_RATE = CONF.http_get_rate
|
||||||
DEFAULT_MAX_VOLUMES = CONF.max_volumes_per_user
|
|
||||||
DEFAULT_MAX_INSTANCES = CONF.max_instances_per_user
|
DEFAULT_MAX_VOLUMES = CONF.max_volumes_per_tenant
|
||||||
DEFAULT_MAX_BACKUPS = CONF.max_backups_per_user
|
DEFAULT_MAX_INSTANCES = CONF.max_instances_per_tenant
|
||||||
|
DEFAULT_MAX_BACKUPS = CONF.max_backups_per_tenant
|
||||||
|
|
||||||
|
|
||||||
def ensure_limits_are_not_faked(func):
|
def ensure_limits_are_not_faked(func):
|
||||||
|
@ -42,8 +42,9 @@ class QuotasBase(object):
|
|||||||
self.client2 = create_dbaas_client(self.user2)
|
self.client2 = create_dbaas_client(self.user2)
|
||||||
self.mgmt_client = create_client(is_admin=True)
|
self.mgmt_client = create_client(is_admin=True)
|
||||||
''' Orig quotas from config
|
''' Orig quotas from config
|
||||||
"trove_max_instances_per_user": 55,
|
|
||||||
"trove_max_volumes_per_user": 100, '''
|
"trove_max_instances_per_tenant": 55,
|
||||||
|
"trove_max_volumes_per_tenant": 100, '''
|
||||||
self.original_quotas1 = self.mgmt_client.quota.show(self.user1.tenant)
|
self.original_quotas1 = self.mgmt_client.quota.show(self.user1.tenant)
|
||||||
self.original_quotas2 = self.mgmt_client.quota.show(self.user2.tenant)
|
self.original_quotas2 = self.mgmt_client.quota.show(self.user2.tenant)
|
||||||
|
|
||||||
@ -69,7 +70,8 @@ class DefaultQuotasTest(QuotasBase):
|
|||||||
def check_quotas_are_set_to_defaults(self):
|
def check_quotas_are_set_to_defaults(self):
|
||||||
quotas = self.mgmt_client.quota.show(self.user1.tenant)
|
quotas = self.mgmt_client.quota.show(self.user1.tenant)
|
||||||
with Check() as check:
|
with Check() as check:
|
||||||
check.equal(CONFIG.trove_max_instances_per_user,
|
|
||||||
|
check.equal(CONFIG.trove_max_instances_per_tenant,
|
||||||
quotas["instances"])
|
quotas["instances"])
|
||||||
check.equal(CONFIG.trove_max_volumes_per_user,
|
check.equal(CONFIG.trove_max_volumes_per_user,
|
||||||
quotas["volumes"])
|
quotas["volumes"])
|
||||||
@ -103,7 +105,7 @@ class ChangeInstancesQuota(QuotasBase):
|
|||||||
quotas = self.mgmt_client.quota.show(self.user1.tenant)
|
quotas = self.mgmt_client.quota.show(self.user1.tenant)
|
||||||
with Check() as check:
|
with Check() as check:
|
||||||
check.equal(0, quotas["instances"])
|
check.equal(0, quotas["instances"])
|
||||||
check.equal(CONFIG.trove_max_volumes_per_user,
|
check.equal(CONFIG.trove_max_volumes_per_tenant,
|
||||||
quotas["volumes"])
|
quotas["volumes"])
|
||||||
asserts.assert_equal(len(quotas), 2)
|
asserts.assert_equal(len(quotas), 2)
|
||||||
|
|
||||||
@ -154,7 +156,8 @@ class ChangeVolumesQuota(QuotasBase):
|
|||||||
def verify_correct_update(self):
|
def verify_correct_update(self):
|
||||||
quotas = self.mgmt_client.quota.show(self.user1.tenant)
|
quotas = self.mgmt_client.quota.show(self.user1.tenant)
|
||||||
with Check() as check:
|
with Check() as check:
|
||||||
check.equal(CONFIG.trove_max_instances_per_user,
|
|
||||||
|
check.equal(CONFIG.trove_max_instances_per_tenant,
|
||||||
quotas["instances"])
|
quotas["instances"])
|
||||||
check.equal(0, quotas["volumes"])
|
check.equal(0, quotas["volumes"])
|
||||||
asserts.assert_equal(len(quotas), 2)
|
asserts.assert_equal(len(quotas), 2)
|
||||||
|
@ -88,7 +88,8 @@ class TestConfig(object):
|
|||||||
"report_directory": os.environ.get("REPORT_DIRECTORY", None),
|
"report_directory": os.environ.get("REPORT_DIRECTORY", None),
|
||||||
"trove_volume_support": True,
|
"trove_volume_support": True,
|
||||||
"trove_volume_size": 1,
|
"trove_volume_size": 1,
|
||||||
"trove_max_volumes_per_user": 100,
|
"trove_max_volumes_per_tenant": 100,
|
||||||
|
"trove_max_instances_per_tenant": 55,
|
||||||
"usage_endpoint": USAGE_ENDPOINT,
|
"usage_endpoint": USAGE_ENDPOINT,
|
||||||
"root_on_create": False,
|
"root_on_create": False,
|
||||||
"mysql": {
|
"mysql": {
|
||||||
|
@ -33,8 +33,10 @@ Unit tests for the classes and functions in DbQuotaDriver.py.
|
|||||||
|
|
||||||
CONF = cfg.CONF
|
CONF = cfg.CONF
|
||||||
resources = {
|
resources = {
|
||||||
Resource.INSTANCES: Resource(Resource.INSTANCES, 'max_instances_per_user'),
|
|
||||||
Resource.VOLUMES: Resource(Resource.VOLUMES, 'max_volumes_per_user')
|
Resource.INSTANCES: Resource(Resource.INSTANCES,
|
||||||
|
'max_instances_per_tenant'),
|
||||||
|
Resource.VOLUMES: Resource(Resource.VOLUMES, 'max_volumes_per_tenant')
|
||||||
}
|
}
|
||||||
|
|
||||||
FAKE_TENANT1 = "123456"
|
FAKE_TENANT1 = "123456"
|
||||||
@ -173,9 +175,10 @@ class DbQuotaDriverTest(trove_testtools.TestCase):
|
|||||||
|
|
||||||
def test_get_defaults(self):
|
def test_get_defaults(self):
|
||||||
defaults = self.driver.get_defaults(resources)
|
defaults = self.driver.get_defaults(resources)
|
||||||
self.assertEqual(CONF.max_instances_per_user,
|
|
||||||
|
self.assertEqual(CONF.max_instances_per_tenant,
|
||||||
defaults[Resource.INSTANCES])
|
defaults[Resource.INSTANCES])
|
||||||
self.assertEqual(CONF.max_volumes_per_user,
|
self.assertEqual(CONF.max_volumes_per_tenant,
|
||||||
defaults[Resource.VOLUMES])
|
defaults[Resource.VOLUMES])
|
||||||
|
|
||||||
def test_get_quota_by_tenant(self):
|
def test_get_quota_by_tenant(self):
|
||||||
@ -202,7 +205,7 @@ class DbQuotaDriverTest(trove_testtools.TestCase):
|
|||||||
|
|
||||||
self.assertEqual(FAKE_TENANT1, quota.tenant_id)
|
self.assertEqual(FAKE_TENANT1, quota.tenant_id)
|
||||||
self.assertEqual(Resource.VOLUMES, quota.resource)
|
self.assertEqual(Resource.VOLUMES, quota.resource)
|
||||||
self.assertEqual(CONF.max_volumes_per_user, quota.hard_limit)
|
self.assertEqual(CONF.max_volumes_per_tenant, quota.hard_limit)
|
||||||
|
|
||||||
def test_get_all_quotas_by_tenant(self):
|
def test_get_all_quotas_by_tenant(self):
|
||||||
|
|
||||||
@ -236,11 +239,12 @@ class DbQuotaDriverTest(trove_testtools.TestCase):
|
|||||||
self.assertEqual(FAKE_TENANT1, quotas[Resource.INSTANCES].tenant_id)
|
self.assertEqual(FAKE_TENANT1, quotas[Resource.INSTANCES].tenant_id)
|
||||||
self.assertEqual(Resource.INSTANCES,
|
self.assertEqual(Resource.INSTANCES,
|
||||||
quotas[Resource.INSTANCES].resource)
|
quotas[Resource.INSTANCES].resource)
|
||||||
self.assertEqual(CONF.max_instances_per_user,
|
|
||||||
|
self.assertEqual(CONF.max_instances_per_tenant,
|
||||||
quotas[Resource.INSTANCES].hard_limit)
|
quotas[Resource.INSTANCES].hard_limit)
|
||||||
self.assertEqual(FAKE_TENANT1, quotas[Resource.VOLUMES].tenant_id)
|
self.assertEqual(FAKE_TENANT1, quotas[Resource.VOLUMES].tenant_id)
|
||||||
self.assertEqual(Resource.VOLUMES, quotas[Resource.VOLUMES].resource)
|
self.assertEqual(Resource.VOLUMES, quotas[Resource.VOLUMES].resource)
|
||||||
self.assertEqual(CONF.max_volumes_per_user,
|
self.assertEqual(CONF.max_volumes_per_tenant,
|
||||||
quotas[Resource.VOLUMES].hard_limit)
|
quotas[Resource.VOLUMES].hard_limit)
|
||||||
|
|
||||||
def test_get_all_quotas_by_tenant_with_one_default(self):
|
def test_get_all_quotas_by_tenant_with_one_default(self):
|
||||||
@ -260,7 +264,7 @@ class DbQuotaDriverTest(trove_testtools.TestCase):
|
|||||||
self.assertEqual(22, quotas[Resource.INSTANCES].hard_limit)
|
self.assertEqual(22, quotas[Resource.INSTANCES].hard_limit)
|
||||||
self.assertEqual(FAKE_TENANT1, quotas[Resource.VOLUMES].tenant_id)
|
self.assertEqual(FAKE_TENANT1, quotas[Resource.VOLUMES].tenant_id)
|
||||||
self.assertEqual(Resource.VOLUMES, quotas[Resource.VOLUMES].resource)
|
self.assertEqual(Resource.VOLUMES, quotas[Resource.VOLUMES].resource)
|
||||||
self.assertEqual(CONF.max_volumes_per_user,
|
self.assertEqual(CONF.max_volumes_per_tenant,
|
||||||
quotas[Resource.VOLUMES].hard_limit)
|
quotas[Resource.VOLUMES].hard_limit)
|
||||||
|
|
||||||
def test_get_quota_usage_by_tenant(self):
|
def test_get_quota_usage_by_tenant(self):
|
||||||
@ -434,7 +438,7 @@ class DbQuotaDriverTest(trove_testtools.TestCase):
|
|||||||
self.mock_quota_result.all = Mock(return_value=[])
|
self.mock_quota_result.all = Mock(return_value=[])
|
||||||
self.mock_usage_result.all = Mock(return_value=FAKE_QUOTAS)
|
self.mock_usage_result.all = Mock(return_value=FAKE_QUOTAS)
|
||||||
|
|
||||||
delta = {'instances': 1, 'volumes': CONF.max_volumes_per_user + 1}
|
delta = {'instances': 1, 'volumes': CONF.max_volumes_per_tenant + 1}
|
||||||
self.assertRaises(exception.QuotaExceeded,
|
self.assertRaises(exception.QuotaExceeded,
|
||||||
self.driver.reserve,
|
self.driver.reserve,
|
||||||
FAKE_TENANT1,
|
FAKE_TENANT1,
|
||||||
|
Loading…
Reference in New Issue
Block a user