 f1cd38aabf
			
		
	
	f1cd38aabf
	
	
	
		
			
			cliff is now smarter (I9155763eee15e19eab23b48989dfcc19ea2c5d34), so we can effectively revert change I6b4f1b793dc383856bfdf9a01514381be3cd2bf1. We bump the dependencies to ensure this. Change-Id: I2af19043fd66b5be0826a774baeabeac7110a4aa Signed-off-by: Stephen Finucane <stephenfin@redhat.com>
		
			
				
	
	
		
			153 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			153 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| #    Copyright 2018 SUSE Linux GmbH
 | |
| #
 | |
| #    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 datetime
 | |
| 
 | |
| from tempest.lib.common.utils import data_utils
 | |
| 
 | |
| from openstackclient.tests.functional.identity.v3 import common
 | |
| 
 | |
| 
 | |
| class ApplicationCredentialTests(common.IdentityTests):
 | |
|     APPLICATION_CREDENTIAL_FIELDS = [
 | |
|         'ID',
 | |
|         'Name',
 | |
|         'Project ID',
 | |
|         'Description',
 | |
|         'Roles',
 | |
|         'Expires At',
 | |
|         'Unrestricted',
 | |
|     ]
 | |
|     APPLICATION_CREDENTIAL_LIST_HEADERS = [
 | |
|         'ID',
 | |
|         'Name',
 | |
|         'Project ID',
 | |
|         'Description',
 | |
|         'Expires At',
 | |
|     ]
 | |
| 
 | |
|     def test_application_credential_create(self):
 | |
|         name = data_utils.rand_name('name')
 | |
|         raw_output = self.openstack(f'application credential create {name}')
 | |
|         self.addCleanup(
 | |
|             self.openstack,
 | |
|             f'application credential delete {name}',
 | |
|         )
 | |
|         items = self.parse_show(raw_output)
 | |
|         self.assert_show_fields(items, self.APPLICATION_CREDENTIAL_FIELDS)
 | |
| 
 | |
|     def _create_role_assignments(self):
 | |
|         try:
 | |
|             user = self.openstack(
 | |
|                 'configuration show -f value -c auth.username'
 | |
|             )
 | |
|         except Exception:
 | |
|             user = self.openstack(
 | |
|                 'configuration show -f value -c auth.user_id'
 | |
|             )
 | |
|         try:
 | |
|             user_domain = self.openstack(
 | |
|                 'configuration show -f value -c auth.user_domain_name'
 | |
|             )
 | |
|         except Exception:
 | |
|             user_domain = self.openstack(
 | |
|                 'configuration show -f value -c auth.user_domain_id'
 | |
|             )
 | |
|         try:
 | |
|             project = self.openstack(
 | |
|                 'configuration show -f value -c auth.project_name'
 | |
|             )
 | |
|         except Exception:
 | |
|             project = self.openstack(
 | |
|                 'configuration show -f value -c auth.project_id'
 | |
|             )
 | |
|         try:
 | |
|             project_domain = self.openstack(
 | |
|                 'configuration show -f value -c auth.project_domain_name'
 | |
|             )
 | |
|         except Exception:
 | |
|             project_domain = self.openstack(
 | |
|                 'configuration show -f value -c auth.project_domain_id'
 | |
|             )
 | |
|         role1 = self._create_dummy_role()
 | |
|         role2 = self._create_dummy_role()
 | |
|         for role in role1, role2:
 | |
|             self.openstack(
 | |
|                 'role add'
 | |
|                 f' --user {user}'
 | |
|                 f' --user-domain {user_domain}'
 | |
|                 f' --project {project}'
 | |
|                 f' --project-domain {project_domain}'
 | |
|                 f' {role}'
 | |
|             )
 | |
|             self.addCleanup(
 | |
|                 self.openstack,
 | |
|                 'role remove'
 | |
|                 f' --user {user}'
 | |
|                 f' --user-domain {user_domain}'
 | |
|                 f' --project {project}'
 | |
|                 f' --project-domain {project_domain}'
 | |
|                 f' {role}',
 | |
|             )
 | |
|         return role1, role2
 | |
| 
 | |
|     def test_application_credential_create_with_options(self):
 | |
|         name = data_utils.rand_name('name')
 | |
|         secret = data_utils.rand_name('secret')
 | |
|         description = data_utils.rand_name('description')
 | |
|         tomorrow = (
 | |
|             datetime.datetime.now(datetime.timezone.utc).replace(tzinfo=None)
 | |
|             + datetime.timedelta(days=1)
 | |
|         ).strftime('%Y-%m-%dT%H:%M:%S%z')
 | |
|         role1, role2 = self._create_role_assignments()
 | |
|         raw_output = self.openstack(
 | |
|             f'application credential create {name}'
 | |
|             f' --secret {secret}'
 | |
|             f' --description {description}'
 | |
|             f' --expiration {tomorrow}'
 | |
|             f' --role {role1}'
 | |
|             f' --role {role2}'
 | |
|             ' --unrestricted'
 | |
|         )
 | |
|         self.addCleanup(
 | |
|             self.openstack,
 | |
|             f'application credential delete {name}',
 | |
|         )
 | |
|         items = self.parse_show(raw_output)
 | |
|         self.assert_show_fields(items, self.APPLICATION_CREDENTIAL_FIELDS)
 | |
| 
 | |
|     def test_application_credential_delete(self):
 | |
|         name = data_utils.rand_name('name')
 | |
|         self.openstack(f'application credential create {name}')
 | |
|         raw_output = self.openstack(f'application credential delete {name}')
 | |
|         self.assertEqual(0, len(raw_output))
 | |
| 
 | |
|     def test_application_credential_list(self):
 | |
|         raw_output = self.openstack('application credential list')
 | |
|         items = self.parse_listing(raw_output)
 | |
|         self.assert_table_structure(
 | |
|             items, self.APPLICATION_CREDENTIAL_LIST_HEADERS
 | |
|         )
 | |
| 
 | |
|     def test_application_credential_show(self):
 | |
|         name = data_utils.rand_name('name')
 | |
|         raw_output = self.openstack(f'application credential create {name}')
 | |
|         self.addCleanup(
 | |
|             self.openstack,
 | |
|             f'application credential delete {name}',
 | |
|         )
 | |
|         raw_output = self.openstack(f'application credential show {name}')
 | |
|         items = self.parse_show(raw_output)
 | |
|         self.assert_show_fields(items, self.APPLICATION_CREDENTIAL_FIELDS)
 |