From 3842960f7189903f1ea5ab432cedc3ca803390d4 Mon Sep 17 00:00:00 2001 From: Steve Martinelli Date: Tue, 30 Sep 2014 18:28:01 -0400 Subject: [PATCH] Create a whole slew of functional tests for identity Complete the remaining identity v2 and v3 functional tests Change-Id: I193fd95e58a38caeb66d37c17cde75b983c48ca0 --- functional/tests/test_identity.py | 118 ++++++++++++++++++++++++++++-- 1 file changed, 112 insertions(+), 6 deletions(-) diff --git a/functional/tests/test_identity.py b/functional/tests/test_identity.py index 5f8b4cb09c..cdb0ed341b 100644 --- a/functional/tests/test_identity.py +++ b/functional/tests/test_identity.py @@ -10,26 +10,132 @@ # 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'] + def test_user_list(self): - field_names = ['ID', 'Name'] raw_output = self.openstack('user list') items = self.parse_listing(raw_output) - self.assert_table_structure(items, field_names) + self.assert_table_structure(items, BASIC_LIST_HEADERS) - def test_user_get(self): - field_names = ['email', 'enabled', 'id', 'name', - 'project_id', 'username'] + def test_user_show(self): raw_output = self.openstack('user show admin') items = self.parse_show(raw_output) - self.assert_show_fields(items, field_names) + 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)) + + +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'] + + 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)