diff options
author | Michael DeHaan <michael.dehaan@gmail.com> | 2012-04-04 02:08:37 +0200 |
---|---|---|
committer | Michael DeHaan <michael.dehaan@gmail.com> | 2012-04-04 02:08:37 +0200 |
commit | 32f574b24de7ac9fedb4d3f2f99618c0d64a0a47 (patch) | |
tree | 0c99e074853cf862251ce94c2af8cdd71b9d9a6b | |
parent | Merge pull request #110 from jhoekx/remote-vars (diff) | |
parent | apt module bugfix (diff) | |
download | ansible-32f574b24de7ac9fedb4d3f2f99618c0d64a0a47.tar.xz ansible-32f574b24de7ac9fedb4d3f2f99618c0d64a0a47.zip |
Merge pull request #113 from mgwilliams/bugfixes-apt-module
apt module bugfix
-rwxr-xr-x | library/apt | 12 |
1 files changed, 7 insertions, 5 deletions
diff --git a/library/apt b/library/apt index b8d441660e..0909f3ead1 100755 --- a/library/apt +++ b/library/apt @@ -67,21 +67,21 @@ def run_apt(command): def package_status(pkgspec, cache): try: - pkg = cache[pkgspec] + pkg = cache[pkgspec] except: fail_json(msg="No package matching '%s' is available" % pkgspec) return (pkg.is_installed, pkg.is_upgradable) def install(pkgspec, cache, upgrade=False): (installed, upgradable) = package_status(pkgspec, cache) - if installed or not upgrade or not upgradable: - return False - else: + if (not installed) or (upgrade and upgradable): cmd = "%s -q -y install '%s'" % (APT, pkgspec) rc, out, err = run_apt(cmd) if rc: json_fail(msg="'apt-get install %s' failed: %s" % (pkgspec, err)) return True + else: + return False def remove(pkgspec, cache, purge=False): (installed, upgradable) = package_status(pkgspec, cache) @@ -128,7 +128,7 @@ if update_cache not in ['yes', 'no']: if purge not in ['yes', 'no']: fail_json(msg='invalid value for purge (requires yes or no -- default is no)') -if package is None and update-cache != 'yes': +if package is None and update_cache != 'yes': fail_json(msg='pkg=name and/or update-cache=yes is required') cache = apt.Cache() @@ -136,6 +136,8 @@ cache = apt.Cache() if update_cache == 'yes': cache.update() cache.open() + if package == None: + exit_json(changed=False) if state == 'latest': changed = install(package, cache, upgrade=True) |