yum should error when a package is not available
I recently ran into a bug in a script where I tried to do the following:
yum -y install another_package.x86_64 some_package.x86_64 && run_my_script
The script ran well on a newer CentOS, but when I tried to execute it on Cent OS 5, some_package.x86_64
was not available. But instead of erroring and stopping yum
just printed the message:
No package some_package.x86_64 available.
How can I force yum
to error in such situations (which IMO should be the default) to make my scripts more robust?
Solution 1:
As you've found, this behaviour changed between RHEL 5 and 6 (see https://bugzilla.redhat.com/show_bug.cgi?id=736694 for some discussion). From that link, checking the return code of yum info <pkg>
should allow you to abort your script as required. Something like:
# Set a variable containing the packages to install:
pkgs_to_install='another_package.x86_64 some_package.x86_64'
# Loop over the packages in the list:
for pkg in ${pkgs_to_install}; do
# Stop executing if at least one package isn't available:
yum info ${pkg} >> /dev/null 2>&1 || exit
done
# Continue running your original script:
yum -y install ${pkgs_to_install} && run_my_script
Solution 2:
Per Bug 1274211, this has been fixed in yum-3.4.3-133.el7. However, you need to enable the strict mode.
The easiest way to do this for scripting purposes is via command-line switch:
yum -y --setopt=skip_missing_names_on_install=False install another_package.x86_64 some_package.x86_64 && run_my_script
However, you can also set it as a configuration option in your yum.conf
:
[main]
skip_missing_names_on_install=0