Bugfix bigip_facts that was trying to check the length of an iterator (#2842)
Recently, a user reported that the bigip_facts module was failing with the error received exception: object of type 'itertools.imap' has no len() This reported was occurring at line 1657 of the bigip_facts module bug report is here https://github.com/F5Networks/f5-ansible/issues/25 Upon further investigation, the map function for returning the specified includes was returning an iterator, and calling len() on an iterator does not work. I believe this problem was caused by part of the Python 3.x effort insofar as the inclusion of this line https://github.com/ansible/ansible/blob/devel/lib/ansible/module_utils/basic.py#L143 seems to affect our usage of map(), probably for the better anyway, and we need to change our expectations in our module's code to no longer assume a list, but instead assume an iterator. After trawling through the module_utils/basic code, I think a list comprehension is more appropriate here anyway, so I'm changing it to be that. The affected user reported it works this way, and my own testing on 2.2.0 supports that.pull/4420/head
parent
e47a5674fb
commit
f48791e8bc
|
@ -1641,7 +1641,7 @@ def main():
|
|||
regex = fnmatch.translate(fact_filter)
|
||||
else:
|
||||
regex = None
|
||||
include = map(lambda x: x.lower(), module.params['include'])
|
||||
include = [x.lower() for x in module.params['include']]
|
||||
valid_includes = ('address_class', 'certificate', 'client_ssl_profile',
|
||||
'device', 'device_group', 'interface', 'key', 'node',
|
||||
'pool', 'provision', 'rule', 'self_ip', 'software',
|
||||
|
|
Loading…
Reference in New Issue