changed: state=build-dep; refactored into install()
This commit is contained in:
parent
442663a13a
commit
3165b39d21
1 changed files with 19 additions and 59 deletions
|
@ -34,10 +34,10 @@ options:
|
||||||
default: null
|
default: null
|
||||||
state:
|
state:
|
||||||
description:
|
description:
|
||||||
- Indicates the desired package state. C(latest) ensures that the latest version is installed.
|
- Indicates the desired package state. C(latest) ensures that the latest version is installed. C(build-dep) ensures the package build dependencies are installed.
|
||||||
required: false
|
required: false
|
||||||
default: present
|
default: present
|
||||||
choices: [ "latest", "absent", "present" ]
|
choices: [ "latest", "absent", "present", "build-dep" ]
|
||||||
update_cache:
|
update_cache:
|
||||||
description:
|
description:
|
||||||
- Run the equivalent of C(apt-get update) before the operation. Can be run as part of the package installation or as a separate step.
|
- Run the equivalent of C(apt-get update) before the operation. Can be run as part of the package installation or as a separate step.
|
||||||
|
@ -82,12 +82,6 @@ options:
|
||||||
required: false
|
required: false
|
||||||
default: "yes"
|
default: "yes"
|
||||||
choices: [ "yes", "safe", "full", "dist"]
|
choices: [ "yes", "safe", "full", "dist"]
|
||||||
build_dep:
|
|
||||||
description:
|
|
||||||
- Instead, install the build dependencies for the named pkg (equivalent to 'apt-get build-dep foo')
|
|
||||||
required: false
|
|
||||||
default: "no"
|
|
||||||
choises: [ "yes", "no" ]
|
|
||||||
dpkg_options:
|
dpkg_options:
|
||||||
description:
|
description:
|
||||||
- Add dpkg options to apt command. Defaults to '-o "Dpkg::Options::=--force-confdef" -o "Dpkg::Options::=--force-confold"'
|
- Add dpkg options to apt command. Defaults to '-o "Dpkg::Options::=--force-confdef" -o "Dpkg::Options::=--force-confold"'
|
||||||
|
@ -141,7 +135,7 @@ EXAMPLES = '''
|
||||||
- apt: deb=/tmp/mypackage.deb
|
- apt: deb=/tmp/mypackage.deb
|
||||||
|
|
||||||
# Install the build dependencies for package "foo"
|
# Install the build dependencies for package "foo"
|
||||||
- apt: pkg=foo build_dep=yes
|
- apt: pkg=foo state=build-dep
|
||||||
'''
|
'''
|
||||||
|
|
||||||
|
|
||||||
|
@ -308,13 +302,18 @@ def expand_pkgspec_from_fnmatches(m, pkgspec, cache):
|
||||||
|
|
||||||
def install(m, pkgspec, cache, upgrade=False, default_release=None,
|
def install(m, pkgspec, cache, upgrade=False, default_release=None,
|
||||||
install_recommends=True, force=False,
|
install_recommends=True, force=False,
|
||||||
dpkg_options=expand_dpkg_options(DPKG_OPTIONS)):
|
dpkg_options=expand_dpkg_options(DPKG_OPTIONS),
|
||||||
|
build_dep=False):
|
||||||
pkg_list = []
|
pkg_list = []
|
||||||
packages = ""
|
packages = ""
|
||||||
pkgspec = expand_pkgspec_from_fnmatches(m, pkgspec, cache)
|
pkgspec = expand_pkgspec_from_fnmatches(m, pkgspec, cache)
|
||||||
for package in pkgspec:
|
for package in pkgspec:
|
||||||
name, version = package_split(package)
|
name, version = package_split(package)
|
||||||
installed, upgradable, has_files = package_status(m, name, version, cache, state='install')
|
installed, upgradable, has_files = package_status(m, name, version, cache, state='install')
|
||||||
|
if build_dep:
|
||||||
|
# Let apt decide what to install
|
||||||
|
pkg_list.append("'%s'" % package)
|
||||||
|
continue
|
||||||
if not installed or (upgrade and upgradable):
|
if not installed or (upgrade and upgradable):
|
||||||
pkg_list.append("'%s'" % package)
|
pkg_list.append("'%s'" % package)
|
||||||
if installed and upgradable and version:
|
if installed and upgradable and version:
|
||||||
|
@ -341,6 +340,9 @@ def install(m, pkgspec, cache, upgrade=False, default_release=None,
|
||||||
for (k,v) in APT_ENV_VARS.iteritems():
|
for (k,v) in APT_ENV_VARS.iteritems():
|
||||||
os.environ[k] = v
|
os.environ[k] = v
|
||||||
|
|
||||||
|
if build_dep:
|
||||||
|
cmd = "%s -y %s %s %s build-dep %s" % (APT_GET_CMD, dpkg_options, force_yes, check_arg, packages)
|
||||||
|
else:
|
||||||
cmd = "%s -y %s %s %s install %s" % (APT_GET_CMD, dpkg_options, force_yes, check_arg, packages)
|
cmd = "%s -y %s %s %s install %s" % (APT_GET_CMD, dpkg_options, force_yes, check_arg, packages)
|
||||||
|
|
||||||
if default_release:
|
if default_release:
|
||||||
|
@ -350,7 +352,7 @@ def install(m, pkgspec, cache, upgrade=False, default_release=None,
|
||||||
|
|
||||||
rc, out, err = m.run_command(cmd)
|
rc, out, err = m.run_command(cmd)
|
||||||
if rc:
|
if rc:
|
||||||
return (False, dict(msg="'apt-get install %s' failed: %s" % (packages, err), stdout=out, stderr=err))
|
return (False, dict(msg="'%s' failed: %s" % (cmd, err), stdout=out, stderr=err))
|
||||||
else:
|
else:
|
||||||
return (True, dict(changed=True, stdout=out, stderr=err))
|
return (True, dict(changed=True, stdout=out, stderr=err))
|
||||||
else:
|
else:
|
||||||
|
@ -493,41 +495,10 @@ def upgrade(m, mode="yes", force=False, default_release=None,
|
||||||
m.exit_json(changed=False, msg=out, stdout=out, stderr=err)
|
m.exit_json(changed=False, msg=out, stdout=out, stderr=err)
|
||||||
m.exit_json(changed=True, msg=out, stdout=out, stderr=err)
|
m.exit_json(changed=True, msg=out, stdout=out, stderr=err)
|
||||||
|
|
||||||
def build_dep(m, pkgspec, cache, force=False,
|
|
||||||
dpkg_options=expand_dpkg_options(DPKG_OPTIONS)):
|
|
||||||
if m.check_mode:
|
|
||||||
check_arg = '--simulate'
|
|
||||||
else:
|
|
||||||
check_arg = ''
|
|
||||||
|
|
||||||
if force:
|
|
||||||
force_yes = '--force-yes'
|
|
||||||
else:
|
|
||||||
force_yes = ''
|
|
||||||
|
|
||||||
packages = ''
|
|
||||||
pkgspec = expand_pkgspec_from_fnmatches(m, pkgspec, cache)
|
|
||||||
for package in pkgspec:
|
|
||||||
name, version = package_split(package)
|
|
||||||
packages += "'%s' " % package
|
|
||||||
if len(packages) == 0:
|
|
||||||
m.exit_json(changed=False)
|
|
||||||
else:
|
|
||||||
for (k,v) in APT_ENV_VARS.iteritems():
|
|
||||||
os.environ[k] = v
|
|
||||||
apt_cmd_path = m.get_bin_path(APT_GET_CMD, required=True)
|
|
||||||
cmd = '%s -y %s %s %s build-dep %s' % (apt_cmd_path, dpkg_options, force_yes, check_arg, packages)
|
|
||||||
rc, out, err = m.run_command(cmd)
|
|
||||||
if rc:
|
|
||||||
m.fail_json(msg="'%s' failed: %s" % (cmd, err), stdout=out)
|
|
||||||
if APT_GET_ZERO in out:
|
|
||||||
m.exit_json(changed=False, msg=out, stdout=out, stderr=err)
|
|
||||||
m.exit_json(changed=True, msg=out, stdout=out, stderr=err)
|
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
argument_spec = dict(
|
argument_spec = dict(
|
||||||
state = dict(default='present', choices=['installed', 'latest', 'removed', 'absent', 'present']),
|
state = dict(default='present', choices=['installed', 'latest', 'removed', 'absent', 'present', 'build-dep']),
|
||||||
update_cache = dict(default=False, aliases=['update-cache'], type='bool'),
|
update_cache = dict(default=False, aliases=['update-cache'], type='bool'),
|
||||||
cache_valid_time = dict(type='int'),
|
cache_valid_time = dict(type='int'),
|
||||||
purge = dict(default=False, type='bool'),
|
purge = dict(default=False, type='bool'),
|
||||||
|
@ -537,7 +508,6 @@ def main():
|
||||||
install_recommends = dict(default='yes', aliases=['install-recommends'], type='bool'),
|
install_recommends = dict(default='yes', aliases=['install-recommends'], type='bool'),
|
||||||
force = dict(default='no', type='bool'),
|
force = dict(default='no', type='bool'),
|
||||||
upgrade = dict(choices=['yes', 'safe', 'full', 'dist']),
|
upgrade = dict(choices=['yes', 'safe', 'full', 'dist']),
|
||||||
build_dep = dict(default='no', type='bool'),
|
|
||||||
dpkg_options = dict(default=DPKG_OPTIONS)
|
dpkg_options = dict(default=DPKG_OPTIONS)
|
||||||
),
|
),
|
||||||
mutually_exclusive = [['package', 'upgrade', 'deb']],
|
mutually_exclusive = [['package', 'upgrade', 'deb']],
|
||||||
|
@ -636,23 +606,13 @@ def main():
|
||||||
if latest and '=' in package:
|
if latest and '=' in package:
|
||||||
module.fail_json(msg='version number inconsistent with state=latest: %s' % package)
|
module.fail_json(msg='version number inconsistent with state=latest: %s' % package)
|
||||||
|
|
||||||
if p['build_dep']:
|
if p['state'] in ('latest', 'present', 'build-dep'):
|
||||||
build_dep(module, packages, cache, force=force_yes, dpkg_options=dpkg_options)
|
build_dep = p.get('build-dep', False)
|
||||||
|
|
||||||
if p['state'] == 'latest':
|
|
||||||
result = install(module, packages, cache, upgrade=True,
|
result = install(module, packages, cache, upgrade=True,
|
||||||
default_release=p['default_release'],
|
default_release=p['default_release'],
|
||||||
install_recommends=install_recommends,
|
install_recommends=install_recommends,
|
||||||
force=force_yes, dpkg_options=dpkg_options)
|
force=force_yes, dpkg_options=dpkg_options,
|
||||||
(success, retvals) = result
|
build_dep=build_dep)
|
||||||
if success:
|
|
||||||
module.exit_json(**retvals)
|
|
||||||
else:
|
|
||||||
module.fail_json(**retvals)
|
|
||||||
elif p['state'] == 'present':
|
|
||||||
result = install(module, packages, cache, default_release=p['default_release'],
|
|
||||||
install_recommends=install_recommends,force=force_yes,
|
|
||||||
dpkg_options=dpkg_options)
|
|
||||||
(success, retvals) = result
|
(success, retvals) = result
|
||||||
if success:
|
if success:
|
||||||
module.exit_json(**retvals)
|
module.exit_json(**retvals)
|
||||||
|
|
Loading…
Reference in a new issue