Unit test of credential in identityv3

Add missing unit tests and refactor the older tests
with fake classeds for credential in identity v3

Change-Id: I94d4f80a86806c6115178421bd481b7622065956
This commit is contained in:
Huanxuan Ao 2016-07-20 17:26:45 +08:00
parent 412b29b972
commit bca4571ab6
2 changed files with 367 additions and 28 deletions

View File

@ -198,8 +198,6 @@ SERVICE_WITHOUT_NAME = {
'links': base_url + 'services/' + service_id, 'links': base_url + 'services/' + service_id,
} }
credential_id = 'c-123'
endpoint_id = 'e-123' endpoint_id = 'e-123'
endpoint_url = 'http://127.0.0.1:35357' endpoint_url = 'http://127.0.0.1:35357'
endpoint_region = 'RegionOne' endpoint_region = 'RegionOne'
@ -639,3 +637,104 @@ class FakeDomain(object):
domain = fakes.FakeResource(info=copy.deepcopy(domain_info), domain = fakes.FakeResource(info=copy.deepcopy(domain_info),
loaded=True) loaded=True)
return domain return domain
class FakeCredential(object):
"""Fake one or more credential."""
@staticmethod
def create_one_credential(attrs=None):
"""Create a fake credential.
:param Dictionary attrs:
A dictionary with all attributes
:return:
A FakeResource object, with id, type, and so on
"""
attrs = attrs or {}
# set default attributes.
credential_info = {
'id': 'credential-id-' + uuid.uuid4().hex,
'type': 'cert',
'user_id': 'user-id-' + uuid.uuid4().hex,
'blob': 'credential-data-' + uuid.uuid4().hex,
'project_id': 'project-id-' + uuid.uuid4().hex,
'links': 'links-' + uuid.uuid4().hex,
}
credential_info.update(attrs)
credential = fakes.FakeResource(
info=copy.deepcopy(credential_info), loaded=True)
return credential
@staticmethod
def create_credentials(attrs=None, count=2):
"""Create multiple fake credentials.
:param Dictionary attrs:
A dictionary with all attributes
:param int count:
The number of credentials to fake
:return:
A list of FakeResource objects faking the credentials
"""
credentials = []
for i in range(0, count):
credential = FakeCredential.create_one_credential(attrs)
credentials.append(credential)
return credentials
@staticmethod
def get_credentials(credentials=None, count=2):
"""Get an iterable MagicMock object with a list of faked credentials.
If credentials list is provided, then initialize the Mock object with
the list. Otherwise create one.
:param List credentials:
A list of FakeResource objects faking credentials
:param Integer count:
The number of credentials to be faked
:return
An iterable Mock object with side_effect set to a list of faked
credentials
"""
if credentials is None:
credentials = FakeCredential.create_credentials(count)
return mock.MagicMock(side_effect=credentials)
class FakeUser(object):
"""Fake one or more user."""
@staticmethod
def create_one_user(attrs=None):
"""Create a fake user.
:param Dictionary attrs:
A dictionary with all attributes
:return:
A FakeResource object, with id, name, and so on
"""
attrs = attrs or {}
# set default attributes.
user_info = {
'id': 'user-id-' + uuid.uuid4().hex,
'name': 'user-name-' + uuid.uuid4().hex,
'default_project_id': 'project-' + uuid.uuid4().hex,
'email': 'user-email-' + uuid.uuid4().hex,
'enabled': True,
'domain_id': 'domain-id' + uuid.uuid4().hex,
'links': 'links-' + uuid.uuid4().hex,
}
user_info.update(attrs)
user = fakes.FakeResource(info=copy.deepcopy(user_info),
loaded=True)
return user

View File

@ -10,7 +10,10 @@
# 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 json import mock
from mock import call
from osc_lib import exceptions
from openstackclient.identity.v3 import credential from openstackclient.identity.v3 import credential
from openstackclient.tests.identity.v3 import fakes as identity_fakes from openstackclient.tests.identity.v3 import fakes as identity_fakes
@ -18,16 +21,6 @@ from openstackclient.tests import utils
class TestCredential(identity_fakes.TestIdentityv3): class TestCredential(identity_fakes.TestIdentityv3):
data = {
"access": "abc123",
"secret": "hidden-message",
"trust_id": None
}
def __init__(self, *args):
super(TestCredential, self).__init__(*args)
self.json_data = json.dumps(self.data)
def setUp(self): def setUp(self):
super(TestCredential, self).setUp() super(TestCredential, self).setUp()
@ -45,15 +38,221 @@ class TestCredential(identity_fakes.TestIdentityv3):
self.projects_mock.reset_mock() self.projects_mock.reset_mock()
class TestCredentialCreate(TestCredential):
user = identity_fakes.FakeUser.create_one_user()
project = identity_fakes.FakeProject.create_one_project()
columns = (
'blob',
'id',
'project_id',
'type',
'user_id',
)
def setUp(self):
super(TestCredentialCreate, self).setUp()
self.credential = identity_fakes.FakeCredential.create_one_credential(
attrs={'user_id': self.user.id, 'project_id': self.project.id})
self.credentials_mock.create.return_value = self.credential
self.users_mock.get.return_value = self.user
self.projects_mock.get.return_value = self.project
self.data = (
self.credential.blob,
self.credential.id,
self.credential.project_id,
self.credential.type,
self.credential.user_id,
)
self.cmd = credential.CreateCredential(self.app, None)
def test_credential_create_no_options(self):
arglist = [
self.credential.user_id,
self.credential.blob,
]
verifylist = [
('user', self.credential.user_id),
('data', self.credential.blob),
]
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
columns, data = self.cmd.take_action(parsed_args)
kwargs = {
'user': self.credential.user_id,
'type': self.credential.type,
'blob': self.credential.blob,
'project': None,
}
self.credentials_mock.create.assert_called_once_with(
**kwargs
)
self.assertEqual(self.columns, columns)
self.assertEqual(self.data, data)
def test_credential_create_with_options(self):
arglist = [
self.credential.user_id,
self.credential.blob,
'--type', self.credential.type,
'--project', self.credential.project_id,
]
verifylist = [
('user', self.credential.user_id),
('data', self.credential.blob),
('type', self.credential.type),
('project', self.credential.project_id),
]
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
columns, data = self.cmd.take_action(parsed_args)
kwargs = {
'user': self.credential.user_id,
'type': self.credential.type,
'blob': self.credential.blob,
'project': self.credential.project_id,
}
self.credentials_mock.create.assert_called_once_with(
**kwargs
)
self.assertEqual(self.columns, columns)
self.assertEqual(self.data, data)
def test_credential_create_with_invalid_type(self):
arglist = [
self.credential.user_id,
self.credential.blob,
'--type', 'invalid_type',
]
verifylist = [
('user', self.credential.user_id),
('data', self.credential.blob),
('type', 'invalid_type'),
]
self.assertRaises(utils.ParserException, self.check_parser,
self.cmd, arglist, verifylist)
class TestCredentialDelete(TestCredential):
credentials = identity_fakes.FakeCredential.create_credentials(count=2)
def setUp(self):
super(TestCredentialDelete, self).setUp()
self.credentials_mock.delete.return_value = None
# Get the command object to test
self.cmd = credential.DeleteCredential(self.app, None)
def test_credential_delete(self):
arglist = [
self.credentials[0].id,
]
verifylist = [
('credential', [self.credentials[0].id]),
]
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
result = self.cmd.take_action(parsed_args)
self.credentials_mock.delete.assert_called_with(
self.credentials[0].id,
)
self.assertIsNone(result)
def test_credential_multi_delete(self):
arglist = []
for c in self.credentials:
arglist.append(c.id)
verifylist = [
('credential', arglist),
]
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
result = self.cmd.take_action(parsed_args)
calls = []
for c in self.credentials:
calls.append(call(c.id))
self.credentials_mock.delete.assert_has_calls(calls)
self.assertIsNone(result)
def test_credential_multi_delete_with_exception(self):
arglist = [
self.credentials[0].id,
'unexist_credential',
]
verifylist = [
('credential', [self.credentials[0].id, 'unexist_credential'])
]
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
delete_mock_result = [None, exceptions.CommandError]
self.credentials_mock.delete = (
mock.MagicMock(side_effect=delete_mock_result)
)
try:
self.cmd.take_action(parsed_args)
self.fail('CommandError should be raised.')
except exceptions.CommandError as e:
self.assertEqual('1 of 2 credential failed to delete.', str(e))
self.credentials_mock.delete.assert_any_call(self.credentials[0].id)
self.credentials_mock.delete.assert_any_call('unexist_credential')
class TestCredentialList(TestCredential):
credential = identity_fakes.FakeCredential.create_one_credential()
columns = ('ID', 'Type', 'User ID', 'Data', 'Project ID')
data = ((
credential.id,
credential.type,
credential.user_id,
credential.blob,
credential.project_id,
), )
def setUp(self):
super(TestCredentialList, self).setUp()
self.credentials_mock.list.return_value = [self.credential]
# Get the command object to test
self.cmd = credential.ListCredential(self.app, None)
def test_domain_list_no_options(self):
arglist = []
verifylist = []
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
columns, data = self.cmd.take_action(parsed_args)
self.credentials_mock.list.assert_called_with()
self.assertEqual(self.columns, columns)
self.assertEqual(self.data, tuple(data))
class TestCredentialSet(TestCredential): class TestCredentialSet(TestCredential):
credential = identity_fakes.FakeCredential.create_one_credential()
def setUp(self): def setUp(self):
super(TestCredentialSet, self).setUp() super(TestCredentialSet, self).setUp()
self.cmd = credential.SetCredential(self.app, None) self.cmd = credential.SetCredential(self.app, None)
def test_credential_set_no_options(self): def test_credential_set_no_options(self):
arglist = [ arglist = [
identity_fakes.credential_id, self.credential.id,
] ]
self.assertRaises(utils.ParserException, self.assertRaises(utils.ParserException,
@ -62,8 +261,8 @@ class TestCredentialSet(TestCredential):
def test_credential_set_missing_user(self): def test_credential_set_missing_user(self):
arglist = [ arglist = [
'--type', 'ec2', '--type', 'ec2',
'--data', self.json_data, '--data', self.credential.blob,
identity_fakes.credential_id, self.credential.id,
] ]
self.assertRaises(utils.ParserException, self.assertRaises(utils.ParserException,
@ -71,9 +270,9 @@ class TestCredentialSet(TestCredential):
def test_credential_set_missing_type(self): def test_credential_set_missing_type(self):
arglist = [ arglist = [
'--user', identity_fakes.user_name, '--user', self.credential.user_id,
'--data', self.json_data, '--data', self.credential.blob,
identity_fakes.credential_id, self.credential.id,
] ]
self.assertRaises(utils.ParserException, self.assertRaises(utils.ParserException,
@ -81,9 +280,9 @@ class TestCredentialSet(TestCredential):
def test_credential_set_missing_data(self): def test_credential_set_missing_data(self):
arglist = [ arglist = [
'--user', identity_fakes.user_name, '--user', self.credential.user_id,
'--type', 'ec2', '--type', 'ec2',
identity_fakes.credential_id, self.credential.id,
] ]
self.assertRaises(utils.ParserException, self.assertRaises(utils.ParserException,
@ -91,10 +290,10 @@ class TestCredentialSet(TestCredential):
def test_credential_set_valid(self): def test_credential_set_valid(self):
arglist = [ arglist = [
'--user', identity_fakes.user_name, '--user', self.credential.user_id,
'--type', 'ec2', '--type', 'ec2',
'--data', self.json_data, '--data', self.credential.blob,
identity_fakes.credential_id, self.credential.id,
] ]
parsed_args = self.check_parser(self.cmd, arglist, []) parsed_args = self.check_parser(self.cmd, arglist, [])
@ -104,14 +303,55 @@ class TestCredentialSet(TestCredential):
def test_credential_set_valid_with_project(self): def test_credential_set_valid_with_project(self):
arglist = [ arglist = [
'--user', identity_fakes.user_name, '--user', self.credential.user_id,
'--type', 'ec2', '--type', 'ec2',
'--data', self.json_data, '--data', self.credential.blob,
'--project', identity_fakes.project_name, '--project', self.credential.project_id,
identity_fakes.credential_id, self.credential.id,
] ]
parsed_args = self.check_parser(self.cmd, arglist, []) parsed_args = self.check_parser(self.cmd, arglist, [])
result = self.cmd.take_action(parsed_args) result = self.cmd.take_action(parsed_args)
self.assertIsNone(result) self.assertIsNone(result)
class TestCredentialShow(TestCredential):
columns = (
'blob',
'id',
'project_id',
'type',
'user_id',
)
def setUp(self):
super(TestCredentialShow, self).setUp()
self.credential = identity_fakes.FakeCredential.create_one_credential()
self.credentials_mock.get.return_value = self.credential
self.data = (
self.credential.blob,
self.credential.id,
self.credential.project_id,
self.credential.type,
self.credential.user_id,
)
self.cmd = credential.ShowCredential(self.app, None)
def test_credential_show(self):
arglist = [
self.credential.id,
]
verifylist = [
('credential', self.credential.id),
]
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
columns, data = self.cmd.take_action(parsed_args)
self.credentials_mock.get.assert_called_once_with(self.credential.id)
self.assertEqual(self.columns, columns)
self.assertEqual(self.data, data)