Create a whole slew of functional tests for identity
Complete the remaining identity v2 and v3 functional tests Change-Id: I193fd95e58a38caeb66d37c17cde75b983c48ca0
This commit is contained in:
parent
742982af4b
commit
3842960f71
@ -10,26 +10,132 @@
|
|||||||
# License for the specific language governing permissions and limitations
|
# License for the specific language governing permissions and limitations
|
||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
|
import os
|
||||||
|
import uuid
|
||||||
|
|
||||||
from functional.common import exceptions
|
from functional.common import exceptions
|
||||||
from functional.common import test
|
from functional.common import test
|
||||||
|
|
||||||
|
BASIC_LIST_HEADERS = ['ID', 'Name']
|
||||||
|
|
||||||
|
|
||||||
class IdentityV2Tests(test.TestCase):
|
class IdentityV2Tests(test.TestCase):
|
||||||
"""Functional tests for Identity V2 commands. """
|
"""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):
|
def test_user_list(self):
|
||||||
field_names = ['ID', 'Name']
|
|
||||||
raw_output = self.openstack('user list')
|
raw_output = self.openstack('user list')
|
||||||
items = self.parse_listing(raw_output)
|
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):
|
def test_user_show(self):
|
||||||
field_names = ['email', 'enabled', 'id', 'name',
|
|
||||||
'project_id', 'username']
|
|
||||||
raw_output = self.openstack('user show admin')
|
raw_output = self.openstack('user show admin')
|
||||||
items = self.parse_show(raw_output)
|
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):
|
def test_bad_user_command(self):
|
||||||
self.assertRaises(exceptions.CommandFailed,
|
self.assertRaises(exceptions.CommandFailed,
|
||||||
self.openstack, 'user unlist')
|
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)
|
||||||
|
Loading…
Reference in New Issue
Block a user