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:
parent
1378861fe7
commit
9c6ad3d076
2 changed files with 50 additions and 5 deletions
|
@ -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.')
|
||||||
|
|
|
@ -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"
|
||||||
|
|
Loading…
Reference in a new issue