 aed521d426
			
		
	
	aed521d426
	
	
	
		
			
			Black used with the '-l 79 -S' flags. A future change will ignore this commit in git-blame history by adding a 'git-blame-ignore-revs' file. Change-Id: I2eeade1ce6653be8e9179ecc40105182c5ff5f16 Signed-off-by: Stephen Finucane <sfinucan@redhat.com>
		
			
				
	
	
		
			521 lines
		
	
	
		
			17 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			521 lines
		
	
	
		
			17 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| #    Licensed under the Apache License, Version 2.0 (the "License"); you may
 | |
| #    not use this file except in compliance with the License. You may obtain
 | |
| #    a copy of the License at
 | |
| #
 | |
| #         http://www.apache.org/licenses/LICENSE-2.0
 | |
| #
 | |
| #    Unless required by applicable law or agreed to in writing, software
 | |
| #    distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
 | |
| #    WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
 | |
| #    License for the specific language governing permissions and limitations
 | |
| #    under the License.
 | |
| 
 | |
| import os
 | |
| 
 | |
| import fixtures
 | |
| from tempest.lib.common.utils import data_utils
 | |
| 
 | |
| from openstackclient.tests.functional import base
 | |
| 
 | |
| 
 | |
| BASIC_LIST_HEADERS = ['ID', 'Name']
 | |
| SYSTEM_CLOUD = os.environ.get('OS_SYSTEM_CLOUD', 'devstack-system-admin')
 | |
| 
 | |
| 
 | |
| class IdentityTests(base.TestCase):
 | |
|     """Functional tests for Identity commands."""
 | |
| 
 | |
|     DOMAIN_FIELDS = ['description', 'enabled', 'id', 'name']
 | |
|     GROUP_FIELDS = ['description', 'domain_id', 'id', 'name']
 | |
|     TOKEN_FIELDS = ['expires', 'id', 'project_id', 'user_id']
 | |
|     USER_FIELDS = [
 | |
|         'email',
 | |
|         'enabled',
 | |
|         'id',
 | |
|         'name',
 | |
|         'name',
 | |
|         'domain_id',
 | |
|         'default_project_id',
 | |
|         'description',
 | |
|         'password_expires_at',
 | |
|     ]
 | |
|     PROJECT_FIELDS = [
 | |
|         'description',
 | |
|         'id',
 | |
|         'domain_id',
 | |
|         'is_domain',
 | |
|         'enabled',
 | |
|         'name',
 | |
|         'parent_id',
 | |
|     ]
 | |
|     ROLE_FIELDS = ['id', 'name', 'domain_id', 'description']
 | |
|     SERVICE_FIELDS = ['id', 'enabled', 'name', 'type', 'description']
 | |
|     REGION_FIELDS = ['description', 'enabled', 'parent_region', 'region']
 | |
|     ENDPOINT_FIELDS = [
 | |
|         'id',
 | |
|         'region',
 | |
|         'region_id',
 | |
|         'service_id',
 | |
|         'service_name',
 | |
|         'service_type',
 | |
|         'enabled',
 | |
|         'interface',
 | |
|         'url',
 | |
|     ]
 | |
| 
 | |
|     REGION_LIST_HEADERS = ['Region', 'Parent Region', 'Description']
 | |
|     ENDPOINT_LIST_HEADERS = [
 | |
|         'ID',
 | |
|         'Region',
 | |
|         'Service Name',
 | |
|         'Service Type',
 | |
|         'Enabled',
 | |
|         'Interface',
 | |
|         'URL',
 | |
|     ]
 | |
|     ENDPOINT_LIST_PROJECT_HEADERS = ['ID', 'Name']
 | |
| 
 | |
|     IDENTITY_PROVIDER_FIELDS = [
 | |
|         'description',
 | |
|         'enabled',
 | |
|         'id',
 | |
|         'remote_ids',
 | |
|         'domain_id',
 | |
|     ]
 | |
|     IDENTITY_PROVIDER_LIST_HEADERS = ['ID', 'Enabled', 'Description']
 | |
| 
 | |
|     SERVICE_PROVIDER_FIELDS = [
 | |
|         'auth_url',
 | |
|         'description',
 | |
|         'enabled',
 | |
|         'id',
 | |
|         'relay_state_prefix',
 | |
|         'sp_url',
 | |
|     ]
 | |
|     SERVICE_PROVIDER_LIST_HEADERS = [
 | |
|         'ID',
 | |
|         'Enabled',
 | |
|         'Description',
 | |
|         'Auth URL',
 | |
|     ]
 | |
|     IMPLIED_ROLE_LIST_HEADERS = [
 | |
|         'Prior Role ID',
 | |
|         'Prior Role Name',
 | |
|         'Implied Role ID',
 | |
|         'Implied Role Name',
 | |
|     ]
 | |
|     REGISTERED_LIMIT_FIELDS = [
 | |
|         'id',
 | |
|         'service_id',
 | |
|         'resource_name',
 | |
|         'default_limit',
 | |
|         'description',
 | |
|         'region_id',
 | |
|     ]
 | |
|     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):
 | |
|         super(IdentityTests, cls).setUpClass()
 | |
|         # create dummy domain
 | |
|         cls.domain_name = data_utils.rand_name('TestDomain')
 | |
|         cls.domain_description = data_utils.rand_name('description')
 | |
|         cls.openstack(
 | |
|             '--os-identity-api-version 3 '
 | |
|             'domain create '
 | |
|             '--description %(description)s '
 | |
|             '--enable '
 | |
|             '%(name)s'
 | |
|             % {'description': cls.domain_description, 'name': cls.domain_name}
 | |
|         )
 | |
| 
 | |
|         # create dummy project
 | |
|         cls.project_name = data_utils.rand_name('TestProject')
 | |
|         cls.project_description = data_utils.rand_name('description')
 | |
|         cls.openstack(
 | |
|             '--os-identity-api-version 3 '
 | |
|             'project create '
 | |
|             '--domain %(domain)s '
 | |
|             '--description %(description)s '
 | |
|             '--enable '
 | |
|             '%(name)s'
 | |
|             % {
 | |
|                 'domain': cls.domain_name,
 | |
|                 'description': cls.project_description,
 | |
|                 'name': cls.project_name,
 | |
|             }
 | |
|         )
 | |
| 
 | |
|     @classmethod
 | |
|     def tearDownClass(cls):
 | |
|         try:
 | |
|             # delete dummy project
 | |
|             cls.openstack(
 | |
|                 '--os-identity-api-version 3 '
 | |
|                 'project delete %s' % cls.project_name
 | |
|             )
 | |
|             # disable and delete dummy domain
 | |
|             cls.openstack(
 | |
|                 '--os-identity-api-version 3 '
 | |
|                 'domain set --disable %s' % cls.domain_name
 | |
|             )
 | |
|             cls.openstack(
 | |
|                 '--os-identity-api-version 3 '
 | |
|                 'domain delete %s' % cls.domain_name
 | |
|             )
 | |
|         finally:
 | |
|             super(IdentityTests, cls).tearDownClass()
 | |
| 
 | |
|     def setUp(self):
 | |
|         super(IdentityTests, self).setUp()
 | |
|         # prepare v3 env
 | |
|         ver_fixture = fixtures.EnvironmentVariable(
 | |
|             'OS_IDENTITY_API_VERSION', '3'
 | |
|         )
 | |
|         self.useFixture(ver_fixture)
 | |
|         auth_url = os.environ.get('OS_AUTH_URL')
 | |
|         if auth_url:
 | |
|             auth_url_fixture = fixtures.EnvironmentVariable(
 | |
|                 'OS_AUTH_URL', auth_url.replace('v2.0', 'v3')
 | |
|             )
 | |
|             self.useFixture(auth_url_fixture)
 | |
| 
 | |
|     def _create_dummy_user(self, add_clean_up=True):
 | |
|         username = data_utils.rand_name('TestUser')
 | |
|         password = data_utils.rand_name('password')
 | |
|         email = data_utils.rand_name() + '@example.com'
 | |
|         description = data_utils.rand_name('description')
 | |
|         raw_output = self.openstack(
 | |
|             'user create '
 | |
|             '--domain %(domain)s '
 | |
|             '--project %(project)s '
 | |
|             '--project-domain %(project_domain)s '
 | |
|             '--password %(password)s '
 | |
|             '--email %(email)s '
 | |
|             '--description %(description)s '
 | |
|             '--enable '
 | |
|             '%(name)s'
 | |
|             % {
 | |
|                 'domain': self.domain_name,
 | |
|                 'project': self.project_name,
 | |
|                 'project_domain': self.domain_name,
 | |
|                 'email': email,
 | |
|                 'password': password,
 | |
|                 'description': description,
 | |
|                 'name': username,
 | |
|             }
 | |
|         )
 | |
|         if add_clean_up:
 | |
|             self.addCleanup(
 | |
|                 self.openstack,
 | |
|                 'user delete %s' % self.parse_show_as_object(raw_output)['id'],
 | |
|             )
 | |
|         items = self.parse_show(raw_output)
 | |
|         self.assert_show_fields(items, self.USER_FIELDS)
 | |
|         return username
 | |
| 
 | |
|     def _create_dummy_role(self, add_clean_up=True):
 | |
|         role_name = data_utils.rand_name('TestRole')
 | |
|         raw_output = self.openstack('role create %s' % role_name)
 | |
|         role = self.parse_show_as_object(raw_output)
 | |
|         if add_clean_up:
 | |
|             self.addCleanup(self.openstack, 'role delete %s' % role['id'])
 | |
|         items = self.parse_show(raw_output)
 | |
|         self.assert_show_fields(items, self.ROLE_FIELDS)
 | |
|         self.assertEqual(role_name, role['name'])
 | |
|         return role_name
 | |
| 
 | |
|     def _create_dummy_implied_role(self, add_clean_up=True):
 | |
|         role_name = self._create_dummy_role(add_clean_up)
 | |
|         implied_role_name = self._create_dummy_role(add_clean_up)
 | |
|         self.openstack(
 | |
|             'implied role create '
 | |
|             '--implied-role %(implied_role)s '
 | |
|             '%(role)s' % {'implied_role': implied_role_name, 'role': role_name}
 | |
|         )
 | |
| 
 | |
|         return implied_role_name, role_name
 | |
| 
 | |
|     def _create_dummy_group(self, add_clean_up=True):
 | |
|         group_name = data_utils.rand_name('TestGroup')
 | |
|         description = data_utils.rand_name('description')
 | |
|         raw_output = self.openstack(
 | |
|             'group create '
 | |
|             '--domain %(domain)s '
 | |
|             '--description %(description)s '
 | |
|             '%(name)s'
 | |
|             % {
 | |
|                 'domain': self.domain_name,
 | |
|                 'description': description,
 | |
|                 'name': group_name,
 | |
|             }
 | |
|         )
 | |
|         if add_clean_up:
 | |
|             self.addCleanup(
 | |
|                 self.openstack,
 | |
|                 'group delete '
 | |
|                 '--domain %(domain)s '
 | |
|                 '%(name)s' % {'domain': self.domain_name, 'name': group_name},
 | |
|             )
 | |
|         items = self.parse_show(raw_output)
 | |
|         self.assert_show_fields(items, self.GROUP_FIELDS)
 | |
|         return group_name
 | |
| 
 | |
|     def _create_dummy_domain(self, add_clean_up=True):
 | |
|         domain_name = data_utils.rand_name('TestDomain')
 | |
|         domain_description = data_utils.rand_name('description')
 | |
|         self.openstack(
 | |
|             'domain create '
 | |
|             '--description %(description)s '
 | |
|             '--enable %(name)s'
 | |
|             % {'description': domain_description, 'name': domain_name}
 | |
|         )
 | |
|         if add_clean_up:
 | |
|             self.addCleanup(self.openstack, 'domain delete %s' % domain_name)
 | |
|             self.addCleanup(
 | |
|                 self.openstack, 'domain set --disable %s' % domain_name
 | |
|             )
 | |
|         return domain_name
 | |
| 
 | |
|     def _create_dummy_project(self, add_clean_up=True):
 | |
|         project_name = data_utils.rand_name('TestProject')
 | |
|         project_description = data_utils.rand_name('description')
 | |
|         self.openstack(
 | |
|             'project create '
 | |
|             '--domain %(domain)s '
 | |
|             '--description %(description)s '
 | |
|             '--enable %(name)s'
 | |
|             % {
 | |
|                 'domain': self.domain_name,
 | |
|                 'description': project_description,
 | |
|                 'name': project_name,
 | |
|             }
 | |
|         )
 | |
|         if add_clean_up:
 | |
|             self.addCleanup(
 | |
|                 self.openstack,
 | |
|                 'project delete '
 | |
|                 '--domain %(domain)s '
 | |
|                 '%(name)s'
 | |
|                 % {'domain': self.domain_name, 'name': project_name},
 | |
|             )
 | |
|         return project_name
 | |
| 
 | |
|     def _create_dummy_region(self, parent_region=None, add_clean_up=True):
 | |
|         region_id = data_utils.rand_name('TestRegion')
 | |
|         description = data_utils.rand_name('description')
 | |
|         parent_region_arg = ''
 | |
|         if parent_region is not None:
 | |
|             parent_region_arg = '--parent-region %s' % parent_region
 | |
|         raw_output = self.openstack(
 | |
|             'region create '
 | |
|             '%(parent_region_arg)s '
 | |
|             '--description %(description)s '
 | |
|             '%(id)s'
 | |
|             % {
 | |
|                 'parent_region_arg': parent_region_arg,
 | |
|                 'description': description,
 | |
|                 'id': region_id,
 | |
|             }
 | |
|         )
 | |
|         if add_clean_up:
 | |
|             self.addCleanup(self.openstack, 'region delete %s' % region_id)
 | |
|         items = self.parse_show(raw_output)
 | |
|         self.assert_show_fields(items, self.REGION_FIELDS)
 | |
|         return region_id
 | |
| 
 | |
|     def _create_dummy_service(self, add_clean_up=True):
 | |
|         service_name = data_utils.rand_name('TestService')
 | |
|         description = data_utils.rand_name('description')
 | |
|         type_name = data_utils.rand_name('TestType')
 | |
|         raw_output = self.openstack(
 | |
|             'service create '
 | |
|             '--name %(name)s '
 | |
|             '--description %(description)s '
 | |
|             '--enable '
 | |
|             '%(type)s'
 | |
|             % {
 | |
|                 'name': service_name,
 | |
|                 'description': description,
 | |
|                 'type': type_name,
 | |
|             }
 | |
|         )
 | |
|         if add_clean_up:
 | |
|             service = self.parse_show_as_object(raw_output)
 | |
|             self.addCleanup(
 | |
|                 self.openstack, 'service delete %s' % service['id']
 | |
|             )
 | |
|         items = self.parse_show(raw_output)
 | |
|         self.assert_show_fields(items, self.SERVICE_FIELDS)
 | |
|         return service_name
 | |
| 
 | |
|     def _create_dummy_endpoint(self, interface='public', add_clean_up=True):
 | |
|         region_id = self._create_dummy_region()
 | |
|         service_name = self._create_dummy_service()
 | |
|         endpoint_url = data_utils.rand_url()
 | |
|         raw_output = self.openstack(
 | |
|             'endpoint create '
 | |
|             '--region %(region)s '
 | |
|             '--enable '
 | |
|             '%(service)s '
 | |
|             '%(interface)s '
 | |
|             '%(url)s'
 | |
|             % {
 | |
|                 'region': region_id,
 | |
|                 'service': service_name,
 | |
|                 'interface': interface,
 | |
|                 'url': endpoint_url,
 | |
|             }
 | |
|         )
 | |
|         endpoint = self.parse_show_as_object(raw_output)
 | |
|         if add_clean_up:
 | |
|             self.addCleanup(
 | |
|                 self.openstack, 'endpoint delete %s' % endpoint['id']
 | |
|             )
 | |
|         items = self.parse_show(raw_output)
 | |
|         self.assert_show_fields(items, self.ENDPOINT_FIELDS)
 | |
|         return endpoint['id']
 | |
| 
 | |
|     def _create_dummy_idp(self, add_clean_up=True):
 | |
|         identity_provider = data_utils.rand_name('IdentityProvider')
 | |
|         description = data_utils.rand_name('description')
 | |
|         raw_output = self.openstack(
 | |
|             'identity provider create '
 | |
|             ' %(name)s '
 | |
|             '--description %(description)s '
 | |
|             '--enable '
 | |
|             % {'name': identity_provider, 'description': description}
 | |
|         )
 | |
|         if add_clean_up:
 | |
|             self.addCleanup(
 | |
|                 self.openstack,
 | |
|                 'identity provider delete %s' % identity_provider,
 | |
|             )
 | |
|         items = self.parse_show(raw_output)
 | |
|         self.assert_show_fields(items, self.IDENTITY_PROVIDER_FIELDS)
 | |
|         return identity_provider
 | |
| 
 | |
|     def _create_dummy_sp(self, add_clean_up=True):
 | |
|         service_provider = data_utils.rand_name('ServiceProvider')
 | |
|         description = data_utils.rand_name('description')
 | |
|         raw_output = self.openstack(
 | |
|             'service provider create '
 | |
|             ' %(name)s '
 | |
|             '--description %(description)s '
 | |
|             '--auth-url https://sp.example.com:35357 '
 | |
|             '--service-provider-url https://sp.example.com:5000 '
 | |
|             '--enable '
 | |
|             % {'name': service_provider, 'description': description}
 | |
|         )
 | |
|         if add_clean_up:
 | |
|             self.addCleanup(
 | |
|                 self.openstack, 'service provider delete %s' % service_provider
 | |
|             )
 | |
|         items = self.parse_show(raw_output)
 | |
|         self.assert_show_fields(items, self.SERVICE_PROVIDER_FIELDS)
 | |
|         return service_provider
 | |
| 
 | |
|     def _create_dummy_registered_limit(self, add_clean_up=True):
 | |
|         service_name = self._create_dummy_service()
 | |
|         resource_name = data_utils.rand_name('resource_name')
 | |
|         params = {
 | |
|             'service_name': service_name,
 | |
|             'default_limit': 10,
 | |
|             'resource_name': resource_name,
 | |
|         }
 | |
|         raw_output = self.openstack(
 | |
|             'registered limit create'
 | |
|             ' --service %(service_name)s'
 | |
|             ' --default-limit %(default_limit)s'
 | |
|             ' %(resource_name)s' % params,
 | |
|             cloud=SYSTEM_CLOUD,
 | |
|         )
 | |
|         items = self.parse_show(raw_output)
 | |
|         registered_limit_id = self._extract_value_from_items('id', items)
 | |
| 
 | |
|         if add_clean_up:
 | |
|             self.addCleanup(
 | |
|                 self.openstack,
 | |
|                 'registered limit delete %s' % registered_limit_id,
 | |
|                 cloud=SYSTEM_CLOUD,
 | |
|             )
 | |
| 
 | |
|         self.assert_show_fields(items, self.REGISTERED_LIMIT_FIELDS)
 | |
|         return registered_limit_id
 | |
| 
 | |
|     def _extract_value_from_items(self, key, items):
 | |
|         for d in items:
 | |
|             for k, v in d.items():
 | |
|                 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,
 | |
|             cloud=SYSTEM_CLOUD,
 | |
|         )
 | |
|         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,
 | |
|             cloud=SYSTEM_CLOUD,
 | |
|         )
 | |
|         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,
 | |
|                 cloud=SYSTEM_CLOUD,
 | |
|             )
 | |
| 
 | |
|         self.assert_show_fields(items, self.LIMIT_FIELDS)
 | |
|         return limit_id
 |