summaryrefslogtreecommitdiff
path: root/openstackclient/tests/functional/identity/v3/common.py
diff options
context:
space:
mode:
Diffstat (limited to 'openstackclient/tests/functional/identity/v3/common.py')
-rw-r--r--openstackclient/tests/functional/identity/v3/common.py43
1 files changed, 43 insertions, 0 deletions
diff --git a/openstackclient/tests/functional/identity/v3/common.py b/openstackclient/tests/functional/identity/v3/common.py
index 525a31a2..58468bc7 100644
--- a/openstackclient/tests/functional/identity/v3/common.py
+++ b/openstackclient/tests/functional/identity/v3/common.py
@@ -59,6 +59,10 @@ class IdentityTests(base.TestCase):
REGISTERED_LIMIT_LIST_HEADERS = ['ID', 'Service ID', 'Resource Name',
'Default Limit', 'Description',
'Region ID']
+ LIMIT_FIELDS = ['id', 'project_id', 'service_id', 'resource_name',
+ 'resource_limit', 'description', 'region_id']
+ LIMIT_LIST_HEADERS = ['ID', 'Project ID', 'Service ID', 'Resource Name',
+ 'Resource Limit', 'Description', 'Region ID']
@classmethod
def setUpClass(cls):
@@ -356,3 +360,42 @@ class IdentityTests(base.TestCase):
for k, v in d.iteritems():
if k == key:
return v
+
+ def _create_dummy_limit(self, add_clean_up=True):
+ registered_limit_id = self._create_dummy_registered_limit()
+
+ raw_output = self.openstack(
+ 'registered limit show %s' % registered_limit_id
+ )
+ items = self.parse_show(raw_output)
+ resource_name = self._extract_value_from_items('resource_name', items)
+ service_id = self._extract_value_from_items('service_id', items)
+ resource_limit = 15
+
+ project_name = self._create_dummy_project()
+ raw_output = self.openstack('project show %s' % project_name)
+ items = self.parse_show(raw_output)
+ project_id = self._extract_value_from_items('id', items)
+
+ params = {
+ 'project_id': project_id,
+ 'service_id': service_id,
+ 'resource_name': resource_name,
+ 'resource_limit': resource_limit
+ }
+
+ raw_output = self.openstack(
+ 'limit create'
+ ' --project %(project_id)s'
+ ' --service %(service_id)s'
+ ' --resource-limit %(resource_limit)s'
+ ' %(resource_name)s' % params
+ )
+ items = self.parse_show(raw_output)
+ limit_id = self._extract_value_from_items('id', items)
+
+ if add_clean_up:
+ self.addCleanup(self.openstack, 'limit delete %s' % limit_id)
+
+ self.assert_show_fields(items, self.LIMIT_FIELDS)
+ return limit_id