cli: list-builds sort-key warning
Fixes: https://pagure.io/koji/issue/2587 Fixes: https://pagure.io/koji/issue/2588
This commit is contained in:
parent
8d13743e1b
commit
8b1fbc45be
2 changed files with 196 additions and 1 deletions
|
|
@ -10,10 +10,13 @@ from . import utils
|
|||
|
||||
class TestListBuilds(utils.CliTestCase):
|
||||
def setUp(self):
|
||||
self.maxDiff = None
|
||||
self.options = mock.MagicMock()
|
||||
self.options.debug = False
|
||||
self.session = mock.MagicMock()
|
||||
self.session.getAPIVersion.return_value = koji.API_VERSION
|
||||
self.user_info = {'id': 1, 'name': 'kojiadmin', 'status': 0, 'usertype': 0,
|
||||
'krb_principals': []}
|
||||
|
||||
@mock.patch('sys.stderr', new_callable=StringIO)
|
||||
def test_list_builds_without_option(self, stderr):
|
||||
|
|
@ -102,3 +105,189 @@ class TestListBuilds(utils.CliTestCase):
|
|||
['--build', build])
|
||||
self.assertExitCode(ex, 2)
|
||||
self.assert_console_message(stderr, expected)
|
||||
|
||||
@mock.patch('sys.stderr', new_callable=StringIO)
|
||||
@mock.patch('sys.stdout', new_callable=StringIO)
|
||||
def test_list_builds_invalid_key(self, stdout, stderr):
|
||||
list_build = [{'build_id': 1, 'epoch': 34, 'name': 'test-build',
|
||||
'nvr': 'test-build-11-12', 'owner_name': 'kojiadmin',
|
||||
'release': '12', 'state': 1, 'version': '11'},
|
||||
{'build_id': 4, 'epoch': 34, 'name': 'test-jx-build',
|
||||
'nvr': 'test-jx-build-11-12', 'owner_name': 'kojiadmin',
|
||||
'release': '12', 'state': 1, 'version': '11'},
|
||||
{'build_id': 2, 'epoch': 34, 'name': 'test-ax-build',
|
||||
'nvr': 'test-ax-build-11-12', 'owner_name': 'kojiadmin',
|
||||
'release': '12', 'state': 4, 'version': '11'},
|
||||
{'build_id': 3, 'epoch': 34, 'name': 'test-zx-build',
|
||||
'nvr': 'test-zx-build-11-12', 'owner_name': 'kojiadmin',
|
||||
'release': '12', 'state': 4, 'version': '11'}, ]
|
||||
test_key = 'test-key'
|
||||
expected_warn = "Invalid sort_key: %s." % test_key
|
||||
expected_output = """test-build-11-12 kojiadmin COMPLETE
|
||||
test-jx-build-11-12 kojiadmin COMPLETE
|
||||
test-ax-build-11-12 kojiadmin CANCELED
|
||||
test-zx-build-11-12 kojiadmin CANCELED
|
||||
"""
|
||||
self.session.getUser.return_value = self.user_info
|
||||
self.session.listBuilds.return_value = list_build
|
||||
rv = anon_handle_list_builds(self.options, self.session, ['--owner', 'kojiadmin',
|
||||
'--sort-key', test_key])
|
||||
self.assertEqual(rv, None)
|
||||
self.assert_console_message(stdout, expected_output)
|
||||
self.assert_console_message(stderr, "%s\n" % expected_warn)
|
||||
|
||||
@mock.patch('sys.stdout', new_callable=StringIO)
|
||||
def test_list_builds_opt_owner_sorted_nvr(self, stdout):
|
||||
list_build = [{'build_id': 1, 'epoch': 34, 'name': 'test-build',
|
||||
'nvr': 'test-build-11-12', 'owner_name': 'kojiadmin',
|
||||
'release': '12', 'state': 1, 'version': '11'},
|
||||
{'build_id': 4, 'epoch': 34, 'name': 'test-jx-build',
|
||||
'nvr': 'test-build-8-12', 'owner_name': 'kojiadmin',
|
||||
'release': '12', 'state': 1, 'version': '8'},
|
||||
{'build_id': 2, 'epoch': 34, 'name': 'test-ax-build',
|
||||
'nvr': 'test-build-11-9', 'owner_name': 'kojiadmin',
|
||||
'release': '9', 'state': 4, 'version': '11'},
|
||||
{'build_id': 3, 'epoch': 34, 'name': 'test-zx-build',
|
||||
'nvr': 'test-build-10-12', 'owner_name': 'kojiadmin',
|
||||
'release': '12', 'state': 4, 'version': '10'}, ]
|
||||
expected_output = """test-build-10-12 kojiadmin CANCELED
|
||||
test-build-11-12 kojiadmin COMPLETE
|
||||
test-build-11-9 kojiadmin CANCELED
|
||||
test-build-8-12 kojiadmin COMPLETE
|
||||
"""
|
||||
self.session.getUser.return_value = self.user_info
|
||||
self.session.listBuilds.return_value = list_build
|
||||
rv = anon_handle_list_builds(self.options, self.session, ['--owner', 'kojiadmin',
|
||||
'--sort-key', 'nvr'])
|
||||
self.assertEqual(rv, None)
|
||||
self.assert_console_message(stdout, expected_output)
|
||||
|
||||
@mock.patch('sys.stdout', new_callable=StringIO)
|
||||
def test_list_builds_opt_owner_sorted_state(self, stdout):
|
||||
list_build = [{'build_id': 1, 'epoch': 34, 'name': 'test-build',
|
||||
'nvr': 'test-build-11-12', 'owner_name': 'kojiadmin',
|
||||
'release': '12', 'state': 1, 'version': '11'},
|
||||
{'build_id': 4, 'epoch': 34, 'name': 'test-jx-build',
|
||||
'nvr': 'test-build-8-12', 'owner_name': 'kojiadmin',
|
||||
'release': '12', 'state': 1, 'version': '8'},
|
||||
{'build_id': 2, 'epoch': 34, 'name': 'test-ax-build',
|
||||
'nvr': 'test-build-11-9', 'owner_name': 'kojiadmin',
|
||||
'release': '9', 'state': 4, 'version': '11'},
|
||||
{'build_id': 3, 'epoch': 34, 'name': 'test-zx-build',
|
||||
'nvr': 'test-build-10-12', 'owner_name': 'kojiadmin',
|
||||
'release': '12', 'state': 4, 'version': '10'}, ]
|
||||
expected_output = """test-build-11-12 kojiadmin COMPLETE
|
||||
test-build-8-12 kojiadmin COMPLETE
|
||||
test-build-11-9 kojiadmin CANCELED
|
||||
test-build-10-12 kojiadmin CANCELED
|
||||
"""
|
||||
self.session.getUser.return_value = self.user_info
|
||||
self.session.listBuilds.return_value = list_build
|
||||
rv = anon_handle_list_builds(self.options, self.session, ['--owner', 'kojiadmin',
|
||||
'--sort-key', 'state'])
|
||||
self.assertEqual(rv, None)
|
||||
self.assert_console_message(stdout, expected_output)
|
||||
|
||||
@mock.patch('sys.stdout', new_callable=StringIO)
|
||||
def test_list_builds_opt_owner_sorted_state_nvr(self, stdout):
|
||||
list_build = [{'build_id': 1, 'epoch': 34, 'name': 'test-build',
|
||||
'nvr': 'test-build-11-12', 'owner_name': 'kojiadmin',
|
||||
'release': '12', 'state': 1, 'version': '11'},
|
||||
{'build_id': 4, 'epoch': 34, 'name': 'test-jx-build',
|
||||
'nvr': 'test-build-8-12', 'owner_name': 'kojiadmin',
|
||||
'release': '12', 'state': 1, 'version': '8'},
|
||||
{'build_id': 2, 'epoch': 34, 'name': 'test-ax-build',
|
||||
'nvr': 'test-build-11-9', 'owner_name': 'kojiadmin',
|
||||
'release': '9', 'state': 4, 'version': '11'},
|
||||
{'build_id': 3, 'epoch': 34, 'name': 'test-zx-build',
|
||||
'nvr': 'test-build-10-12', 'owner_name': 'kojiadmin',
|
||||
'release': '12', 'state': 4, 'version': '10'}, ]
|
||||
expected_output = """test-build-11-12 kojiadmin COMPLETE
|
||||
test-build-8-12 kojiadmin COMPLETE
|
||||
test-build-10-12 kojiadmin CANCELED
|
||||
test-build-11-9 kojiadmin CANCELED
|
||||
"""
|
||||
self.session.getUser.return_value = self.user_info
|
||||
self.session.listBuilds.return_value = list_build
|
||||
rv = anon_handle_list_builds(self.options, self.session, ['--owner', 'kojiadmin',
|
||||
'--sort-key', 'state',
|
||||
'--sort-key', 'nvr'])
|
||||
self.assertEqual(rv, None)
|
||||
self.assert_console_message(stdout, expected_output)
|
||||
|
||||
@mock.patch('sys.stdout', new_callable=StringIO)
|
||||
def test_list_builds_opt_prefix_sorted_owner(self, stdout):
|
||||
list_build = [{'build_id': 1, 'epoch': 34, 'name': 'test-build',
|
||||
'nvr': 'test-build-11-12', 'owner_name': 'kojiadmin',
|
||||
'release': '12', 'state': 1, 'version': '11'},
|
||||
{'build_id': 4, 'epoch': 34, 'name': 'test-jx-build',
|
||||
'nvr': 'test-build-8-12', 'owner_name': 'kojitest',
|
||||
'release': '12', 'state': 1, 'version': '8'},
|
||||
{'build_id': 2, 'epoch': 34, 'name': 'test-ax-build',
|
||||
'nvr': 'test-build-11-9', 'owner_name': 'kojitest',
|
||||
'release': '9', 'state': 4, 'version': '11'},
|
||||
{'build_id': 3, 'epoch': 34, 'name': 'test-zx-build',
|
||||
'nvr': 'test-build-10-12', 'owner_name': 'kojiadmin',
|
||||
'release': '12', 'state': 4, 'version': '10'}, ]
|
||||
expected_output = """test-build-11-12 kojiadmin COMPLETE
|
||||
test-build-10-12 kojiadmin CANCELED
|
||||
test-build-8-12 kojitest COMPLETE
|
||||
test-build-11-9 kojitest CANCELED
|
||||
"""
|
||||
self.session.listBuilds.return_value = list_build
|
||||
rv = anon_handle_list_builds(self.options, self.session, ['--prefix', 'test-build',
|
||||
'--sort-key', 'owner_name'])
|
||||
self.assertEqual(rv, None)
|
||||
self.assert_console_message(stdout, expected_output)
|
||||
|
||||
@mock.patch('sys.stdout', new_callable=StringIO)
|
||||
def test_list_builds_opt_prefix_sorted_owner_nvr(self, stdout):
|
||||
list_build = [{'build_id': 1, 'epoch': 34, 'name': 'test-build',
|
||||
'nvr': 'test-build-11-12', 'owner_name': 'kojiadmin',
|
||||
'release': '12', 'state': 1, 'version': '11'},
|
||||
{'build_id': 4, 'epoch': 34, 'name': 'test-jx-build',
|
||||
'nvr': 'test-build-8-12', 'owner_name': 'kojitest',
|
||||
'release': '12', 'state': 1, 'version': '8'},
|
||||
{'build_id': 2, 'epoch': 34, 'name': 'test-ax-build',
|
||||
'nvr': 'test-build-11-9', 'owner_name': 'kojitest',
|
||||
'release': '9', 'state': 4, 'version': '11'},
|
||||
{'build_id': 3, 'epoch': 34, 'name': 'test-zx-build',
|
||||
'nvr': 'test-build-10-12', 'owner_name': 'kojiadmin',
|
||||
'release': '12', 'state': 4, 'version': '10'}, ]
|
||||
expected_output = """test-build-10-12 kojiadmin CANCELED
|
||||
test-build-11-12 kojiadmin COMPLETE
|
||||
test-build-11-9 kojitest CANCELED
|
||||
test-build-8-12 kojitest COMPLETE
|
||||
"""
|
||||
self.session.listBuilds.return_value = list_build
|
||||
rv = anon_handle_list_builds(self.options, self.session, ['--prefix', 'test-build',
|
||||
'--sort-key', 'owner_name',
|
||||
'--sort-key', 'nvr'])
|
||||
self.assertEqual(rv, None)
|
||||
self.assert_console_message(stdout, expected_output)
|
||||
|
||||
@mock.patch('sys.stdout', new_callable=StringIO)
|
||||
def test_list_builds_opt_owner_reverse(self, stdout):
|
||||
list_build = [{'build_id': 1, 'epoch': 34, 'name': 'test-build',
|
||||
'nvr': 'test-build-11-12', 'owner_name': 'kojiadmin',
|
||||
'release': '12', 'state': 1, 'version': '11'},
|
||||
{'build_id': 4, 'epoch': 34, 'name': 'test-jx-build',
|
||||
'nvr': 'test-build-8-12', 'owner_name': 'kojiadmin',
|
||||
'release': '12', 'state': 1, 'version': '8'},
|
||||
{'build_id': 2, 'epoch': 34, 'name': 'test-ax-build',
|
||||
'nvr': 'test-build-11-9', 'owner_name': 'kojiadmin',
|
||||
'release': '9', 'state': 4, 'version': '11'},
|
||||
{'build_id': 3, 'epoch': 34, 'name': 'test-zx-build',
|
||||
'nvr': 'test-build-10-12', 'owner_name': 'kojiadmin',
|
||||
'release': '12', 'state': 4, 'version': '10'}, ]
|
||||
expected_output = """test-build-8-12 kojiadmin COMPLETE
|
||||
test-build-11-9 kojiadmin CANCELED
|
||||
test-build-11-12 kojiadmin COMPLETE
|
||||
test-build-10-12 kojiadmin CANCELED
|
||||
"""
|
||||
self.session.getUser.return_value = self.user_info
|
||||
self.session.listBuilds.return_value = list_build
|
||||
rv = anon_handle_list_builds(self.options, self.session, ['--owner', 'kojiadmin',
|
||||
'--reverse'])
|
||||
self.assertEqual(rv, None)
|
||||
self.assert_console_message(stdout, expected_output)
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue