Revert "fix cache 'update' method to be 'mapping' compatible"

This reverts commit 68301f890a.
This commit is contained in:
Toshio Kuratomi 2018-12-04 11:18:46 -08:00
parent e4a3e73b15
commit d06cd869b8
3 changed files with 19 additions and 28 deletions

View file

@ -1,2 +0,0 @@
bugfixes:
- fix issue with incorrect dict update in vars manager

View file

@ -289,18 +289,10 @@ class FactCache(MutableMapping):
""" Flush the fact cache of all keys. """ """ Flush the fact cache of all keys. """
self._plugin.flush() self._plugin.flush()
def update(self, host_facts): def update(self, key, value):
""" We override the normal update to ensure we always use the 'setter' method """
for key in host_facts:
try:
host_cache = self._plugin.get(key) host_cache = self._plugin.get(key)
if host_cache: host_cache.update(value)
host_cache.update(host_facts[key])
else:
host_cache = host_facts[key]
self._plugin.set(key, host_cache) self._plugin.set(key, host_cache)
except KeyError:
self._plugin.set(key, host_facts[key])
class InventoryFileCacheModule(BaseFileCacheModule): class InventoryFileCacheModule(BaseFileCacheModule):
@ -319,7 +311,7 @@ class InventoryFileCacheModule(BaseFileCacheModule):
def validate_cache_connection(self): def validate_cache_connection(self):
try: try:
super(InventoryFileCacheModule, self).validate_cache_connection() super(InventoryFileCacheModule, self).validate_cache_connection()
except AnsibleError: except AnsibleError as e:
cache_connection_set = False cache_connection_set = False
else: else:
cache_connection_set = True cache_connection_set = True

View file

@ -622,7 +622,8 @@ class VariableManager:
''' '''
Clears the facts for a host Clears the facts for a host
''' '''
self._fact_cache.pop(hostname, None) if hostname in self._fact_cache:
del self._fact_cache[hostname]
def set_host_facts(self, host, facts): def set_host_facts(self, host, facts):
''' '''
@ -632,14 +633,11 @@ class VariableManager:
if not isinstance(facts, dict): if not isinstance(facts, dict):
raise AnsibleAssertionError("the type of 'facts' to set for host_facts should be a dict but is a %s" % type(facts)) raise AnsibleAssertionError("the type of 'facts' to set for host_facts should be a dict but is a %s" % type(facts))
if host.name not in self._fact_cache:
self._fact_cache[host.name] = facts
else:
try: try:
try:
# this is a cache plugin, not a dictionary
self._fact_cache.update({host.name: facts})
except TypeError:
# this is here for backwards compatibilty for the time cache plugins were not 'dict compatible'
self._fact_cache.update(host.name, facts) self._fact_cache.update(host.name, facts)
display.deprecated("Your configured fact cache plugin is using a deprecated form of the 'update' method", version="2.12")
except KeyError: except KeyError:
self._fact_cache[host.name] = facts self._fact_cache[host.name] = facts
@ -651,6 +649,9 @@ class VariableManager:
if not isinstance(facts, dict): if not isinstance(facts, dict):
raise AnsibleAssertionError("the type of 'facts' to set for nonpersistent_facts should be a dict but is a %s" % type(facts)) raise AnsibleAssertionError("the type of 'facts' to set for nonpersistent_facts should be a dict but is a %s" % type(facts))
if host.name not in self._nonpersistent_fact_cache:
self._nonpersistent_fact_cache[host.name] = facts
else:
try: try:
self._nonpersistent_fact_cache[host.name].update(facts) self._nonpersistent_fact_cache[host.name].update(facts)
except KeyError: except KeyError: