# 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 uuid from functional.common import exceptions from functional.common import test BASIC_LIST_HEADERS = ['ID', 'Name'] class IdentityV2Tests(test.TestCase): """Functional tests for Identity V2 commands. """ USER_FIELDS = ['email', 'enabled', 'id', 'name', 'project_id', 'username'] PROJECT_FIELDS = ['enabled', 'id', 'name', 'description'] EC2_CREDENTIALS_FIELDS = [ 'access', 'project_id', 'secret', 'trust_id', 'user_id', ] EC2_CREDENTIALS_LIST_HEADERS = [ 'Access', 'Secret', 'Project ID', 'User ID', ] def test_user_list(self): raw_output = self.openstack('user list') items = self.parse_listing(raw_output) self.assert_table_structure(items, BASIC_LIST_HEADERS) def test_user_show(self): raw_output = self.openstack('user show admin') items = self.parse_show(raw_output) self.assert_show_fields(items, self.USER_FIELDS) def test_user_create(self): raw_output = self.openstack('user create mjordan --password bulls' ' --email hoops@example.com') items = self.parse_show(raw_output) self.assert_show_fields(items, self.USER_FIELDS) def test_user_delete(self): self.openstack('user create dummy') raw_output = self.openstack('user delete dummy') self.assertEqual(0, len(raw_output)) def test_bad_user_command(self): self.assertRaises(exceptions.CommandFailed, self.openstack, 'user unlist') def test_project_list(self): raw_output = self.openstack('project list') items = self.parse_listing(raw_output) self.assert_table_structure(items, BASIC_LIST_HEADERS) def test_project_show(self): raw_output = self.openstack('project show admin') items = self.parse_show(raw_output) self.assert_show_fields(items, self.PROJECT_FIELDS) def test_project_create(self): raw_output = self.openstack('project create test-project') items = self.parse_show(raw_output) self.assert_show_fields(items, self.PROJECT_FIELDS) def test_project_delete(self): self.openstack('project create dummy-project') raw_output = self.openstack('project delete dummy-project') self.assertEqual(0, len(raw_output)) def test_ec2_credentials_create(self): create_output = self.openstack('ec2 credentials create') create_items = self.parse_show(create_output) self.openstack( 'ec2 credentials delete %s' % create_items[0]['access'], ) self.assert_show_fields(create_items, self.EC2_CREDENTIALS_FIELDS) def test_ec2_credentials_delete(self): create_output = self.openstack('ec2 credentials create') create_items = self.parse_show(create_output) raw_output = self.openstack( 'ec2 credentials delete %s' % create_items[0]['access'], ) self.assertEqual(0, len(raw_output)) def test_ec2_credentials_list(self): raw_output = self.openstack('ec2 credentials list') items = self.parse_listing(raw_output) self.assert_table_structure(items, self.EC2_CREDENTIALS_LIST_HEADERS) def test_ec2_credentials_show(self): create_output = self.openstack('ec2 credentials create') create_items = self.parse_show(create_output) show_output = self.openstack( 'ec2 credentials show %s' % create_items[0]['access'], ) items = self.parse_show(show_output) self.openstack( 'ec2 credentials delete %s' % create_items[0]['access'], ) self.assert_show_fields(items, self.EC2_CREDENTIALS_FIELDS) class IdentityV3Tests(test.TestCase): """Functional tests for Identity V3 commands. """ DOMAIN_FIELDS = ['description', 'enabled', 'id', 'name', 'links'] GROUP_FIELDS = ['description', 'domain_id', 'id', 'name', 'links'] TOKEN_FIELDS = ['expires', 'id', 'project_id', 'user_id'] def _create_dummy_group(self): name = uuid.uuid4().hex self.openstack('group create ' + name) return name def _create_dummy_domain(self): name = uuid.uuid4().hex self.openstack('domain create ' + name) return name def setUp(self): super(IdentityV3Tests, self).setUp() auth_url = os.environ.get('OS_AUTH_URL') auth_url = auth_url.replace('v2.0', 'v3') os.environ['OS_AUTH_URL'] = auth_url os.environ['OS_IDENTITY_API_VERSION'] = '3' os.environ['OS_USER_DOMAIN_ID'] = 'default' os.environ['OS_PROJECT_DOMAIN_ID'] = 'default' def test_group_create(self): raw_output = self.openstack('group create ' + uuid.uuid4().hex) items = self.parse_show(raw_output) self.assert_show_fields(items, self.GROUP_FIELDS) def test_group_list(self): self._create_dummy_group() raw_output = self.openstack('group list') items = self.parse_listing(raw_output) self.assert_table_structure(items, BASIC_LIST_HEADERS) def test_group_delete(self): name = self._create_dummy_group() raw_output = self.openstack('group delete ' + name) self.assertEqual(0, len(raw_output)) def test_group_show(self): name = self._create_dummy_group() raw_output = self.openstack('group show ' + name) items = self.parse_show(raw_output) self.assert_show_fields(items, self.GROUP_FIELDS) def test_domain_create(self): raw_output = self.openstack('domain create ' + uuid.uuid4().hex) items = self.parse_show(raw_output) self.assert_show_fields(items, self.DOMAIN_FIELDS) def test_domain_list(self): self._create_dummy_domain() raw_output = self.openstack('domain list') items = self.parse_listing(raw_output) self.assert_table_structure(items, BASIC_LIST_HEADERS) def test_domain_delete(self): name = self._create_dummy_domain() self.assertRaises(exceptions.CommandFailed, self.openstack, 'domain delete ' + name) def test_domain_show(self): name = self._create_dummy_domain() raw_output = self.openstack('domain show ' + name) items = self.parse_show(raw_output) self.assert_show_fields(items, self.DOMAIN_FIELDS) def test_token_issue(self): raw_output = self.openstack('token issue') items = self.parse_show(raw_output) self.assert_show_fields(items, self.TOKEN_FIELDS)