Fix quota tests for static credentials

when running tempest tests with static set of credentials Tempest does
not create new tenants on the fly, and those pre-defined tenants may alreay
have configured quotas that are different from default project ones.

For quota tests to reliaby pass we need to store the original quotas in the
beginning of the test and update to them in the cleanUp phase instead
of deleting them (which resets them to the default ones).

Change-Id: Ia1de916a97fee81148976a5b9cb134e012af8e0c
Closes-Bug: #1800470
This commit is contained in:
Pavlo Shchelokovskyy 2018-10-25 19:03:46 +03:00
parent 28b850fa8b
commit 8ed3b51a61
2 changed files with 32 additions and 9 deletions

View File

@ -36,6 +36,12 @@ class QuotasAdminTest(BaseQuotasTest):
credentials = ["admin"] credentials = ["admin"]
def setUp(self):
super(QuotasAdminTest, self).setUp()
_, original_quotas = self.admin_client.show_quotas()
self.addCleanup(self.admin_client.update_quotas,
**original_quotas['quota'])
@classmethod @classmethod
def setup_credentials(cls): def setup_credentials(cls):
# Do not create network resources for these test. # Do not create network resources for these test.

View File

@ -52,8 +52,22 @@ class QuotasV2Test(base.BaseDnsV2Test):
cls.admin_client = cls.os_admin.quotas_client cls.admin_client = cls.os_admin.quotas_client
cls.alt_client = cls.os_alt.quotas_client cls.alt_client = cls.os_alt.quotas_client
def _store_quotas(self, project_id=None, cleanup=True):
"""Remember current quotas and reset them after the test"""
params = {}
if project_id:
params['project_id'] = project_id
params['headers'] = {'X-Auth-All-Projects': True}
_r, original_quotas = self.admin_client.show_quotas(**params)
params.update(original_quotas)
if cleanup:
self.addCleanup(self.admin_client.update_quotas, **params)
return original_quotas
@decorators.idempotent_id('1dac991a-9e2e-452c-a47a-26ac37381ec5') @decorators.idempotent_id('1dac991a-9e2e-452c-a47a-26ac37381ec5')
def test_show_quotas(self): def test_show_quotas(self):
self._store_quotas()
LOG.info("Updating quotas") LOG.info("Updating quotas")
quotas = dns_data_utils.rand_quotas() quotas = dns_data_utils.rand_quotas()
_, body = self.admin_client.update_quotas(**quotas) _, body = self.admin_client.update_quotas(**quotas)
@ -67,6 +81,7 @@ class QuotasV2Test(base.BaseDnsV2Test):
@decorators.idempotent_id('0448b089-5803-4ce3-8a6c-5c15ff75a2cc') @decorators.idempotent_id('0448b089-5803-4ce3-8a6c-5c15ff75a2cc')
def test_delete_quotas(self): def test_delete_quotas(self):
self._store_quotas()
LOG.info("Deleting quotas") LOG.info("Deleting quotas")
_, body = self.admin_client.delete_quotas() _, body = self.admin_client.delete_quotas()
@ -75,10 +90,10 @@ class QuotasV2Test(base.BaseDnsV2Test):
@decorators.idempotent_id('76d24c87-1b39-4e19-947c-c08e1380dc61') @decorators.idempotent_id('76d24c87-1b39-4e19-947c-c08e1380dc61')
def test_update_quotas(self): def test_update_quotas(self):
self._store_quotas()
LOG.info("Updating quotas") LOG.info("Updating quotas")
quotas = dns_data_utils.rand_quotas() quotas = dns_data_utils.rand_quotas()
_, body = self.admin_client.update_quotas(**quotas) _, body = self.admin_client.update_quotas(**quotas)
self.addCleanup(self.admin_client.delete_quotas)
LOG.info("Ensuring the response has all quota types") LOG.info("Ensuring the response has all quota types")
self.assertExpected(quotas, body, []) self.assertExpected(quotas, body, [])
@ -87,6 +102,7 @@ class QuotasV2Test(base.BaseDnsV2Test):
def test_update_quotas_other_project(self): def test_update_quotas_other_project(self):
project_id = self.quotas_client.tenant_id project_id = self.quotas_client.tenant_id
self._store_quotas(project_id=project_id)
LOG.info("Updating quotas for %s ", project_id) LOG.info("Updating quotas for %s ", project_id)
@ -95,7 +111,6 @@ class QuotasV2Test(base.BaseDnsV2Test):
request['project_id'] = project_id request['project_id'] = project_id
request['headers'] = {'X-Auth-All-Projects': True} request['headers'] = {'X-Auth-All-Projects': True}
_, body = self.admin_client.update_quotas(**request) _, body = self.admin_client.update_quotas(**request)
self.addCleanup(self.admin_client.delete_quotas, project_id=project_id)
LOG.info("Ensuring the response has all quota types") LOG.info("Ensuring the response has all quota types")
self.assertExpected(quotas, body, []) self.assertExpected(quotas, body, [])
@ -109,8 +124,13 @@ class QuotasV2Test(base.BaseDnsV2Test):
LOG.info("Using 'alt' project id to set quotas on.") LOG.info("Using 'alt' project id to set quotas on.")
project_id = self.alt_client.tenant_id project_id = self.alt_client.tenant_id
self._store_quotas(project_id=project_id)
_, original_quotas = self.admin_client.show_quotas( LOG.info("Resetting quotas to default for %s ", project_id)
self.admin_client.delete_quotas(
project_id=project_id,
headers={'X-Auth-All-Projects': True})
_, default_quotas = self.admin_client.show_quotas(
project_id=project_id, headers={'X-Auth-All-Projects': True}) project_id=project_id, headers={'X-Auth-All-Projects': True})
LOG.info("Updating quotas for %s ", project_id) LOG.info("Updating quotas for %s ", project_id)
@ -120,7 +140,6 @@ class QuotasV2Test(base.BaseDnsV2Test):
request['project_id'] = project_id request['project_id'] = project_id
request['headers'] = {'X-Auth-All-Projects': True} request['headers'] = {'X-Auth-All-Projects': True}
_, body = self.admin_client.update_quotas(**request) _, body = self.admin_client.update_quotas(**request)
self.addCleanup(self.admin_client.delete_quotas, project_id=project_id)
self.admin_client.delete_quotas( self.admin_client.delete_quotas(
project_id=project_id, project_id=project_id,
@ -129,7 +148,7 @@ class QuotasV2Test(base.BaseDnsV2Test):
_, final_quotas = self.admin_client.show_quotas( _, final_quotas = self.admin_client.show_quotas(
project_id=project_id, headers={'X-Auth-All-Projects': True}) project_id=project_id, headers={'X-Auth-All-Projects': True})
self.assertExpected(original_quotas, final_quotas, []) self.assertExpected(default_quotas, final_quotas, [])
@decorators.idempotent_id('9b09b3e2-7e88-4569-bce3-9be2f7ac70c4') @decorators.idempotent_id('9b09b3e2-7e88-4569-bce3-9be2f7ac70c4')
def test_update_quotas_invalid_project(self): def test_update_quotas_invalid_project(self):
@ -139,19 +158,17 @@ class QuotasV2Test(base.BaseDnsV2Test):
"is not being verified.") "is not being verified.")
project_id = 'project-that-does-not-exist' project_id = 'project-that-does-not-exist'
original_quotas = self._store_quotas(project_id=project_id,
cleanup=False)
LOG.info("Updating quotas for non-existing %s ", project_id) LOG.info("Updating quotas for non-existing %s ", project_id)
_, original_quotas = self.admin_client.show_quotas(
project_id=project_id, headers={'X-Auth-All-Projects': True})
quotas = dns_data_utils.rand_quotas() quotas = dns_data_utils.rand_quotas()
request = quotas.copy() request = quotas.copy()
request['project_id'] = project_id request['project_id'] = project_id
request['headers'] = {'X-Auth-All-Projects': True} request['headers'] = {'X-Auth-All-Projects': True}
with self.assertRaisesDns(lib_exc.BadRequest, 'invalid_project', 400): with self.assertRaisesDns(lib_exc.BadRequest, 'invalid_project', 400):
self.admin_client.update_quotas(**request) self.admin_client.update_quotas(**request)
self.addCleanup(self.admin_client.delete_quotas, project_id=project_id)
_, client_body = self.quotas_client.show_quotas() _, client_body = self.quotas_client.show_quotas()