Refactor fake data for projects and users
* Move fake data structures into tests/identity/fakes.py * Use fake clients correctly and support multiple client versions Change-Id: Icacbb2ca740b63937bd2c4442af61b620638b53e
This commit is contained in:
parent
1c495a573c
commit
eb405a88c4
@ -37,6 +37,7 @@ class FakeApp(object):
|
|||||||
self.stdin = sys.stdin
|
self.stdin = sys.stdin
|
||||||
self.stdout = _stdout or sys.stdout
|
self.stdout = _stdout or sys.stdout
|
||||||
self.stderr = sys.stderr
|
self.stderr = sys.stderr
|
||||||
|
self.restapi = None
|
||||||
|
|
||||||
|
|
||||||
class FakeClientManager(object):
|
class FakeClientManager(object):
|
||||||
@ -44,11 +45,6 @@ class FakeClientManager(object):
|
|||||||
pass
|
pass
|
||||||
|
|
||||||
|
|
||||||
class FakeRESTApi(object):
|
|
||||||
def __init__(self):
|
|
||||||
pass
|
|
||||||
|
|
||||||
|
|
||||||
class FakeResource(object):
|
class FakeResource(object):
|
||||||
def __init__(self, manager, info, loaded=False):
|
def __init__(self, manager, info, loaded=False):
|
||||||
self.manager = manager
|
self.manager = manager
|
||||||
|
@ -18,6 +18,38 @@ import mock
|
|||||||
from openstackclient.tests import fakes
|
from openstackclient.tests import fakes
|
||||||
|
|
||||||
|
|
||||||
|
user_id = 'aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa'
|
||||||
|
user_name = 'paul'
|
||||||
|
user_description = 'Sir Paul'
|
||||||
|
user_email = 'paul@applecorps.com'
|
||||||
|
|
||||||
|
project_id = '8-9-64'
|
||||||
|
project_name = 'beatles'
|
||||||
|
project_description = 'Fab Four'
|
||||||
|
|
||||||
|
USER = {
|
||||||
|
'id': user_id,
|
||||||
|
'name': user_name,
|
||||||
|
'tenantId': project_id,
|
||||||
|
'email': user_email,
|
||||||
|
'enabled': True,
|
||||||
|
}
|
||||||
|
|
||||||
|
PROJECT = {
|
||||||
|
'id': project_id,
|
||||||
|
'name': project_name,
|
||||||
|
'description': project_description,
|
||||||
|
'enabled': True,
|
||||||
|
}
|
||||||
|
|
||||||
|
PROJECT_2 = {
|
||||||
|
'id': project_id + '-2222',
|
||||||
|
'name': project_name + ' reprise',
|
||||||
|
'description': project_description + 'plus four more',
|
||||||
|
'enabled': True,
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
class FakeIdentityv2Client(object):
|
class FakeIdentityv2Client(object):
|
||||||
def __init__(self, **kwargs):
|
def __init__(self, **kwargs):
|
||||||
self.tenants = mock.Mock()
|
self.tenants = mock.Mock()
|
||||||
@ -26,8 +58,8 @@ class FakeIdentityv2Client(object):
|
|||||||
self.users.resource_class = fakes.FakeResource(None, {})
|
self.users.resource_class = fakes.FakeResource(None, {})
|
||||||
self.ec2 = mock.Mock()
|
self.ec2 = mock.Mock()
|
||||||
self.ec2.resource_class = fakes.FakeResource(None, {})
|
self.ec2.resource_class = fakes.FakeResource(None, {})
|
||||||
self.auth_tenant_id = 'fake-tenant'
|
self.auth_token = kwargs['token']
|
||||||
self.auth_user_id = 'fake-user'
|
self.management_url = kwargs['endpoint']
|
||||||
|
|
||||||
|
|
||||||
class FakeIdentityv3Client(object):
|
class FakeIdentityv3Client(object):
|
||||||
|
@ -22,27 +22,29 @@ AUTH_TOKEN = "foobar"
|
|||||||
AUTH_URL = "http://0.0.0.0"
|
AUTH_URL = "http://0.0.0.0"
|
||||||
|
|
||||||
|
|
||||||
class FakeClient(object):
|
class TestIdentity(utils.TestCommand):
|
||||||
def __init__(self, endpoint=None, **kwargs):
|
|
||||||
self.auth_token = AUTH_TOKEN
|
|
||||||
self.auth_url = AUTH_URL
|
|
||||||
|
|
||||||
|
|
||||||
class TestIdentity(utils.TestCase):
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(TestIdentity, self).setUp()
|
super(TestIdentity, self).setUp()
|
||||||
|
|
||||||
api_version = {"identity": "2.0"}
|
api_version = {"identity": "2.0"}
|
||||||
|
|
||||||
identity_client.API_VERSIONS = {
|
identity_client.API_VERSIONS = {
|
||||||
"2.0": "openstackclient.tests.identity.test_identity.FakeClient"
|
"2.0": "openstackclient.tests.identity.fakes.FakeIdentityv2Client"
|
||||||
}
|
}
|
||||||
|
|
||||||
self.cm = clientmanager.ClientManager(token=AUTH_TOKEN,
|
self.app.client_manager = clientmanager.ClientManager(
|
||||||
url=AUTH_URL,
|
token=AUTH_TOKEN,
|
||||||
auth_url=AUTH_URL,
|
url=AUTH_URL,
|
||||||
api_version=api_version)
|
auth_url=AUTH_URL,
|
||||||
|
api_version=api_version,
|
||||||
|
)
|
||||||
|
|
||||||
def test_make_client(self):
|
def test_make_client(self):
|
||||||
self.assertEqual(self.cm.identity.auth_token, AUTH_TOKEN)
|
self.assertEqual(
|
||||||
self.assertEqual(self.cm.identity.auth_url, AUTH_URL)
|
self.app.client_manager.identity.auth_token,
|
||||||
|
AUTH_TOKEN,
|
||||||
|
)
|
||||||
|
self.assertEqual(
|
||||||
|
self.app.client_manager.identity.management_url,
|
||||||
|
AUTH_URL,
|
||||||
|
)
|
||||||
|
@ -18,42 +18,17 @@ import copy
|
|||||||
from openstackclient.identity.v2_0 import project
|
from openstackclient.identity.v2_0 import project
|
||||||
from openstackclient.tests import fakes
|
from openstackclient.tests import fakes
|
||||||
from openstackclient.tests.identity import fakes as identity_fakes
|
from openstackclient.tests.identity import fakes as identity_fakes
|
||||||
from openstackclient.tests import utils
|
from openstackclient.tests.identity import test_identity
|
||||||
|
|
||||||
|
|
||||||
IDENTITY_API_VERSION = "2.0"
|
class TestProject(test_identity.TestIdentity):
|
||||||
|
|
||||||
user_id = 'aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa'
|
|
||||||
user_name = 'paul'
|
|
||||||
user_description = 'Sir Paul'
|
|
||||||
|
|
||||||
project_id = '8-9-64'
|
|
||||||
project_name = 'beatles'
|
|
||||||
project_description = 'Fab Four'
|
|
||||||
|
|
||||||
USER = {
|
|
||||||
'id': user_id,
|
|
||||||
'name': user_name,
|
|
||||||
'tenantId': project_id,
|
|
||||||
}
|
|
||||||
|
|
||||||
PROJECT = {
|
|
||||||
'id': project_id,
|
|
||||||
'name': project_name,
|
|
||||||
'description': project_description,
|
|
||||||
'enabled': True,
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
class TestProject(utils.TestCommand):
|
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(TestProject, self).setUp()
|
super(TestProject, self).setUp()
|
||||||
self.app.client_manager.identity = \
|
|
||||||
identity_fakes.FakeIdentityv2Client()
|
|
||||||
|
|
||||||
# Get a shortcut to the TenantManager Mock
|
# Get a shortcut to the TenantManager Mock
|
||||||
self.projects_mock = self.app.client_manager.identity.tenants
|
self.projects_mock = self.app.client_manager.identity.tenants
|
||||||
|
self.projects_mock.reset_mock()
|
||||||
|
|
||||||
|
|
||||||
class TestProjectCreate(TestProject):
|
class TestProjectCreate(TestProject):
|
||||||
@ -63,7 +38,7 @@ class TestProjectCreate(TestProject):
|
|||||||
|
|
||||||
self.projects_mock.create.return_value = fakes.FakeResource(
|
self.projects_mock.create.return_value = fakes.FakeResource(
|
||||||
None,
|
None,
|
||||||
copy.deepcopy(PROJECT),
|
copy.deepcopy(identity_fakes.PROJECT),
|
||||||
loaded=True,
|
loaded=True,
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -71,9 +46,11 @@ class TestProjectCreate(TestProject):
|
|||||||
self.cmd = project.CreateProject(self.app, None)
|
self.cmd = project.CreateProject(self.app, None)
|
||||||
|
|
||||||
def test_project_create_no_options(self):
|
def test_project_create_no_options(self):
|
||||||
arglist = [project_name]
|
arglist = [
|
||||||
|
identity_fakes.project_name,
|
||||||
|
]
|
||||||
verifylist = [
|
verifylist = [
|
||||||
('project_name', project_name),
|
('project_name', identity_fakes.project_name),
|
||||||
('enable', False),
|
('enable', False),
|
||||||
('disable', False),
|
('disable', False),
|
||||||
]
|
]
|
||||||
@ -87,16 +64,30 @@ class TestProjectCreate(TestProject):
|
|||||||
'description': None,
|
'description': None,
|
||||||
'enabled': True,
|
'enabled': True,
|
||||||
}
|
}
|
||||||
self.projects_mock.create.assert_called_with(project_name, **kwargs)
|
self.projects_mock.create.assert_called_with(
|
||||||
|
identity_fakes.project_name,
|
||||||
|
**kwargs
|
||||||
|
)
|
||||||
|
|
||||||
collist = ('description', 'enabled', 'id', 'name')
|
collist = ('description', 'enabled', 'id', 'name')
|
||||||
self.assertEqual(columns, collist)
|
self.assertEqual(columns, collist)
|
||||||
datalist = (project_description, True, project_id, project_name)
|
datalist = (
|
||||||
|
identity_fakes.project_description,
|
||||||
|
True,
|
||||||
|
identity_fakes.project_id,
|
||||||
|
identity_fakes.project_name,
|
||||||
|
)
|
||||||
self.assertEqual(data, datalist)
|
self.assertEqual(data, datalist)
|
||||||
|
|
||||||
def test_project_create_description(self):
|
def test_project_create_description(self):
|
||||||
arglist = ['--description', 'new desc', project_name]
|
arglist = [
|
||||||
verifylist = [('description', 'new desc')]
|
'--description', 'new desc',
|
||||||
|
identity_fakes.project_name,
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('project_name', identity_fakes.project_name),
|
||||||
|
('description', 'new desc'),
|
||||||
|
]
|
||||||
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
# DisplayCommandBase.take_action() returns two tuples
|
# DisplayCommandBase.take_action() returns two tuples
|
||||||
@ -107,16 +98,31 @@ class TestProjectCreate(TestProject):
|
|||||||
'description': 'new desc',
|
'description': 'new desc',
|
||||||
'enabled': True,
|
'enabled': True,
|
||||||
}
|
}
|
||||||
self.projects_mock.create.assert_called_with(project_name, **kwargs)
|
self.projects_mock.create.assert_called_with(
|
||||||
|
identity_fakes.project_name,
|
||||||
|
**kwargs
|
||||||
|
)
|
||||||
|
|
||||||
collist = ('description', 'enabled', 'id', 'name')
|
collist = ('description', 'enabled', 'id', 'name')
|
||||||
self.assertEqual(columns, collist)
|
self.assertEqual(columns, collist)
|
||||||
datalist = (project_description, True, project_id, project_name)
|
datalist = (
|
||||||
|
identity_fakes.project_description,
|
||||||
|
True,
|
||||||
|
identity_fakes.project_id,
|
||||||
|
identity_fakes.project_name,
|
||||||
|
)
|
||||||
self.assertEqual(data, datalist)
|
self.assertEqual(data, datalist)
|
||||||
|
|
||||||
def test_project_create_enable(self):
|
def test_project_create_enable(self):
|
||||||
arglist = ['--enable', project_name]
|
arglist = [
|
||||||
verifylist = [('enable', True), ('disable', False)]
|
'--enable',
|
||||||
|
identity_fakes.project_name,
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('project_name', identity_fakes.project_name),
|
||||||
|
('enable', True),
|
||||||
|
('disable', False),
|
||||||
|
]
|
||||||
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
# DisplayCommandBase.take_action() returns two tuples
|
# DisplayCommandBase.take_action() returns two tuples
|
||||||
@ -127,16 +133,31 @@ class TestProjectCreate(TestProject):
|
|||||||
'description': None,
|
'description': None,
|
||||||
'enabled': True,
|
'enabled': True,
|
||||||
}
|
}
|
||||||
self.projects_mock.create.assert_called_with(project_name, **kwargs)
|
self.projects_mock.create.assert_called_with(
|
||||||
|
identity_fakes.project_name,
|
||||||
|
**kwargs
|
||||||
|
)
|
||||||
|
|
||||||
collist = ('description', 'enabled', 'id', 'name')
|
collist = ('description', 'enabled', 'id', 'name')
|
||||||
self.assertEqual(columns, collist)
|
self.assertEqual(columns, collist)
|
||||||
datalist = (project_description, True, project_id, project_name)
|
datalist = (
|
||||||
|
identity_fakes.project_description,
|
||||||
|
True,
|
||||||
|
identity_fakes.project_id,
|
||||||
|
identity_fakes.project_name,
|
||||||
|
)
|
||||||
self.assertEqual(data, datalist)
|
self.assertEqual(data, datalist)
|
||||||
|
|
||||||
def test_project_create_disable(self):
|
def test_project_create_disable(self):
|
||||||
arglist = ['--disable', project_name]
|
arglist = [
|
||||||
verifylist = [('enable', False), ('disable', True)]
|
'--disable',
|
||||||
|
identity_fakes.project_name,
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('project_name', identity_fakes.project_name),
|
||||||
|
('enable', False),
|
||||||
|
('disable', True),
|
||||||
|
]
|
||||||
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
# DisplayCommandBase.take_action() returns two tuples
|
# DisplayCommandBase.take_action() returns two tuples
|
||||||
@ -147,11 +168,19 @@ class TestProjectCreate(TestProject):
|
|||||||
'description': None,
|
'description': None,
|
||||||
'enabled': False,
|
'enabled': False,
|
||||||
}
|
}
|
||||||
self.projects_mock.create.assert_called_with(project_name, **kwargs)
|
self.projects_mock.create.assert_called_with(
|
||||||
|
identity_fakes.project_name,
|
||||||
|
**kwargs
|
||||||
|
)
|
||||||
|
|
||||||
collist = ('description', 'enabled', 'id', 'name')
|
collist = ('description', 'enabled', 'id', 'name')
|
||||||
self.assertEqual(columns, collist)
|
self.assertEqual(columns, collist)
|
||||||
datalist = (project_description, True, project_id, project_name)
|
datalist = (
|
||||||
|
identity_fakes.project_description,
|
||||||
|
True,
|
||||||
|
identity_fakes.project_id,
|
||||||
|
identity_fakes.project_name,
|
||||||
|
)
|
||||||
self.assertEqual(data, datalist)
|
self.assertEqual(data, datalist)
|
||||||
|
|
||||||
|
|
||||||
@ -163,7 +192,7 @@ class TestProjectDelete(TestProject):
|
|||||||
# This is the return value for utils.find_resource()
|
# This is the return value for utils.find_resource()
|
||||||
self.projects_mock.get.return_value = fakes.FakeResource(
|
self.projects_mock.get.return_value = fakes.FakeResource(
|
||||||
None,
|
None,
|
||||||
copy.deepcopy(PROJECT),
|
copy.deepcopy(identity_fakes.PROJECT),
|
||||||
loaded=True,
|
loaded=True,
|
||||||
)
|
)
|
||||||
self.projects_mock.delete.return_value = None
|
self.projects_mock.delete.return_value = None
|
||||||
@ -172,14 +201,20 @@ class TestProjectDelete(TestProject):
|
|||||||
self.cmd = project.DeleteProject(self.app, None)
|
self.cmd = project.DeleteProject(self.app, None)
|
||||||
|
|
||||||
def test_project_delete_no_options(self):
|
def test_project_delete_no_options(self):
|
||||||
arglist = [user_id]
|
arglist = [
|
||||||
verifylist = [('project', user_id)]
|
identity_fakes.project_id,
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('project', identity_fakes.project_id),
|
||||||
|
]
|
||||||
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
result = self.cmd.run(parsed_args)
|
result = self.cmd.run(parsed_args)
|
||||||
self.assertEqual(result, 0)
|
self.assertEqual(result, 0)
|
||||||
|
|
||||||
self.projects_mock.delete.assert_called_with(project_id)
|
self.projects_mock.delete.assert_called_with(
|
||||||
|
identity_fakes.project_id,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
class TestProjectList(TestProject):
|
class TestProjectList(TestProject):
|
||||||
@ -190,7 +225,7 @@ class TestProjectList(TestProject):
|
|||||||
self.projects_mock.list.return_value = [
|
self.projects_mock.list.return_value = [
|
||||||
fakes.FakeResource(
|
fakes.FakeResource(
|
||||||
None,
|
None,
|
||||||
copy.deepcopy(PROJECT),
|
copy.deepcopy(identity_fakes.PROJECT),
|
||||||
loaded=True,
|
loaded=True,
|
||||||
),
|
),
|
||||||
]
|
]
|
||||||
@ -209,12 +244,19 @@ class TestProjectList(TestProject):
|
|||||||
|
|
||||||
collist = ('ID', 'Name')
|
collist = ('ID', 'Name')
|
||||||
self.assertEqual(columns, collist)
|
self.assertEqual(columns, collist)
|
||||||
datalist = ((project_id, project_name), )
|
datalist = ((
|
||||||
|
identity_fakes.project_id,
|
||||||
|
identity_fakes.project_name,
|
||||||
|
), )
|
||||||
self.assertEqual(tuple(data), datalist)
|
self.assertEqual(tuple(data), datalist)
|
||||||
|
|
||||||
def test_project_list_long(self):
|
def test_project_list_long(self):
|
||||||
arglist = ['--long']
|
arglist = [
|
||||||
verifylist = [('long', True)]
|
'--long',
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('long', True),
|
||||||
|
]
|
||||||
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
# DisplayCommandBase.take_action() returns two tuples
|
# DisplayCommandBase.take_action() returns two tuples
|
||||||
@ -223,7 +265,12 @@ class TestProjectList(TestProject):
|
|||||||
|
|
||||||
collist = ('ID', 'Name', 'Description', 'Enabled')
|
collist = ('ID', 'Name', 'Description', 'Enabled')
|
||||||
self.assertEqual(columns, collist)
|
self.assertEqual(columns, collist)
|
||||||
datalist = ((project_id, project_name, project_description, True), )
|
datalist = ((
|
||||||
|
identity_fakes.project_id,
|
||||||
|
identity_fakes.project_name,
|
||||||
|
identity_fakes.project_description,
|
||||||
|
True,
|
||||||
|
), )
|
||||||
self.assertEqual(tuple(data), datalist)
|
self.assertEqual(tuple(data), datalist)
|
||||||
|
|
||||||
|
|
||||||
@ -234,7 +281,7 @@ class TestProjectSet(TestProject):
|
|||||||
|
|
||||||
self.projects_mock.get.return_value = fakes.FakeResource(
|
self.projects_mock.get.return_value = fakes.FakeResource(
|
||||||
None,
|
None,
|
||||||
copy.deepcopy(PROJECT),
|
copy.deepcopy(identity_fakes.PROJECT),
|
||||||
loaded=True,
|
loaded=True,
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -242,9 +289,11 @@ class TestProjectSet(TestProject):
|
|||||||
self.cmd = project.SetProject(self.app, None)
|
self.cmd = project.SetProject(self.app, None)
|
||||||
|
|
||||||
def test_project_set_no_options(self):
|
def test_project_set_no_options(self):
|
||||||
arglist = [project_name]
|
arglist = [
|
||||||
|
identity_fakes.project_name,
|
||||||
|
]
|
||||||
verifylist = [
|
verifylist = [
|
||||||
('project', project_name),
|
('project', identity_fakes.project_name),
|
||||||
('enable', False),
|
('enable', False),
|
||||||
('disable', False),
|
('disable', False),
|
||||||
]
|
]
|
||||||
@ -255,15 +304,23 @@ class TestProjectSet(TestProject):
|
|||||||
|
|
||||||
# Set expected values
|
# Set expected values
|
||||||
kwargs = {
|
kwargs = {
|
||||||
'description': project_description,
|
'description': identity_fakes.project_description,
|
||||||
'enabled': True,
|
'enabled': True,
|
||||||
'tenant_name': project_name,
|
'tenant_name': identity_fakes.project_name,
|
||||||
}
|
}
|
||||||
self.projects_mock.update.assert_called_with(project_id, **kwargs)
|
self.projects_mock.update.assert_called_with(
|
||||||
|
identity_fakes.project_id,
|
||||||
|
**kwargs
|
||||||
|
)
|
||||||
|
|
||||||
def test_project_set_name(self):
|
def test_project_set_name(self):
|
||||||
arglist = ['--name', 'qwerty', project_name]
|
arglist = [
|
||||||
verifylist = [('name', 'qwerty')]
|
'--name', 'qwerty',
|
||||||
|
identity_fakes.project_name,
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('name', 'qwerty'),
|
||||||
|
]
|
||||||
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
result = self.cmd.run(parsed_args)
|
result = self.cmd.run(parsed_args)
|
||||||
@ -271,15 +328,23 @@ class TestProjectSet(TestProject):
|
|||||||
|
|
||||||
# Set expected values
|
# Set expected values
|
||||||
kwargs = {
|
kwargs = {
|
||||||
'description': project_description,
|
'description': identity_fakes.project_description,
|
||||||
'enabled': True,
|
'enabled': True,
|
||||||
'tenant_name': 'qwerty',
|
'tenant_name': 'qwerty',
|
||||||
}
|
}
|
||||||
self.projects_mock.update.assert_called_with(project_id, **kwargs)
|
self.projects_mock.update.assert_called_with(
|
||||||
|
identity_fakes.project_id,
|
||||||
|
**kwargs
|
||||||
|
)
|
||||||
|
|
||||||
def test_project_set_description(self):
|
def test_project_set_description(self):
|
||||||
arglist = ['--description', 'new desc', project_name]
|
arglist = [
|
||||||
verifylist = [('description', 'new desc')]
|
'--description', 'new desc',
|
||||||
|
identity_fakes.project_name,
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('description', 'new desc'),
|
||||||
|
]
|
||||||
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
result = self.cmd.run(parsed_args)
|
result = self.cmd.run(parsed_args)
|
||||||
@ -289,13 +354,22 @@ class TestProjectSet(TestProject):
|
|||||||
kwargs = {
|
kwargs = {
|
||||||
'description': 'new desc',
|
'description': 'new desc',
|
||||||
'enabled': True,
|
'enabled': True,
|
||||||
'tenant_name': project_name,
|
'tenant_name': identity_fakes.project_name,
|
||||||
}
|
}
|
||||||
self.projects_mock.update.assert_called_with(project_id, **kwargs)
|
self.projects_mock.update.assert_called_with(
|
||||||
|
identity_fakes.project_id,
|
||||||
|
**kwargs
|
||||||
|
)
|
||||||
|
|
||||||
def test_project_set_enable(self):
|
def test_project_set_enable(self):
|
||||||
arglist = ['--enable', project_name]
|
arglist = [
|
||||||
verifylist = [('enable', True), ('disable', False)]
|
'--enable',
|
||||||
|
identity_fakes.project_name,
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('enable', True),
|
||||||
|
('disable', False),
|
||||||
|
]
|
||||||
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
result = self.cmd.run(parsed_args)
|
result = self.cmd.run(parsed_args)
|
||||||
@ -303,15 +377,24 @@ class TestProjectSet(TestProject):
|
|||||||
|
|
||||||
# Set expected values
|
# Set expected values
|
||||||
kwargs = {
|
kwargs = {
|
||||||
'description': project_description,
|
'description': identity_fakes.project_description,
|
||||||
'enabled': True,
|
'enabled': True,
|
||||||
'tenant_name': project_name,
|
'tenant_name': identity_fakes.project_name,
|
||||||
}
|
}
|
||||||
self.projects_mock.update.assert_called_with(project_id, **kwargs)
|
self.projects_mock.update.assert_called_with(
|
||||||
|
identity_fakes.project_id,
|
||||||
|
**kwargs
|
||||||
|
)
|
||||||
|
|
||||||
def test_project_set_disable(self):
|
def test_project_set_disable(self):
|
||||||
arglist = ['--disable', project_name]
|
arglist = [
|
||||||
verifylist = [('enable', False), ('disable', True)]
|
'--disable',
|
||||||
|
identity_fakes.project_name,
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('enable', False),
|
||||||
|
('disable', True),
|
||||||
|
]
|
||||||
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
result = self.cmd.run(parsed_args)
|
result = self.cmd.run(parsed_args)
|
||||||
@ -319,11 +402,14 @@ class TestProjectSet(TestProject):
|
|||||||
|
|
||||||
# Set expected values
|
# Set expected values
|
||||||
kwargs = {
|
kwargs = {
|
||||||
'description': project_description,
|
'description': identity_fakes.project_description,
|
||||||
'enabled': False,
|
'enabled': False,
|
||||||
'tenant_name': project_name,
|
'tenant_name': identity_fakes.project_name,
|
||||||
}
|
}
|
||||||
self.projects_mock.update.assert_called_with(project_id, **kwargs)
|
self.projects_mock.update.assert_called_with(
|
||||||
|
identity_fakes.project_id,
|
||||||
|
**kwargs
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
class TestProjectShow(TestProject):
|
class TestProjectShow(TestProject):
|
||||||
@ -333,7 +419,7 @@ class TestProjectShow(TestProject):
|
|||||||
|
|
||||||
self.projects_mock.get.return_value = fakes.FakeResource(
|
self.projects_mock.get.return_value = fakes.FakeResource(
|
||||||
None,
|
None,
|
||||||
copy.deepcopy(PROJECT),
|
copy.deepcopy(identity_fakes.PROJECT),
|
||||||
loaded=True,
|
loaded=True,
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -341,15 +427,26 @@ class TestProjectShow(TestProject):
|
|||||||
self.cmd = project.ShowProject(self.app, None)
|
self.cmd = project.ShowProject(self.app, None)
|
||||||
|
|
||||||
def test_project_show(self):
|
def test_project_show(self):
|
||||||
arglist = [user_id]
|
arglist = [
|
||||||
verifylist = [('project', user_id)]
|
identity_fakes.project_id,
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('project', identity_fakes.project_id),
|
||||||
|
]
|
||||||
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
# DisplayCommandBase.take_action() returns two tuples
|
# DisplayCommandBase.take_action() returns two tuples
|
||||||
columns, data = self.cmd.take_action(parsed_args)
|
columns, data = self.cmd.take_action(parsed_args)
|
||||||
self.projects_mock.get.assert_called_with(user_id)
|
self.projects_mock.get.assert_called_with(
|
||||||
|
identity_fakes.project_id,
|
||||||
|
)
|
||||||
|
|
||||||
collist = ('description', 'enabled', 'id', 'name')
|
collist = ('description', 'enabled', 'id', 'name')
|
||||||
self.assertEqual(columns, collist)
|
self.assertEqual(columns, collist)
|
||||||
datalist = (project_description, True, project_id, project_name)
|
datalist = (
|
||||||
|
identity_fakes.project_description,
|
||||||
|
True,
|
||||||
|
identity_fakes.project_id,
|
||||||
|
identity_fakes.project_name,
|
||||||
|
)
|
||||||
self.assertEqual(data, datalist)
|
self.assertEqual(data, datalist)
|
343
openstackclient/tests/identity/v2_0/test_users.py → openstackclient/tests/identity/v2_0/test_user.py
343
openstackclient/tests/identity/v2_0/test_users.py → openstackclient/tests/identity/v2_0/test_user.py
@ -18,54 +18,20 @@ import copy
|
|||||||
from openstackclient.identity.v2_0 import user
|
from openstackclient.identity.v2_0 import user
|
||||||
from openstackclient.tests import fakes
|
from openstackclient.tests import fakes
|
||||||
from openstackclient.tests.identity import fakes as identity_fakes
|
from openstackclient.tests.identity import fakes as identity_fakes
|
||||||
from openstackclient.tests import utils
|
from openstackclient.tests.identity import test_identity
|
||||||
|
|
||||||
|
|
||||||
IDENTITY_API_VERSION = "2.0"
|
class TestUser(test_identity.TestIdentity):
|
||||||
|
|
||||||
user_id = 'aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa'
|
|
||||||
user_name = 'paul'
|
|
||||||
user_description = 'Sir Paul'
|
|
||||||
user_email = 'paul@applecorps.com'
|
|
||||||
|
|
||||||
project_id = '8-9-64'
|
|
||||||
project_name = 'beatles'
|
|
||||||
project_description = 'Fab Four'
|
|
||||||
|
|
||||||
USER = {
|
|
||||||
'id': user_id,
|
|
||||||
'name': user_name,
|
|
||||||
'tenantId': project_id,
|
|
||||||
'email': user_email,
|
|
||||||
'enabled': True,
|
|
||||||
}
|
|
||||||
|
|
||||||
PROJECT = {
|
|
||||||
'id': project_id,
|
|
||||||
'name': project_name,
|
|
||||||
'description': project_description,
|
|
||||||
'enabled': True,
|
|
||||||
}
|
|
||||||
|
|
||||||
PROJECT_2 = {
|
|
||||||
'id': project_id + '-2222',
|
|
||||||
'name': project_name + ' reprise',
|
|
||||||
'description': project_description + 'plus four more',
|
|
||||||
'enabled': True,
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
class TestUser(utils.TestCommand):
|
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(TestUser, self).setUp()
|
super(TestUser, self).setUp()
|
||||||
self.app.client_manager.identity = \
|
|
||||||
identity_fakes.FakeIdentityv2Client()
|
|
||||||
|
|
||||||
# Get a shortcut to the TenantManager Mock
|
# Get a shortcut to the TenantManager Mock
|
||||||
self.projects_mock = self.app.client_manager.identity.tenants
|
self.projects_mock = self.app.client_manager.identity.tenants
|
||||||
|
self.projects_mock.reset_mock()
|
||||||
# Get a shortcut to the UserManager Mock
|
# Get a shortcut to the UserManager Mock
|
||||||
self.users_mock = self.app.client_manager.identity.users
|
self.users_mock = self.app.client_manager.identity.users
|
||||||
|
self.users_mock.reset_mock()
|
||||||
|
|
||||||
|
|
||||||
class TestUserCreate(TestUser):
|
class TestUserCreate(TestUser):
|
||||||
@ -75,12 +41,12 @@ class TestUserCreate(TestUser):
|
|||||||
|
|
||||||
self.projects_mock.get.return_value = fakes.FakeResource(
|
self.projects_mock.get.return_value = fakes.FakeResource(
|
||||||
None,
|
None,
|
||||||
copy.deepcopy(PROJECT),
|
copy.deepcopy(identity_fakes.PROJECT),
|
||||||
loaded=True,
|
loaded=True,
|
||||||
)
|
)
|
||||||
self.users_mock.create.return_value = fakes.FakeResource(
|
self.users_mock.create.return_value = fakes.FakeResource(
|
||||||
None,
|
None,
|
||||||
copy.deepcopy(USER),
|
copy.deepcopy(identity_fakes.USER),
|
||||||
loaded=True,
|
loaded=True,
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -88,9 +54,11 @@ class TestUserCreate(TestUser):
|
|||||||
self.cmd = user.CreateUser(self.app, None)
|
self.cmd = user.CreateUser(self.app, None)
|
||||||
|
|
||||||
def test_user_create_no_options(self):
|
def test_user_create_no_options(self):
|
||||||
arglist = [user_name]
|
arglist = [
|
||||||
|
identity_fakes.user_name,
|
||||||
|
]
|
||||||
verifylist = [
|
verifylist = [
|
||||||
('name', user_name),
|
('name', identity_fakes.user_name),
|
||||||
]
|
]
|
||||||
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
@ -104,7 +72,7 @@ class TestUserCreate(TestUser):
|
|||||||
}
|
}
|
||||||
# users.create(name, password, email, tenant_id=None, enabled=True)
|
# users.create(name, password, email, tenant_id=None, enabled=True)
|
||||||
self.users_mock.create.assert_called_with(
|
self.users_mock.create.assert_called_with(
|
||||||
user_name,
|
identity_fakes.user_name,
|
||||||
None,
|
None,
|
||||||
None,
|
None,
|
||||||
**kwargs
|
**kwargs
|
||||||
@ -112,12 +80,24 @@ class TestUserCreate(TestUser):
|
|||||||
|
|
||||||
collist = ('email', 'enabled', 'id', 'name', 'project_id')
|
collist = ('email', 'enabled', 'id', 'name', 'project_id')
|
||||||
self.assertEqual(columns, collist)
|
self.assertEqual(columns, collist)
|
||||||
datalist = (user_email, True, user_id, user_name, project_id)
|
datalist = (
|
||||||
|
identity_fakes.user_email,
|
||||||
|
True,
|
||||||
|
identity_fakes.user_id,
|
||||||
|
identity_fakes.user_name,
|
||||||
|
identity_fakes.project_id,
|
||||||
|
)
|
||||||
self.assertEqual(data, datalist)
|
self.assertEqual(data, datalist)
|
||||||
|
|
||||||
def test_user_create_password(self):
|
def test_user_create_password(self):
|
||||||
arglist = ['--password', 'secret', user_name]
|
arglist = [
|
||||||
verifylist = [('password', 'secret')]
|
'--password', 'secret',
|
||||||
|
identity_fakes.user_name,
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('name', identity_fakes.user_name),
|
||||||
|
('password', 'secret')
|
||||||
|
]
|
||||||
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
# DisplayCommandBase.take_action() returns two tuples
|
# DisplayCommandBase.take_action() returns two tuples
|
||||||
@ -130,7 +110,7 @@ class TestUserCreate(TestUser):
|
|||||||
}
|
}
|
||||||
# users.create(name, password, email, tenant_id=None, enabled=True)
|
# users.create(name, password, email, tenant_id=None, enabled=True)
|
||||||
self.users_mock.create.assert_called_with(
|
self.users_mock.create.assert_called_with(
|
||||||
user_name,
|
identity_fakes.user_name,
|
||||||
'secret',
|
'secret',
|
||||||
None,
|
None,
|
||||||
**kwargs
|
**kwargs
|
||||||
@ -138,12 +118,24 @@ class TestUserCreate(TestUser):
|
|||||||
|
|
||||||
collist = ('email', 'enabled', 'id', 'name', 'project_id')
|
collist = ('email', 'enabled', 'id', 'name', 'project_id')
|
||||||
self.assertEqual(columns, collist)
|
self.assertEqual(columns, collist)
|
||||||
datalist = (user_email, True, user_id, user_name, project_id)
|
datalist = (
|
||||||
|
identity_fakes.user_email,
|
||||||
|
True,
|
||||||
|
identity_fakes.user_id,
|
||||||
|
identity_fakes.user_name,
|
||||||
|
identity_fakes.project_id,
|
||||||
|
)
|
||||||
self.assertEqual(data, datalist)
|
self.assertEqual(data, datalist)
|
||||||
|
|
||||||
def test_user_create_email(self):
|
def test_user_create_email(self):
|
||||||
arglist = ['--email', 'barney@example.com', user_name]
|
arglist = [
|
||||||
verifylist = [('email', 'barney@example.com')]
|
'--email', 'barney@example.com',
|
||||||
|
identity_fakes.user_name,
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('name', identity_fakes.user_name),
|
||||||
|
('email', 'barney@example.com'),
|
||||||
|
]
|
||||||
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
# DisplayCommandBase.take_action() returns two tuples
|
# DisplayCommandBase.take_action() returns two tuples
|
||||||
@ -156,7 +148,7 @@ class TestUserCreate(TestUser):
|
|||||||
}
|
}
|
||||||
# users.create(name, password, email, tenant_id=None, enabled=True)
|
# users.create(name, password, email, tenant_id=None, enabled=True)
|
||||||
self.users_mock.create.assert_called_with(
|
self.users_mock.create.assert_called_with(
|
||||||
user_name,
|
identity_fakes.user_name,
|
||||||
None,
|
None,
|
||||||
'barney@example.com',
|
'barney@example.com',
|
||||||
**kwargs
|
**kwargs
|
||||||
@ -164,27 +156,39 @@ class TestUserCreate(TestUser):
|
|||||||
|
|
||||||
collist = ('email', 'enabled', 'id', 'name', 'project_id')
|
collist = ('email', 'enabled', 'id', 'name', 'project_id')
|
||||||
self.assertEqual(columns, collist)
|
self.assertEqual(columns, collist)
|
||||||
datalist = (user_email, True, user_id, user_name, project_id)
|
datalist = (
|
||||||
|
identity_fakes.user_email,
|
||||||
|
True,
|
||||||
|
identity_fakes.user_id,
|
||||||
|
identity_fakes.user_name,
|
||||||
|
identity_fakes.project_id,
|
||||||
|
)
|
||||||
self.assertEqual(data, datalist)
|
self.assertEqual(data, datalist)
|
||||||
|
|
||||||
def test_user_create_project(self):
|
def test_user_create_project(self):
|
||||||
# Return the new project
|
# Return the new project
|
||||||
self.projects_mock.get.return_value = fakes.FakeResource(
|
self.projects_mock.get.return_value = fakes.FakeResource(
|
||||||
None,
|
None,
|
||||||
copy.deepcopy(PROJECT_2),
|
copy.deepcopy(identity_fakes.PROJECT_2),
|
||||||
loaded=True,
|
loaded=True,
|
||||||
)
|
)
|
||||||
# Set up to return an updated user
|
# Set up to return an updated user
|
||||||
USER_2 = copy.deepcopy(USER)
|
USER_2 = copy.deepcopy(identity_fakes.USER)
|
||||||
USER_2['tenantId'] = PROJECT_2['id']
|
USER_2['tenantId'] = identity_fakes.PROJECT_2['id']
|
||||||
self.users_mock.create.return_value = fakes.FakeResource(
|
self.users_mock.create.return_value = fakes.FakeResource(
|
||||||
None,
|
None,
|
||||||
USER_2,
|
USER_2,
|
||||||
loaded=True,
|
loaded=True,
|
||||||
)
|
)
|
||||||
|
|
||||||
arglist = ['--project', PROJECT_2['name'], user_name]
|
arglist = [
|
||||||
verifylist = [('project', PROJECT_2['name'])]
|
'--project', identity_fakes.PROJECT_2['name'],
|
||||||
|
identity_fakes.user_name,
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('name', identity_fakes.user_name),
|
||||||
|
('project', identity_fakes.PROJECT_2['name']),
|
||||||
|
]
|
||||||
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
# DisplayCommandBase.take_action() returns two tuples
|
# DisplayCommandBase.take_action() returns two tuples
|
||||||
@ -193,11 +197,11 @@ class TestUserCreate(TestUser):
|
|||||||
# Set expected values
|
# Set expected values
|
||||||
kwargs = {
|
kwargs = {
|
||||||
'enabled': True,
|
'enabled': True,
|
||||||
'tenant_id': PROJECT_2['id'],
|
'tenant_id': identity_fakes.PROJECT_2['id'],
|
||||||
}
|
}
|
||||||
# users.create(name, password, email, tenant_id=None, enabled=True)
|
# users.create(name, password, email, tenant_id=None, enabled=True)
|
||||||
self.users_mock.create.assert_called_with(
|
self.users_mock.create.assert_called_with(
|
||||||
user_name,
|
identity_fakes.user_name,
|
||||||
None,
|
None,
|
||||||
None,
|
None,
|
||||||
**kwargs
|
**kwargs
|
||||||
@ -205,12 +209,25 @@ class TestUserCreate(TestUser):
|
|||||||
|
|
||||||
collist = ('email', 'enabled', 'id', 'name', 'project_id')
|
collist = ('email', 'enabled', 'id', 'name', 'project_id')
|
||||||
self.assertEqual(columns, collist)
|
self.assertEqual(columns, collist)
|
||||||
datalist = (user_email, True, user_id, user_name, PROJECT_2['id'])
|
datalist = (
|
||||||
|
identity_fakes.user_email,
|
||||||
|
True,
|
||||||
|
identity_fakes.user_id,
|
||||||
|
identity_fakes.user_name,
|
||||||
|
identity_fakes.PROJECT_2['id'],
|
||||||
|
)
|
||||||
self.assertEqual(data, datalist)
|
self.assertEqual(data, datalist)
|
||||||
|
|
||||||
def test_user_create_enable(self):
|
def test_user_create_enable(self):
|
||||||
arglist = ['--enable', project_name]
|
arglist = [
|
||||||
verifylist = [('enable', True), ('disable', False)]
|
'--enable',
|
||||||
|
identity_fakes.user_name,
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('name', identity_fakes.user_name),
|
||||||
|
('enable', True),
|
||||||
|
('disable', False),
|
||||||
|
]
|
||||||
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
# DisplayCommandBase.take_action() returns two tuples
|
# DisplayCommandBase.take_action() returns two tuples
|
||||||
@ -223,7 +240,7 @@ class TestUserCreate(TestUser):
|
|||||||
}
|
}
|
||||||
# users.create(name, password, email, tenant_id=None, enabled=True)
|
# users.create(name, password, email, tenant_id=None, enabled=True)
|
||||||
self.users_mock.create.assert_called_with(
|
self.users_mock.create.assert_called_with(
|
||||||
project_name,
|
identity_fakes.user_name,
|
||||||
None,
|
None,
|
||||||
None,
|
None,
|
||||||
**kwargs
|
**kwargs
|
||||||
@ -231,12 +248,25 @@ class TestUserCreate(TestUser):
|
|||||||
|
|
||||||
collist = ('email', 'enabled', 'id', 'name', 'project_id')
|
collist = ('email', 'enabled', 'id', 'name', 'project_id')
|
||||||
self.assertEqual(columns, collist)
|
self.assertEqual(columns, collist)
|
||||||
datalist = (user_email, True, user_id, user_name, project_id)
|
datalist = (
|
||||||
|
identity_fakes.user_email,
|
||||||
|
True,
|
||||||
|
identity_fakes.user_id,
|
||||||
|
identity_fakes.user_name,
|
||||||
|
identity_fakes.project_id,
|
||||||
|
)
|
||||||
self.assertEqual(data, datalist)
|
self.assertEqual(data, datalist)
|
||||||
|
|
||||||
def test_user_create_disable(self):
|
def test_user_create_disable(self):
|
||||||
arglist = ['--disable', project_name]
|
arglist = [
|
||||||
verifylist = [('enable', False), ('disable', True)]
|
'--disable',
|
||||||
|
identity_fakes.user_name,
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('name', identity_fakes.user_name),
|
||||||
|
('enable', False),
|
||||||
|
('disable', True),
|
||||||
|
]
|
||||||
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
# DisplayCommandBase.take_action() returns two tuples
|
# DisplayCommandBase.take_action() returns two tuples
|
||||||
@ -249,7 +279,7 @@ class TestUserCreate(TestUser):
|
|||||||
}
|
}
|
||||||
# users.create(name, password, email, tenant_id=None, enabled=True)
|
# users.create(name, password, email, tenant_id=None, enabled=True)
|
||||||
self.users_mock.create.assert_called_with(
|
self.users_mock.create.assert_called_with(
|
||||||
project_name,
|
identity_fakes.user_name,
|
||||||
None,
|
None,
|
||||||
None,
|
None,
|
||||||
**kwargs
|
**kwargs
|
||||||
@ -257,7 +287,13 @@ class TestUserCreate(TestUser):
|
|||||||
|
|
||||||
collist = ('email', 'enabled', 'id', 'name', 'project_id')
|
collist = ('email', 'enabled', 'id', 'name', 'project_id')
|
||||||
self.assertEqual(columns, collist)
|
self.assertEqual(columns, collist)
|
||||||
datalist = (user_email, True, user_id, user_name, project_id)
|
datalist = (
|
||||||
|
identity_fakes.user_email,
|
||||||
|
True,
|
||||||
|
identity_fakes.user_id,
|
||||||
|
identity_fakes.user_name,
|
||||||
|
identity_fakes.project_id,
|
||||||
|
)
|
||||||
self.assertEqual(data, datalist)
|
self.assertEqual(data, datalist)
|
||||||
|
|
||||||
|
|
||||||
@ -269,7 +305,7 @@ class TestUserDelete(TestUser):
|
|||||||
# This is the return value for utils.find_resource()
|
# This is the return value for utils.find_resource()
|
||||||
self.users_mock.get.return_value = fakes.FakeResource(
|
self.users_mock.get.return_value = fakes.FakeResource(
|
||||||
None,
|
None,
|
||||||
copy.deepcopy(USER),
|
copy.deepcopy(identity_fakes.USER),
|
||||||
loaded=True,
|
loaded=True,
|
||||||
)
|
)
|
||||||
self.users_mock.delete.return_value = None
|
self.users_mock.delete.return_value = None
|
||||||
@ -278,16 +314,20 @@ class TestUserDelete(TestUser):
|
|||||||
self.cmd = user.DeleteUser(self.app, None)
|
self.cmd = user.DeleteUser(self.app, None)
|
||||||
|
|
||||||
def test_user_delete_no_options(self):
|
def test_user_delete_no_options(self):
|
||||||
arglist = [user_id]
|
arglist = [
|
||||||
|
identity_fakes.user_id,
|
||||||
|
]
|
||||||
verifylist = [
|
verifylist = [
|
||||||
('user', user_id),
|
('user', identity_fakes.user_id),
|
||||||
]
|
]
|
||||||
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
# DisplayCommandBase.take_action() returns two tuples
|
# DisplayCommandBase.take_action() returns two tuples
|
||||||
self.cmd.take_action(parsed_args)
|
self.cmd.take_action(parsed_args)
|
||||||
|
|
||||||
self.users_mock.delete.assert_called_with(user_id)
|
self.users_mock.delete.assert_called_with(
|
||||||
|
identity_fakes.user_id,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
class TestUserList(TestUser):
|
class TestUserList(TestUser):
|
||||||
@ -295,10 +335,17 @@ class TestUserList(TestUser):
|
|||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(TestUserList, self).setUp()
|
super(TestUserList, self).setUp()
|
||||||
|
|
||||||
|
self.projects_mock.list.return_value = [
|
||||||
|
fakes.FakeResource(
|
||||||
|
None,
|
||||||
|
copy.deepcopy(identity_fakes.PROJECT),
|
||||||
|
loaded=True,
|
||||||
|
),
|
||||||
|
]
|
||||||
self.users_mock.list.return_value = [
|
self.users_mock.list.return_value = [
|
||||||
fakes.FakeResource(
|
fakes.FakeResource(
|
||||||
None,
|
None,
|
||||||
copy.deepcopy(USER),
|
copy.deepcopy(identity_fakes.USER),
|
||||||
loaded=True,
|
loaded=True,
|
||||||
),
|
),
|
||||||
]
|
]
|
||||||
@ -318,12 +365,19 @@ class TestUserList(TestUser):
|
|||||||
|
|
||||||
collist = ('ID', 'Name')
|
collist = ('ID', 'Name')
|
||||||
self.assertEqual(columns, collist)
|
self.assertEqual(columns, collist)
|
||||||
datalist = ((user_id, user_name), )
|
datalist = ((
|
||||||
|
identity_fakes.user_id,
|
||||||
|
identity_fakes.user_name,
|
||||||
|
), )
|
||||||
self.assertEqual(tuple(data), datalist)
|
self.assertEqual(tuple(data), datalist)
|
||||||
|
|
||||||
def test_user_list_project(self):
|
def test_user_list_project(self):
|
||||||
arglist = ['--project', project_id]
|
arglist = [
|
||||||
verifylist = [('project', project_id)]
|
'--project', identity_fakes.project_id,
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('project', identity_fakes.project_id),
|
||||||
|
]
|
||||||
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
# DisplayCommandBase.take_action() returns two tuples
|
# DisplayCommandBase.take_action() returns two tuples
|
||||||
@ -333,12 +387,19 @@ class TestUserList(TestUser):
|
|||||||
|
|
||||||
collist = ('ID', 'Name')
|
collist = ('ID', 'Name')
|
||||||
self.assertEqual(columns, collist)
|
self.assertEqual(columns, collist)
|
||||||
datalist = ((user_id, user_name), )
|
datalist = ((
|
||||||
|
identity_fakes.user_id,
|
||||||
|
identity_fakes.user_name,
|
||||||
|
), )
|
||||||
self.assertEqual(tuple(data), datalist)
|
self.assertEqual(tuple(data), datalist)
|
||||||
|
|
||||||
def test_user_list_long(self):
|
def test_user_list_long(self):
|
||||||
arglist = ['--long']
|
arglist = [
|
||||||
verifylist = [('long', True)]
|
'--long',
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('long', True),
|
||||||
|
]
|
||||||
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
# DisplayCommandBase.take_action() returns two tuples
|
# DisplayCommandBase.take_action() returns two tuples
|
||||||
@ -348,7 +409,13 @@ class TestUserList(TestUser):
|
|||||||
|
|
||||||
collist = ('ID', 'Name', 'Project', 'Email', 'Enabled')
|
collist = ('ID', 'Name', 'Project', 'Email', 'Enabled')
|
||||||
self.assertEqual(columns, collist)
|
self.assertEqual(columns, collist)
|
||||||
datalist = ((user_id, user_name, project_id, user_email, True), )
|
datalist = ((
|
||||||
|
identity_fakes.user_id,
|
||||||
|
identity_fakes.user_name,
|
||||||
|
identity_fakes.project_name,
|
||||||
|
identity_fakes.user_email,
|
||||||
|
True,
|
||||||
|
), )
|
||||||
self.assertEqual(tuple(data), datalist)
|
self.assertEqual(tuple(data), datalist)
|
||||||
|
|
||||||
|
|
||||||
@ -359,12 +426,12 @@ class TestUserSet(TestUser):
|
|||||||
|
|
||||||
self.projects_mock.get.return_value = fakes.FakeResource(
|
self.projects_mock.get.return_value = fakes.FakeResource(
|
||||||
None,
|
None,
|
||||||
copy.deepcopy(PROJECT),
|
copy.deepcopy(identity_fakes.PROJECT),
|
||||||
loaded=True,
|
loaded=True,
|
||||||
)
|
)
|
||||||
self.users_mock.get.return_value = fakes.FakeResource(
|
self.users_mock.get.return_value = fakes.FakeResource(
|
||||||
None,
|
None,
|
||||||
copy.deepcopy(USER),
|
copy.deepcopy(identity_fakes.USER),
|
||||||
loaded=True,
|
loaded=True,
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -372,9 +439,11 @@ class TestUserSet(TestUser):
|
|||||||
self.cmd = user.SetUser(self.app, None)
|
self.cmd = user.SetUser(self.app, None)
|
||||||
|
|
||||||
def test_user_set_no_options(self):
|
def test_user_set_no_options(self):
|
||||||
arglist = [user_name]
|
arglist = [
|
||||||
|
identity_fakes.user_name,
|
||||||
|
]
|
||||||
verifylist = [
|
verifylist = [
|
||||||
('user', user_name),
|
('user', identity_fakes.user_name),
|
||||||
('enable', False),
|
('enable', False),
|
||||||
('disable', False),
|
('disable', False),
|
||||||
('project', None),
|
('project', None),
|
||||||
@ -384,11 +453,17 @@ class TestUserSet(TestUser):
|
|||||||
# DisplayCommandBase.take_action() returns two tuples
|
# DisplayCommandBase.take_action() returns two tuples
|
||||||
self.cmd.take_action(parsed_args)
|
self.cmd.take_action(parsed_args)
|
||||||
|
|
||||||
|
# SetUser doesn't call anything if no args are passed
|
||||||
self.assertFalse(self.users_mock.update.called)
|
self.assertFalse(self.users_mock.update.called)
|
||||||
|
|
||||||
def test_user_set_name(self):
|
def test_user_set_name(self):
|
||||||
arglist = ['--name', 'qwerty', user_name]
|
arglist = [
|
||||||
verifylist = [('name', 'qwerty')]
|
'--name', 'qwerty',
|
||||||
|
identity_fakes.user_name,
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('name', 'qwerty'),
|
||||||
|
]
|
||||||
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
# DisplayCommandBase.take_action() returns two tuples
|
# DisplayCommandBase.take_action() returns two tuples
|
||||||
@ -398,21 +473,37 @@ class TestUserSet(TestUser):
|
|||||||
kwargs = {
|
kwargs = {
|
||||||
'name': 'qwerty',
|
'name': 'qwerty',
|
||||||
}
|
}
|
||||||
self.users_mock.update.assert_called_with(user_id, **kwargs)
|
self.users_mock.update.assert_called_with(
|
||||||
|
identity_fakes.user_id,
|
||||||
|
**kwargs
|
||||||
|
)
|
||||||
|
|
||||||
def test_user_set_password(self):
|
def test_user_set_password(self):
|
||||||
arglist = ['--password', 'secret', user_name]
|
arglist = [
|
||||||
verifylist = [('password', 'secret')]
|
'--password', 'secret',
|
||||||
|
identity_fakes.user_name,
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('password', 'secret'),
|
||||||
|
]
|
||||||
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
# DisplayCommandBase.take_action() returns two tuples
|
# DisplayCommandBase.take_action() returns two tuples
|
||||||
self.cmd.take_action(parsed_args)
|
self.cmd.take_action(parsed_args)
|
||||||
|
|
||||||
self.users_mock.update_password.assert_called_with(user_id, 'secret')
|
self.users_mock.update_password.assert_called_with(
|
||||||
|
identity_fakes.user_id,
|
||||||
|
'secret',
|
||||||
|
)
|
||||||
|
|
||||||
def test_user_set_email(self):
|
def test_user_set_email(self):
|
||||||
arglist = ['--email', 'barney@example.com', user_name]
|
arglist = [
|
||||||
verifylist = [('email', 'barney@example.com')]
|
'--email', 'barney@example.com',
|
||||||
|
identity_fakes.user_name,
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('email', 'barney@example.com'),
|
||||||
|
]
|
||||||
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
# DisplayCommandBase.take_action() returns two tuples
|
# DisplayCommandBase.take_action() returns two tuples
|
||||||
@ -422,24 +513,38 @@ class TestUserSet(TestUser):
|
|||||||
kwargs = {
|
kwargs = {
|
||||||
'email': 'barney@example.com',
|
'email': 'barney@example.com',
|
||||||
}
|
}
|
||||||
self.users_mock.update.assert_called_with(user_id, **kwargs)
|
self.users_mock.update.assert_called_with(
|
||||||
|
identity_fakes.user_id,
|
||||||
|
**kwargs
|
||||||
|
)
|
||||||
|
|
||||||
def test_user_set_project(self):
|
def test_user_set_project(self):
|
||||||
arglist = ['--project', project_id, user_name]
|
arglist = [
|
||||||
verifylist = [('project', project_id)]
|
'--project', identity_fakes.project_id,
|
||||||
|
identity_fakes.user_name,
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('project', identity_fakes.project_id),
|
||||||
|
]
|
||||||
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
# DisplayCommandBase.take_action() returns two tuples
|
# DisplayCommandBase.take_action() returns two tuples
|
||||||
self.cmd.take_action(parsed_args)
|
self.cmd.take_action(parsed_args)
|
||||||
|
|
||||||
self.users_mock.update_tenant.assert_called_with(
|
self.users_mock.update_tenant.assert_called_with(
|
||||||
user_id,
|
identity_fakes.user_id,
|
||||||
project_id,
|
identity_fakes.project_id,
|
||||||
)
|
)
|
||||||
|
|
||||||
def test_user_set_enable(self):
|
def test_user_set_enable(self):
|
||||||
arglist = ['--enable', user_name]
|
arglist = [
|
||||||
verifylist = [('enable', True), ('disable', False)]
|
'--enable',
|
||||||
|
identity_fakes.user_name,
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('enable', True),
|
||||||
|
('disable', False),
|
||||||
|
]
|
||||||
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
# DisplayCommandBase.take_action() returns two tuples
|
# DisplayCommandBase.take_action() returns two tuples
|
||||||
@ -449,11 +554,20 @@ class TestUserSet(TestUser):
|
|||||||
kwargs = {
|
kwargs = {
|
||||||
'enabled': True,
|
'enabled': True,
|
||||||
}
|
}
|
||||||
self.users_mock.update.assert_called_with(user_id, **kwargs)
|
self.users_mock.update.assert_called_with(
|
||||||
|
identity_fakes.user_id,
|
||||||
|
**kwargs
|
||||||
|
)
|
||||||
|
|
||||||
def test_user_set_disable(self):
|
def test_user_set_disable(self):
|
||||||
arglist = ['--disable', user_name]
|
arglist = [
|
||||||
verifylist = [('enable', False), ('disable', True)]
|
'--disable',
|
||||||
|
identity_fakes.user_name,
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('enable', False),
|
||||||
|
('disable', True),
|
||||||
|
]
|
||||||
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
# DisplayCommandBase.take_action() returns two tuples
|
# DisplayCommandBase.take_action() returns two tuples
|
||||||
@ -463,7 +577,10 @@ class TestUserSet(TestUser):
|
|||||||
kwargs = {
|
kwargs = {
|
||||||
'enabled': False,
|
'enabled': False,
|
||||||
}
|
}
|
||||||
self.users_mock.update.assert_called_with(user_id, **kwargs)
|
self.users_mock.update.assert_called_with(
|
||||||
|
identity_fakes.user_id,
|
||||||
|
**kwargs
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
class TestUserShow(TestUser):
|
class TestUserShow(TestUser):
|
||||||
@ -473,7 +590,7 @@ class TestUserShow(TestUser):
|
|||||||
|
|
||||||
self.users_mock.get.return_value = fakes.FakeResource(
|
self.users_mock.get.return_value = fakes.FakeResource(
|
||||||
None,
|
None,
|
||||||
copy.deepcopy(USER),
|
copy.deepcopy(identity_fakes.USER),
|
||||||
loaded=True,
|
loaded=True,
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -481,16 +598,26 @@ class TestUserShow(TestUser):
|
|||||||
self.cmd = user.ShowUser(self.app, None)
|
self.cmd = user.ShowUser(self.app, None)
|
||||||
|
|
||||||
def test_user_show(self):
|
def test_user_show(self):
|
||||||
arglist = [user_id]
|
arglist = [
|
||||||
verifylist = [('user', user_id)]
|
identity_fakes.user_id,
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('user', identity_fakes.user_id),
|
||||||
|
]
|
||||||
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
# DisplayCommandBase.take_action() returns two tuples
|
# DisplayCommandBase.take_action() returns two tuples
|
||||||
columns, data = self.cmd.take_action(parsed_args)
|
columns, data = self.cmd.take_action(parsed_args)
|
||||||
|
|
||||||
self.users_mock.get.assert_called_with(user_id)
|
self.users_mock.get.assert_called_with(identity_fakes.user_id)
|
||||||
|
|
||||||
collist = ('email', 'enabled', 'id', 'name', 'project_id')
|
collist = ('email', 'enabled', 'id', 'name', 'project_id')
|
||||||
self.assertEqual(columns, collist)
|
self.assertEqual(columns, collist)
|
||||||
datalist = (user_email, True, user_id, user_name, project_id)
|
datalist = (
|
||||||
|
identity_fakes.user_email,
|
||||||
|
True,
|
||||||
|
identity_fakes.user_id,
|
||||||
|
identity_fakes.user_name,
|
||||||
|
identity_fakes.project_id,
|
||||||
|
)
|
||||||
self.assertEqual(data, datalist)
|
self.assertEqual(data, datalist)
|
@ -22,6 +22,7 @@ import mock
|
|||||||
|
|
||||||
from openstackclient.object.v1.lib import container as lib_container
|
from openstackclient.object.v1.lib import container as lib_container
|
||||||
from openstackclient.tests.common import test_restapi as restapi
|
from openstackclient.tests.common import test_restapi as restapi
|
||||||
|
from openstackclient.tests import fakes
|
||||||
from openstackclient.tests import utils
|
from openstackclient.tests import utils
|
||||||
|
|
||||||
|
|
||||||
@ -41,6 +42,7 @@ class TestObject(utils.TestCommand):
|
|||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(TestObject, self).setUp()
|
super(TestObject, self).setUp()
|
||||||
|
self.app.client_manager = fakes.FakeClientManager()
|
||||||
self.app.client_manager.object = FakeClient()
|
self.app.client_manager.object = FakeClient()
|
||||||
self.app.restapi = mock.MagicMock()
|
self.app.restapi = mock.MagicMock()
|
||||||
|
|
||||||
|
@ -21,6 +21,7 @@ import mock
|
|||||||
|
|
||||||
from openstackclient.object.v1.lib import object as lib_object
|
from openstackclient.object.v1.lib import object as lib_object
|
||||||
from openstackclient.tests.common import test_restapi as restapi
|
from openstackclient.tests.common import test_restapi as restapi
|
||||||
|
from openstackclient.tests import fakes
|
||||||
from openstackclient.tests import utils
|
from openstackclient.tests import utils
|
||||||
|
|
||||||
|
|
||||||
@ -40,6 +41,7 @@ class TestObject(utils.TestCommand):
|
|||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(TestObject, self).setUp()
|
super(TestObject, self).setUp()
|
||||||
|
self.app.client_manager = fakes.FakeClientManager()
|
||||||
self.app.client_manager.object = FakeClient()
|
self.app.client_manager.object = FakeClient()
|
||||||
self.app.restapi = mock.MagicMock()
|
self.app.restapi = mock.MagicMock()
|
||||||
|
|
||||||
|
@ -70,8 +70,6 @@ class TestCommand(TestCase):
|
|||||||
# Build up a fake app
|
# Build up a fake app
|
||||||
self.fake_stdout = fakes.FakeStdout()
|
self.fake_stdout = fakes.FakeStdout()
|
||||||
self.app = fakes.FakeApp(self.fake_stdout)
|
self.app = fakes.FakeApp(self.fake_stdout)
|
||||||
self.app.client_manager = fakes.FakeClientManager()
|
|
||||||
self.app.restapi = fakes.FakeRESTApi()
|
|
||||||
|
|
||||||
def check_parser(self, cmd, args, verify_args):
|
def check_parser(self, cmd, args, verify_args):
|
||||||
cmd_parser = cmd.get_parser('check_parser')
|
cmd_parser = cmd.get_parser('check_parser')
|
||||||
|
Loading…
x
Reference in New Issue
Block a user