Add remove-group-pkg CLI command
Fixes: https://pagure.io/koji/issue/3199
This commit is contained in:
parent
f2b13a9ae2
commit
f7464aec2c
4 changed files with 131 additions and 0 deletions
|
|
@ -3100,6 +3100,26 @@ def handle_add_group_pkg(goptions, session, args):
|
||||||
session.groupPackageListAdd(tag, group, pkg)
|
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):
|
def handle_block_group_pkg(goptions, session, args):
|
||||||
"[admin] Block a package from a group's package listing"
|
"[admin] Block a package from a group's package listing"
|
||||||
usage = "usage: %prog block-group-pkg [options] <tag> <group> <pkg> [<pkg> ...]"
|
usage = "usage: %prog block-group-pkg [options] <tag> <group> <pkg> [<pkg> ...]"
|
||||||
|
|
|
||||||
|
|
@ -49,6 +49,7 @@ admin commands:
|
||||||
regen-repo Generate a current repo if there is not one
|
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-external-repo Remove an external repo from a tag or tags, or remove entirely
|
||||||
remove-group Remove group from tag
|
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-host-from-channel Remove a host from a channel
|
||||||
remove-pkg Remove a package from the listing for tag
|
remove-pkg Remove a package from the listing for tag
|
||||||
remove-sig Remove signed RPMs from db and disk
|
remove-sig Remove signed RPMs from db and disk
|
||||||
|
|
|
||||||
|
|
@ -49,6 +49,7 @@ admin commands:
|
||||||
regen-repo Generate a current repo if there is not one
|
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-external-repo Remove an external repo from a tag or tags, or remove entirely
|
||||||
remove-group Remove group from tag
|
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-host-from-channel Remove a host from a channel
|
||||||
remove-pkg Remove a package from the listing for tag
|
remove-pkg Remove a package from the listing for tag
|
||||||
remove-sig Remove signed RPMs from db and disk
|
remove-sig Remove signed RPMs from db and disk
|
||||||
|
|
|
||||||
109
tests/test_cli/test_remove_group_pkg.py
Normal file
109
tests/test_cli/test_remove_group_pkg.py
Normal 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)
|
||||||
Loading…
Add table
Add a link
Reference in a new issue