diff options
| author | Steve Martinelli <stevemar@ca.ibm.com> | 2014-11-12 10:48:47 -0500 |
|---|---|---|
| committer | Steve Martinelli <stevemar@ca.ibm.com> | 2014-11-14 16:29:57 -0500 |
| commit | 7242113a8f8bcb8c227b259376e34e28ef6c2b52 (patch) | |
| tree | fba19d2415efc5e324fe8d3855febd765088cc50 /openstackclient/tests | |
| parent | c55fdb6f6d1fc356ee03cf21fdf3d5b99418c921 (diff) | |
| download | python-openstackclient-7242113a8f8bcb8c227b259376e34e28ef6c2b52.tar.gz | |
Add additional support for --or-show
Add --or-show for the following:
* v2 roles
* v2 projects
Change-Id: Ibbae19cda668575b9527fbd259f1298c48b8265b
Diffstat (limited to 'openstackclient/tests')
| -rw-r--r-- | openstackclient/tests/identity/v2_0/test_project.py | 85 | ||||
| -rw-r--r-- | openstackclient/tests/identity/v2_0/test_role.py | 71 |
2 files changed, 156 insertions, 0 deletions
diff --git a/openstackclient/tests/identity/v2_0/test_project.py b/openstackclient/tests/identity/v2_0/test_project.py index d046cd47..833b5d84 100644 --- a/openstackclient/tests/identity/v2_0/test_project.py +++ b/openstackclient/tests/identity/v2_0/test_project.py @@ -15,6 +15,8 @@ import copy +from keystoneclient.openstack.common.apiclient import exceptions as ksc_exc + from openstackclient.identity.v2_0 import project from openstackclient.tests import fakes from openstackclient.tests.identity.v2_0 import fakes as identity_fakes @@ -219,6 +221,89 @@ class TestProjectCreate(TestProject): ) self.assertEqual(data, datalist) + def test_project_create_or_show_exists(self): + def _raise_conflict(*args, **kwargs): + raise ksc_exc.Conflict(None) + + # need to make this throw an exception... + self.projects_mock.create.side_effect = _raise_conflict + + self.projects_mock.get.return_value = fakes.FakeResource( + None, + copy.deepcopy(identity_fakes.PROJECT), + loaded=True, + ) + + arglist = [ + '--or-show', + identity_fakes.project_name, + ] + verifylist = [ + ('name', identity_fakes.project_name), + ('or_show', True), + ] + parsed_args = self.check_parser(self.cmd, arglist, verifylist) + + # DisplayCommandBase.take_action() returns two tuples + columns, data = self.cmd.take_action(parsed_args) + + # ProjectManager.create(name, description, enabled) + self.projects_mock.get.assert_called_with(identity_fakes.project_name) + + # Set expected values + kwargs = { + 'description': None, + 'enabled': True, + } + self.projects_mock.create.assert_called_with( + identity_fakes.project_name, + **kwargs + ) + + collist = ('description', 'enabled', 'id', 'name') + self.assertEqual(collist, columns) + datalist = ( + identity_fakes.project_description, + True, + identity_fakes.project_id, + identity_fakes.project_name, + ) + self.assertEqual(datalist, data) + + def test_project_create_or_show_not_exists(self): + arglist = [ + '--or-show', + identity_fakes.project_name, + ] + verifylist = [ + ('name', identity_fakes.project_name), + ('or_show', True), + ] + parsed_args = self.check_parser(self.cmd, arglist, verifylist) + + # DisplayCommandBase.take_action() returns two tuples + columns, data = self.cmd.take_action(parsed_args) + + # Set expected values + kwargs = { + 'description': None, + 'enabled': True, + } + self.projects_mock.create.assert_called_with( + identity_fakes.project_name, + **kwargs + ) + + collist = ('description', 'enabled', 'id', 'name') + self.assertEqual(collist, columns) + datalist = ( + identity_fakes.project_description, + True, + identity_fakes.project_id, + identity_fakes.project_name, + ) + self.assertEqual(datalist, data) + class TestProjectDelete(TestProject): diff --git a/openstackclient/tests/identity/v2_0/test_role.py b/openstackclient/tests/identity/v2_0/test_role.py index d515bd7c..67467747 100644 --- a/openstackclient/tests/identity/v2_0/test_role.py +++ b/openstackclient/tests/identity/v2_0/test_role.py @@ -16,6 +16,8 @@ import copy import mock +from keystoneclient.openstack.common.apiclient import exceptions as ksc_exc + from openstackclient.common import exceptions from openstackclient.identity.v2_0 import role from openstackclient.tests import fakes @@ -142,6 +144,75 @@ class TestRoleCreate(TestRole): ) self.assertEqual(data, datalist) + def test_role_create_or_show_exists(self): + def _raise_conflict(*args, **kwargs): + raise ksc_exc.Conflict(None) + + # need to make this throw an exception... + self.roles_mock.create.side_effect = _raise_conflict + + self.roles_mock.get.return_value = fakes.FakeResource( + None, + copy.deepcopy(identity_fakes.ROLE), + loaded=True, + ) + + arglist = [ + '--or-show', + identity_fakes.role_name, + ] + verifylist = [ + ('role_name', identity_fakes.role_name), + ('or_show', True), + ] + parsed_args = self.check_parser(self.cmd, arglist, verifylist) + + # DisplayCommandBase.take_action() returns two tuples + columns, data = self.cmd.take_action(parsed_args) + + # RoleManager.get(name, description, enabled) + self.roles_mock.get.assert_called_with(identity_fakes.role_name) + + # RoleManager.create(name) + self.roles_mock.create.assert_called_with( + identity_fakes.role_name, + ) + + collist = ('id', 'name') + self.assertEqual(collist, columns) + datalist = ( + identity_fakes.role_id, + identity_fakes.role_name, + ) + self.assertEqual(datalist, data) + + def test_role_create_or_show_not_exists(self): + arglist = [ + '--or-show', + identity_fakes.role_name, + ] + verifylist = [ + ('role_name', identity_fakes.role_name), + ('or_show', True), + ] + parsed_args = self.check_parser(self.cmd, arglist, verifylist) + + # DisplayCommandBase.take_action() returns two tuples + columns, data = self.cmd.take_action(parsed_args) + + # RoleManager.create(name) + self.roles_mock.create.assert_called_with( + identity_fakes.role_name, + ) + + collist = ('id', 'name') + self.assertEqual(collist, columns) + datalist = ( + identity_fakes.role_id, + identity_fakes.role_name, + ) + self.assertEqual(datalist, data) + class TestRoleDelete(TestRole): |
