Increase CLI unit tests
This commit is contained in:
parent
e3aeb0c1f1
commit
4c50c5fe92
2 changed files with 154 additions and 53 deletions
|
|
@ -201,6 +201,35 @@ class TestAddPkg(utils.CliTestCase):
|
|||
self.session.listPackages.assert_not_called()
|
||||
self.session.packageListAdd.assert_not_called()
|
||||
|
||||
@mock.patch('sys.stdout', new_callable=six.StringIO)
|
||||
def test_handle_add_pkg_parameter_error(self, stdout):
|
||||
tag = 'tag'
|
||||
dsttag = {'name': tag, 'id': 1}
|
||||
package = 'package'
|
||||
owner = 'testuser'
|
||||
args = ['--owner', owner, tag, package]
|
||||
|
||||
self.session.getTag.return_value = dsttag
|
||||
self.session.listPackages.side_effect = [koji.ParameterError, []]
|
||||
# Run it and check immediate output
|
||||
# args: tag, package
|
||||
# expected: success
|
||||
rv = handle_add_pkg(self.options, self.session, args)
|
||||
actual = stdout.getvalue()
|
||||
expected = 'Adding 1 packages to tag tag\n'
|
||||
self.assertMultiLineEqual(actual, expected)
|
||||
# Finally, assert that things were called as we expected.
|
||||
self.activate_session_mock.assert_called_once_with(self.session, self.options)
|
||||
self.session.getTag.assert_called_once_with(tag)
|
||||
self.session.listPackages.assert_has_calls([
|
||||
call(tagID=dsttag['id'], with_owners=False),
|
||||
call(tagID=dsttag['id'])
|
||||
])
|
||||
self.session.packageListAdd.assert_called_once_with(
|
||||
tag, package, owner, block=False, force=None)
|
||||
self.session.multiCall.assert_called_once_with(strict=True)
|
||||
self.assertFalse(rv)
|
||||
|
||||
|
||||
if __name__ == '__main__':
|
||||
unittest.main()
|
||||
|
|
|
|||
|
|
@ -9,9 +9,6 @@ from . import utils
|
|||
|
||||
class TestListPermissions(utils.CliTestCase):
|
||||
|
||||
# Show long diffs in error output...
|
||||
maxDiff = None
|
||||
|
||||
def setUp(self):
|
||||
self.error_format = """Usage: %s list-permissions [options]
|
||||
(Specify the --help global option for a list of other help options)
|
||||
|
|
@ -19,87 +16,162 @@ class TestListPermissions(utils.CliTestCase):
|
|||
%s: error: {message}
|
||||
""" % (self.progname, self.progname)
|
||||
|
||||
@mock.patch('sys.stderr', new_callable=six.StringIO)
|
||||
@mock.patch('sys.stdout', new_callable=six.StringIO)
|
||||
@mock.patch('koji_cli.commands.activate_session')
|
||||
def test_handle_list_permissions(
|
||||
self,
|
||||
activate_session_mock,
|
||||
stdout,
|
||||
stderr):
|
||||
"""Test handle_list_permissions function"""
|
||||
session = mock.MagicMock()
|
||||
options = mock.MagicMock()
|
||||
user = 'tester'
|
||||
all_perms = [
|
||||
self.session = mock.MagicMock()
|
||||
self.activate_session_mock = mock.patch('koji_cli.commands.activate_session').start()
|
||||
self.options = mock.MagicMock()
|
||||
self.options.quiet = True
|
||||
# Show long diffs in error output...
|
||||
self.maxDiff = None
|
||||
self.all_perms = [
|
||||
{'id': 0, 'name': 'admin', 'description': 'admin-description'},
|
||||
{'id': 1, 'name': 'build', 'description': 'build-description'},
|
||||
{'id': 2, 'name': 'repo', 'description': 'repo-description'},
|
||||
{'id': 3, 'name': 'image', 'description': 'image-description'},
|
||||
{'id': 4, 'name': 'livecd', 'description': 'livecd-description'},
|
||||
{'id': 5, 'name': 'appliance', 'description': 'appliance-description'}
|
||||
{'id': 5, 'name': 'appliance', 'description': 'appliance-description'},
|
||||
{'id': 6, 'name': 'long-permission-appliance',
|
||||
'description': 'long-permission-appliance-description'}
|
||||
]
|
||||
self.user = 'tester'
|
||||
self.userinfo = {'id': 101, 'name': self.user}
|
||||
|
||||
# case 1. argument error (no argument is required)
|
||||
def test_handle_list_permissions_arg_error(self):
|
||||
"""Test handle_list_permissions argument error (no argument is required)"""
|
||||
expected = self.format_error_message("This command takes no arguments")
|
||||
self.assert_system_exit(
|
||||
handle_list_permissions,
|
||||
options,
|
||||
session,
|
||||
self.options,
|
||||
self.session,
|
||||
['arg-1', 'arg-2'],
|
||||
stderr=expected,
|
||||
activate_session=None)
|
||||
activate_session=None,
|
||||
exit_code=2
|
||||
)
|
||||
self.activate_session_mock.assert_not_called()
|
||||
self.session.getUser.assert_not_called()
|
||||
self.session.getUserPerms.assert_not_called()
|
||||
self.session.getPerms.assert_not_called()
|
||||
self.session.getAllPerms.assert_not_called()
|
||||
|
||||
# case 2. user does not exists
|
||||
expected = "No such user: %s" % user + "\n"
|
||||
session.getUser.return_value = None
|
||||
with self.assertRaises(SystemExit) as ex:
|
||||
handle_list_permissions(options, session, ['--user', user])
|
||||
self.assertExitCode(ex, 1)
|
||||
self.assert_console_message(stderr, expected)
|
||||
def test_handle_list_permissions_user_not_exists(self):
|
||||
"""Test handle_list_permissions user does not exists"""
|
||||
self.session.getUser.return_value = None
|
||||
self.assert_system_exit(
|
||||
handle_list_permissions,
|
||||
self.options,
|
||||
self.session,
|
||||
['--user', self.user],
|
||||
stderr="No such user: %s" % self.user + "\n",
|
||||
activate_session=None,
|
||||
exit_code=1
|
||||
)
|
||||
self.activate_session_mock.assert_called_once()
|
||||
self.session.getUser.assert_called_once()
|
||||
self.session.getUserPerms.assert_not_called()
|
||||
self.session.getPerms.assert_not_called()
|
||||
self.session.getAllPerms.assert_not_called()
|
||||
|
||||
# case 3. List user permission
|
||||
perms = [p['name'] for p in all_perms[::1]]
|
||||
session.getUserPerms.return_value = perms
|
||||
session.getUser.return_value = {'id': 101, 'name': user}
|
||||
expected = """admin
|
||||
build
|
||||
repo
|
||||
image
|
||||
livecd
|
||||
appliance
|
||||
@mock.patch('sys.stdout', new_callable=six.StringIO)
|
||||
def test_handle_list_permissions_empty_perms(self, stdout):
|
||||
"""Test handle_list_permissions that perms is empty"""
|
||||
expected = """Permission name
|
||||
"""
|
||||
handle_list_permissions(options, session, ['--user', user])
|
||||
self.options.quiet = False
|
||||
self.session.getUser.return_value = self.userinfo
|
||||
self.session.getUserPerms.return_value = []
|
||||
handle_list_permissions(self.options, self.session, ['--user', self.user])
|
||||
self.assert_console_message(stdout, expected)
|
||||
|
||||
session.getUserPerms.reset_mock()
|
||||
self.activate_session_mock.assert_called_once()
|
||||
self.session.getUser.assert_called_once()
|
||||
self.session.getUserPerms.assert_called_once()
|
||||
self.session.getPerms.assert_not_called()
|
||||
self.session.getAllPerms.assert_not_called()
|
||||
|
||||
# case 4. List my permission
|
||||
perms = [p['name'] for p in all_perms[1:3]]
|
||||
session.getPerms.return_value = perms
|
||||
@mock.patch('sys.stdout', new_callable=six.StringIO)
|
||||
def test_handle_list_permissions_user_perms(self, stdout):
|
||||
"""Test handle_list_permissions user permissions"""
|
||||
expected = """admin
|
||||
build
|
||||
repo
|
||||
image
|
||||
livecd
|
||||
appliance
|
||||
long-permission-appliance
|
||||
"""
|
||||
perms = [p['name'] for p in self.all_perms[::1]]
|
||||
self.session.getUserPerms.return_value = perms
|
||||
self.session.getUser.return_value = self.userinfo
|
||||
handle_list_permissions(self.options, self.session, ['--user', self.user])
|
||||
self.assert_console_message(stdout, expected)
|
||||
|
||||
self.activate_session_mock.assert_called_once()
|
||||
self.session.getUser.assert_called_once()
|
||||
self.session.getUserPerms.assert_called_once()
|
||||
self.session.getPerms.assert_not_called()
|
||||
self.session.getAllPerms.assert_not_called()
|
||||
|
||||
@mock.patch('sys.stdout', new_callable=six.StringIO)
|
||||
def test_handle_list_permissions_my_perms(self, stdout):
|
||||
"""Test handle_list_permissions my permissions"""
|
||||
expected = """build
|
||||
repo
|
||||
"""
|
||||
handle_list_permissions(options, session, ['--mine'])
|
||||
perms = [p['name'] for p in self.all_perms[1:3]]
|
||||
self.session.getPerms.return_value = perms
|
||||
handle_list_permissions(self.options, self.session, ['--mine'])
|
||||
self.assert_console_message(stdout, expected)
|
||||
session.getUserPerms.assert_not_called()
|
||||
|
||||
session.getPerms.reset_mock()
|
||||
self.activate_session_mock.assert_called_once()
|
||||
self.session.getUser.assert_not_called()
|
||||
self.session.getUserPerms.assert_not_called()
|
||||
self.session.getPerms.assert_called_once()
|
||||
self.session.getAllPerms.assert_not_called()
|
||||
|
||||
# case 5. List all permission
|
||||
session.getAllPerms.return_value = all_perms
|
||||
expected = """admin admin-description
|
||||
@mock.patch('sys.stdout', new_callable=six.StringIO)
|
||||
def test_handle_list_permissions_all_perms_quiet_false(self, stdout):
|
||||
"""Test handle_list_permissions all permissions and quiet is false"""
|
||||
self.options.quiet = False
|
||||
expected = """Permission name Description
|
||||
admin admin-description
|
||||
build build-description
|
||||
repo repo-description
|
||||
image image-description
|
||||
livecd livecd-description
|
||||
appliance appliance-description
|
||||
long-permission-appliance long-permission-appliance-description
|
||||
"""
|
||||
self.session.getAllPerms.return_value = self.all_perms
|
||||
handle_list_permissions(self.options, self.session, [])
|
||||
self.assert_console_message(stdout, expected)
|
||||
|
||||
self.activate_session_mock.assert_called_once()
|
||||
self.session.getUser.assert_not_called()
|
||||
self.session.getUserPerms.assert_not_called()
|
||||
self.session.getPerms.assert_not_called()
|
||||
self.session.getAllPerms.assert_called_once()
|
||||
|
||||
@mock.patch('sys.stdout', new_callable=six.StringIO)
|
||||
def test_handle_list_permissions_all_perms_length_shorter_eight(self, stdout):
|
||||
"""Test handle_list_permissions all permissions, length perms shorter than eight"""
|
||||
self.options.quiet = False
|
||||
expected = """Permission name Description
|
||||
admin admin-description
|
||||
build build-description
|
||||
repo repo-description
|
||||
image image-description
|
||||
livecd livecd-description
|
||||
appliance appliance-description
|
||||
"""
|
||||
handle_list_permissions(options, session, [])
|
||||
self.session.getAllPerms.return_value = self.all_perms[:-1]
|
||||
handle_list_permissions(self.options, self.session, [])
|
||||
self.assert_console_message(stdout, expected)
|
||||
session.getUserPerms.assert_not_called()
|
||||
session.getPerms.assert_not_called()
|
||||
session.getAllPerms.assert_called_once()
|
||||
|
||||
self.activate_session_mock.assert_called_once()
|
||||
self.session.getUser.assert_not_called()
|
||||
self.session.getUserPerms.assert_not_called()
|
||||
self.session.getPerms.assert_not_called()
|
||||
self.session.getAllPerms.assert_called_once()
|
||||
|
||||
def test_handle_list_permissions_help(self):
|
||||
self.assert_help(
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue