Add remove-group-pkg CLI command

Fixes: https://pagure.io/koji/issue/3199
This commit is contained in:
Jana Cupova 2022-01-03 08:13:00 +01:00 committed by Mike McLean
parent f2b13a9ae2
commit f7464aec2c
4 changed files with 131 additions and 0 deletions

View file

@ -3100,6 +3100,26 @@ def handle_add_group_pkg(goptions, session, args):
session.groupPackageListAdd(tag, group, pkg)
def handle_remove_group_pkg(goptions, session, args):
"[admin] Remove a package from a group's package listing"
usage = "usage: %prog remove-group-pkg [options] <tag> <group> <pkg> [<pkg> ...]"
parser = OptionParser(usage=get_usage_str(usage))
parser.add_option("--force", action='store_true', help="Override blocks if necessary")
(options, args) = parser.parse_args(args)
if len(args) < 3:
parser.error("You must specify a tag name, group name, and one or more package names")
tag = args[0]
group = args[1]
opts = {}
opts['force'] = options.force
activate_session(session, goptions)
dsttag = session.getTag(tag)
if dsttag is None:
error("No such tag: %s" % tag)
with session.multicall() as m:
[m.groupPackageListRemove(tag, group, pkg, **opts) for pkg in args[2:]]
def handle_block_group_pkg(goptions, session, args):
"[admin] Block a package from a group's package listing"
usage = "usage: %prog block-group-pkg [options] <tag> <group> <pkg> [<pkg> ...]"

View file

@ -49,6 +49,7 @@ admin commands:
regen-repo Generate a current repo if there is not one
remove-external-repo Remove an external repo from a tag or tags, or remove entirely
remove-group Remove group from tag
remove-group-pkg Remove a package from a group's package listing
remove-host-from-channel Remove a host from a channel
remove-pkg Remove a package from the listing for tag
remove-sig Remove signed RPMs from db and disk

View file

@ -49,6 +49,7 @@ admin commands:
regen-repo Generate a current repo if there is not one
remove-external-repo Remove an external repo from a tag or tags, or remove entirely
remove-group Remove group from tag
remove-group-pkg Remove a package from a group's package listing
remove-host-from-channel Remove a host from a channel
remove-pkg Remove a package from the listing for tag
remove-sig Remove signed RPMs from db and disk

View file

@ -0,0 +1,109 @@
from __future__ import absolute_import
import mock
import six
from koji_cli.commands import handle_remove_group_pkg
import koji
from . import utils
class TestRemoveGroupPkg(utils.CliTestCase):
def setUp(self):
# Show long diffs in error output...
self.maxDiff = None
self.options = mock.MagicMock()
self.options.debug = False
self.session = mock.MagicMock()
self.session.getAPIVersion.return_value = koji.API_VERSION
self.activate_session_mock = mock.patch('koji_cli.commands.activate_session').start()
self.error_format = """Usage: %s remove-group-pkg [options] <tag> <group> <pkg> [<pkg> ...]
(Specify the --help global option for a list of other help options)
%s: error: {message}
""" % (self.progname, self.progname)
def test_handle_remove_pkg_not_existing_tag(self):
tag = 'tag'
package = 'package'
group = 'group'
args = [tag, group, package]
self.session.getTag.return_value = None
self.assert_system_exit(
handle_remove_group_pkg,
self.options, self.session, args,
stderr='No such tag: %s\n' % tag,
stdout='',
activate_session=None,
exit_code=1)
# 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.groupPackageListRemove.assert_not_called()
self.session.multiCall.assert_not_called()
def test_handle_remove_pkg_wrong_count_args(self):
tag = 'tag'
group = 'group'
args = [tag, group]
expected_error = self.format_error_message(
'You must specify a tag name, group name, and one or more package names')
self.assert_system_exit(
handle_remove_group_pkg,
self.options, self.session, args,
stderr=expected_error,
stdout='',
activate_session=None,
exit_code=2)
# Finally, assert that things were called as we expected.
self.activate_session_mock.assert_not_called()
self.session.getTag.assert_not_called()
self.session.groupPackageListRemove.assert_not_called()
self.session.multiCall.assert_not_called()
@mock.patch('sys.stdout', new_callable=six.StringIO)
@mock.patch('sys.stderr', new_callable=six.StringIO)
def test_handle_remove_pkg(self, stderr, stdout):
tag = 'tag'
dsttag = {'name': tag, 'id': 1}
package = 'package'
group = 'group'
args = [tag, group, package]
self.session.getTag.return_value = dsttag
self.session.groupPackageListRemove.return_value = None
handle_remove_group_pkg(self.options, self.session, args)
actual = stderr.getvalue()
expected = ''
self.assertMultiLineEqual(actual, expected)
actual = stdout.getvalue()
expected = ''
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)
@mock.patch('sys.stdout', new_callable=six.StringIO)
@mock.patch('sys.stderr', new_callable=six.StringIO)
def test_handle_remove_pkg_with_force(self, stderr, stdout):
tag = 'tag'
dsttag = {'name': tag, 'id': 1}
package = 'package'
group = 'group'
args = [tag, group, package, '--force']
self.session.getTag.return_value = dsttag
self.session.groupPackageListRemove.return_value = None
handle_remove_group_pkg(self.options, self.session, args)
actual = stderr.getvalue()
expected = ''
self.assertMultiLineEqual(actual, expected)
actual = stdout.getvalue()
expected = ''
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)