1
0
Fork 0
mirror of https://github.com/ansible-collections/community.general.git synced 2024-09-14 20:13:21 +02:00

pacman: don't always return changed w/ update_cache (#4318)

* pacman: don't always return changed w/ update_cache

This used to be the behavior before the recent refactoring. [1]

Allows the following to return changed only when packages were upgraded:

  - pacman:
    update_cache: yes
    upgrade: yes

And the following to return changed only when the foo package wasn't at
the latest version:

  - pacman:
    name: foo
    state: latest
    update_cache: yes

[1] https://github.com/ansible-collections/community.general/pull/3907

* Update changelogs/fragments/4318-pacman-restore-old-changed-behavior.yml

Co-authored-by: Felix Fontein <felix@fontein.de>

Co-authored-by: Felix Fontein <felix@fontein.de>
This commit is contained in:
Evangelos Foutras 2022-03-06 22:38:33 +02:00 committed by GitHub
parent 1ca7894d30
commit cc8151f209
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 18 additions and 0 deletions

View file

@ -0,0 +1,12 @@
bugfixes:
- pacman - when the ``update_cache`` option is combined with another option
such as ``upgrade``, report ``changed`` based on the actions performed by
the latter option. This was the behavior in community.general 4.4.0 and before.
In community.general 4.5.0, a task combining these options would always
report ``changed``
(https://github.com/ansible-collections/community.general/pull/4318).
known_issues:
- pacman - ``update_cache`` cannot differentiate between up to date and
outdated package lists and will report ``changed`` in both situations
(https://github.com/ansible-collections/community.general/pull/4318).

View file

@ -271,6 +271,12 @@ class Pacman(object):
if not (self.m.params["name"] or self.m.params["upgrade"]): if not (self.m.params["name"] or self.m.params["upgrade"]):
self.success() self.success()
# Avoid shadowing lack of changes in the following stages
# so that update_cache: yes doesn't always return changed
# TODO: remove this when update_cache is tweaked to report its real
# changed status (i.e. no changed if package lists were up to date)
self.changed = False
self.inventory = self._build_inventory() self.inventory = self._build_inventory()
if self.m.params["upgrade"]: if self.m.params["upgrade"]:
self.upgrade() self.upgrade()