|
|
d2a170 |
commit 7e7f374c1ac6984fc50726dd649c4f4c2f56266c
|
|
|
d2a170 |
Author: Valentina Mukhamedzhanova <vmukhame@redhat.com>
|
|
|
d2a170 |
Date: Wed Jan 29 12:08:30 2014 -0500
|
|
|
d2a170 |
|
|
|
d2a170 |
Make 'yum install @group' give an error when trying to install a
|
|
|
d2a170 |
non-existent group.
|
|
|
d2a170 |
|
|
|
d2a170 |
diff --git a/cli.py b/cli.py
|
|
|
d2a170 |
index c8884ae..eed63a2 100755
|
|
|
d2a170 |
--- a/cli.py
|
|
|
d2a170 |
+++ b/cli.py
|
|
|
d2a170 |
@@ -964,6 +964,8 @@ class YumBaseCli(yum.YumBase, output.YumOutput):
|
|
|
d2a170 |
else:
|
|
|
d2a170 |
assert basecmd == 'install', basecmd
|
|
|
d2a170 |
txmbrs = self.install(pattern=arg)
|
|
|
d2a170 |
+ except yum.Errors.GroupInstallError, e:
|
|
|
d2a170 |
+ self.verbose_logger.log(yum.logginglevels.INFO_2, e)
|
|
|
d2a170 |
except yum.Errors.InstallError:
|
|
|
d2a170 |
self.verbose_logger.log(yum.logginglevels.INFO_2,
|
|
|
d2a170 |
_('No package %s%s%s available.'),
|
|
|
d2a170 |
@@ -1922,6 +1924,7 @@ class YumBaseCli(yum.YumBase, output.YumOutput):
|
|
|
d2a170 |
for igrp in self.igroups.groups:
|
|
|
d2a170 |
pkgs_used.extend(self._at_groupupgrade('@' + igrp))
|
|
|
d2a170 |
|
|
|
d2a170 |
+ done = False
|
|
|
d2a170 |
for group_string in grouplist:
|
|
|
d2a170 |
|
|
|
d2a170 |
grp_grp = True
|
|
|
d2a170 |
@@ -1966,11 +1969,19 @@ class YumBaseCli(yum.YumBase, output.YumOutput):
|
|
|
d2a170 |
if not group_matched:
|
|
|
d2a170 |
self.logger.error(_('Warning: group %s does not exist.'), group_string)
|
|
|
d2a170 |
continue
|
|
|
d2a170 |
+ done = True
|
|
|
d2a170 |
|
|
|
d2a170 |
if not pkgs_used:
|
|
|
d2a170 |
if self.conf.group_command == 'objects':
|
|
|
d2a170 |
self.logger.critical(_("Maybe run: yum groups mark install (see man yum)"))
|
|
|
d2a170 |
- return 0, [_('No packages in any requested group available to install or update')]
|
|
|
d2a170 |
+ exit_status = 1
|
|
|
d2a170 |
+ if upgrade:
|
|
|
d2a170 |
+ # upgrades don't fail
|
|
|
d2a170 |
+ exit_status = 0
|
|
|
d2a170 |
+ if done:
|
|
|
d2a170 |
+ # at least one group_string was a valid group
|
|
|
d2a170 |
+ exit_status = 0
|
|
|
d2a170 |
+ return exit_status, [_('No packages in any requested group available to install or update')]
|
|
|
d2a170 |
else:
|
|
|
d2a170 |
return 2, [P_('%d package to Install', '%d packages to Install', len(pkgs_used)) % len(pkgs_used)]
|
|
|
d2a170 |
|
|
|
d2a170 |
diff --git a/yum/Errors.py b/yum/Errors.py
|
|
|
d2a170 |
index 70de539..2c2f022 100644
|
|
|
d2a170 |
--- a/yum/Errors.py
|
|
|
d2a170 |
+++ b/yum/Errors.py
|
|
|
d2a170 |
@@ -105,6 +105,9 @@ class GroupsError(YumBaseError):
|
|
|
d2a170 |
class InstallError(YumBaseError):
|
|
|
d2a170 |
pass
|
|
|
d2a170 |
|
|
|
d2a170 |
+class GroupInstallError(InstallError):
|
|
|
d2a170 |
+ pass
|
|
|
d2a170 |
+
|
|
|
d2a170 |
class UpdateError(YumBaseError):
|
|
|
d2a170 |
pass
|
|
|
d2a170 |
|
|
|
d2a170 |
diff --git a/yum/__init__.py b/yum/__init__.py
|
|
|
d2a170 |
index bbd20f3..b40c7e4 100644
|
|
|
d2a170 |
--- a/yum/__init__.py
|
|
|
d2a170 |
+++ b/yum/__init__.py
|
|
|
d2a170 |
@@ -1158,8 +1158,7 @@ class YumBase(depsolve.Depsolve):
|
|
|
d2a170 |
if hasattr(self, 'term'):
|
|
|
d2a170 |
hibeg, hiend = self.term.MODE['bold'], self.term.MODE['normal']
|
|
|
d2a170 |
|
|
|
d2a170 |
- func(_("The program %s%s%s is found in the yum-utils package.") %
|
|
|
d2a170 |
- (hibeg, prog, hiend))
|
|
|
d2a170 |
+ func(_("The program %s is found in the yum-utils package.") % self._try_bold(prog))
|
|
|
d2a170 |
|
|
|
d2a170 |
def buildTransaction(self, unfinished_transactions_check=True):
|
|
|
d2a170 |
"""Go through the packages in the transaction set, find them
|
|
|
d2a170 |
@@ -4451,6 +4450,12 @@ much more problems).
|
|
|
d2a170 |
if node == slow:
|
|
|
d2a170 |
return None
|
|
|
d2a170 |
|
|
|
d2a170 |
+ def _try_bold(self, string_):
|
|
|
d2a170 |
+ """Attempt to make the string look bold in terminal."""
|
|
|
d2a170 |
+ if hasattr(self, 'term'):
|
|
|
d2a170 |
+ return '%s%s%s' % (self.term.MODE['bold'], string_, self.term.MODE['normal'])
|
|
|
d2a170 |
+ return string_
|
|
|
d2a170 |
+
|
|
|
d2a170 |
def _at_groupinstall(self, pattern, upgrade=False):
|
|
|
d2a170 |
" Do groupinstall via. leading @ on the cmd line, for install."
|
|
|
d2a170 |
assert pattern[0] == '@'
|
|
|
d2a170 |
@@ -4464,42 +4469,31 @@ much more problems).
|
|
|
d2a170 |
self.logger.warning(e)
|
|
|
d2a170 |
return tx_return
|
|
|
d2a170 |
|
|
|
d2a170 |
+ found = False
|
|
|
d2a170 |
if group_string and group_string[0] == '^':
|
|
|
d2a170 |
group_string = group_string[1:]
|
|
|
d2a170 |
# Actually dealing with "environment groups".
|
|
|
d2a170 |
- found = False
|
|
|
d2a170 |
for env_grp in comps.return_environments(group_string):
|
|
|
d2a170 |
found = True
|
|
|
d2a170 |
- try:
|
|
|
d2a170 |
- txmbrs = self.selectEnvironment(env_grp.environmentid,
|
|
|
d2a170 |
- upgrade=upgrade)
|
|
|
d2a170 |
- tx_return.extend(txmbrs)
|
|
|
d2a170 |
- except yum.Errors.GroupsError:
|
|
|
d2a170 |
- assert False, "Checked in for loop."
|
|
|
d2a170 |
- continue
|
|
|
d2a170 |
- if not found:
|
|
|
d2a170 |
- self.logger.error(_('Warning: Environment group %s does not exist.'),
|
|
|
d2a170 |
- group_string)
|
|
|
d2a170 |
- return tx_return
|
|
|
d2a170 |
-
|
|
|
d2a170 |
- found = False
|
|
|
d2a170 |
- for group in comps.return_groups(group_string):
|
|
|
d2a170 |
- found = True
|
|
|
d2a170 |
- try:
|
|
|
d2a170 |
+ txmbrs = self.selectEnvironment(env_grp.environmentid,
|
|
|
d2a170 |
+ upgrade=upgrade)
|
|
|
d2a170 |
+ tx_return.extend(txmbrs)
|
|
|
d2a170 |
+ else:
|
|
|
d2a170 |
+ for group in comps.return_groups(group_string):
|
|
|
d2a170 |
+ found = True
|
|
|
d2a170 |
txmbrs = self.selectGroup(group.groupid, upgrade=upgrade)
|
|
|
d2a170 |
tx_return.extend(txmbrs)
|
|
|
d2a170 |
- except yum.Errors.GroupsError:
|
|
|
d2a170 |
- assert False, "Checked in for loop."
|
|
|
d2a170 |
- continue
|
|
|
d2a170 |
if not found:
|
|
|
d2a170 |
- self.logger.error(_('Warning: Package group %s does not exist.'),
|
|
|
d2a170 |
- group_string)
|
|
|
d2a170 |
-
|
|
|
d2a170 |
+ raise Errors.GroupInstallError, _('Group %s does not exist.') % self._try_bold(group_string)
|
|
|
d2a170 |
return tx_return
|
|
|
d2a170 |
|
|
|
d2a170 |
def _at_groupupgrade(self, pattern):
|
|
|
d2a170 |
" Do group upgrade via. leading @ on the cmd line, for update."
|
|
|
d2a170 |
- return self._at_groupinstall(pattern, upgrade=True)
|
|
|
d2a170 |
+ try:
|
|
|
d2a170 |
+ return self._at_groupinstall(pattern, upgrade=True)
|
|
|
d2a170 |
+ except Errors.GroupInstallError, e:
|
|
|
d2a170 |
+ self.logger.warning(_('Warning: %s'), e)
|
|
|
d2a170 |
+ return []
|
|
|
d2a170 |
|
|
|
d2a170 |
def _at_groupremove(self, pattern):
|
|
|
d2a170 |
" Do groupremove via. leading @ on the cmd line, for remove."
|