Add update_only parameter for yum module (#22206)

* Add update_only parameter for yum module

When using latest, `update_only: yes` will ensure that only existing
packages are updated and no additional packages are installed.

* Update yum.py

Update version added for `update_only` parameter to 2.5

* add unit tests for update_only flag in yum module
This commit is contained in:
Stephen 2017-10-04 04:25:13 -04:00 committed by Martin Krizek
parent 1378861fe7
commit 9c6ad3d076
2 changed files with 50 additions and 5 deletions

View file

@ -93,6 +93,17 @@ options:
type: bool type: bool
default: "yes" default: "yes"
version_added: "2.1" version_added: "2.1"
update_only:
description:
- When using latest, only update installed packages. Do not install packages.
- Has an effect only if state is I(latest)
required: false
default: "no"
choices: ["yes", "no"]
aliases: []
version_added: "2.5"
installroot: installroot:
description: description:
- Specifies an alternative installroot, relative to which all packages - Specifies an alternative installroot, relative to which all packages
@ -926,7 +937,7 @@ def parse_check_update(check_update_output):
return updates return updates
def latest(module, items, repoq, yum_basecmd, conf_file, en_repos, dis_repos, installroot='/'): def latest(module, items, repoq, yum_basecmd, conf_file, en_repos, dis_repos, update_only, installroot='/'):
res = {} res = {}
res['results'] = [] res['results'] = []
@ -1000,7 +1011,7 @@ def latest(module, items, repoq, yum_basecmd, conf_file, en_repos, dis_repos, in
# dep/pkgname - find it # dep/pkgname - find it
else: else:
if is_installed(module, repoq, spec, conf_file, en_repos=en_repos, dis_repos=dis_repos, installroot=installroot): if is_installed(module, repoq, spec, conf_file, en_repos=en_repos, dis_repos=dis_repos, installroot=installroot) or update_only:
pkgs['update'].append(spec) pkgs['update'].append(spec)
else: else:
pkgs['install'].append(spec) pkgs['install'].append(spec)
@ -1032,6 +1043,9 @@ def latest(module, items, repoq, yum_basecmd, conf_file, en_repos, dis_repos, in
will_update_from_other_package[spec] = this_name_only will_update_from_other_package[spec] = this_name_only
break break
if not is_installed(module, repoq, spec, conf_file, en_repos=en_repos, dis_repos=dis_repos, installroot=installroot) and update_only:
res['results'].append("Packages providing %s not installed due to update_only specified" % spec)
continue
if nothing_to_do: if nothing_to_do:
res['results'].append("All packages providing %s are up to date" % spec) res['results'].append("All packages providing %s are up to date" % spec)
continue continue
@ -1092,7 +1106,7 @@ def latest(module, items, repoq, yum_basecmd, conf_file, en_repos, dis_repos, in
def ensure(module, state, pkgs, conf_file, enablerepo, disablerepo, def ensure(module, state, pkgs, conf_file, enablerepo, disablerepo,
disable_gpg_check, exclude, repoq, skip_broken, security, disable_gpg_check, exclude, repoq, skip_broken, update_only, security,
installroot='/', allow_downgrade=False): installroot='/', allow_downgrade=False):
# fedora will redirect yum to dnf, which has incompatibilities # fedora will redirect yum to dnf, which has incompatibilities
@ -1195,7 +1209,7 @@ def ensure(module, state, pkgs, conf_file, enablerepo, disablerepo,
yum_basecmd.append('--nogpgcheck') yum_basecmd.append('--nogpgcheck')
if security: if security:
yum_basecmd.append('--security') yum_basecmd.append('--security')
res = latest(module, pkgs, repoq, yum_basecmd, conf_file, en_repos, dis_repos, installroot=installroot) res = latest(module, pkgs, repoq, yum_basecmd, conf_file, en_repos, dis_repos, update_only, installroot=installroot)
else: else:
# should be caught by AnsibleModule argument_spec # should be caught by AnsibleModule argument_spec
module.fail_json(msg="we should never get here unless this all failed", module.fail_json(msg="we should never get here unless this all failed",
@ -1230,6 +1244,7 @@ def main():
update_cache=dict(type='bool', default=False, aliases=['expire-cache']), update_cache=dict(type='bool', default=False, aliases=['expire-cache']),
validate_certs=dict(type='bool', default=True), validate_certs=dict(type='bool', default=True),
installroot=dict(type='str', default="/"), installroot=dict(type='str', default="/"),
update_only=dict(required=False, default="no", type='bool'),
# this should not be needed, but exists as a failsafe # this should not be needed, but exists as a failsafe
install_repoquery=dict(type='bool', default=True), install_repoquery=dict(type='bool', default=True),
allow_downgrade=dict(type='bool', default=False), allow_downgrade=dict(type='bool', default=False),
@ -1287,11 +1302,12 @@ def main():
disablerepo = params.get('disablerepo', '') disablerepo = params.get('disablerepo', '')
disable_gpg_check = params['disable_gpg_check'] disable_gpg_check = params['disable_gpg_check']
skip_broken = params['skip_broken'] skip_broken = params['skip_broken']
update_only = params['update_only']
security = params['security'] security = params['security']
allow_downgrade = params['allow_downgrade'] allow_downgrade = params['allow_downgrade']
results = ensure(module, state, pkg, params['conf_file'], enablerepo, results = ensure(module, state, pkg, params['conf_file'], enablerepo,
disablerepo, disable_gpg_check, exclude, repoquery, disablerepo, disable_gpg_check, exclude, repoquery,
skip_broken, security, params['installroot'], allow_downgrade) skip_broken, update_only, security, params['installroot'], allow_downgrade)
if repoquery: if repoquery:
results['msg'] = '%s %s' % (results.get('msg', ''), results['msg'] = '%s %s' % (results.get('msg', ''),
'Warning: Due to potential bad behaviour with rhnplugin and certificates, used slower repoquery calls instead of Yum API.') 'Warning: Due to potential bad behaviour with rhnplugin and certificates, used slower repoquery calls instead of Yum API.')

View file

@ -427,3 +427,32 @@
that: that:
- "'changed' in yum_result" - "'changed' in yum_result"
- "'msg' in yum_result" - "'msg' in yum_result"
- name: use latest to install httpd
yum:
name: httpd
state: latest
register: yum_result
- name: verify httpd was installed
assert:
that:
- "'changed' in yum_result"
- name: uninstall httpd
yum:
name: httpd
state: removed
- name: update httpd only if it exists
yum:
name: httpd
state: latest
update_only: yes
register: yum_result
- name: verify httpd not installed
assert:
that:
- "not yum_result.changed"
- "'Packages providing httpd not installed due to update_only specified' in yum_result.results"