From ba914ef97e73583554d14c280ae18f11fced66f6 Mon Sep 17 00:00:00 2001 From: "Jose A. Rivera" Date: Fri, 24 Mar 2017 11:00:08 -0500 Subject: oo_collect: Update comments to show source of failure Signed-off-by: Jose A. Rivera --- filter_plugins/oo_filters.py | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/filter_plugins/oo_filters.py b/filter_plugins/oo_filters.py index a619f9ccb..6760f9b2d 100644 --- a/filter_plugins/oo_filters.py +++ b/filter_plugins/oo_filters.py @@ -140,14 +140,14 @@ def oo_collect(data, attribute=None, filters=None): returns [1, 2, 3] """ if not isinstance(data, list): - raise errors.AnsibleFilterError("|failed expects to filter on a List") + raise errors.AnsibleFilterError("oo_collect expects to filter on a List") if not attribute: - raise errors.AnsibleFilterError("|failed expects attribute to be set") + raise errors.AnsibleFilterError("oo_collect expects attribute to be set") if filters is not None: if not isinstance(filters, dict): - raise errors.AnsibleFilterError("|failed expects filter to be a" + raise errors.AnsibleFilterError("oo_collect expects filter to be a" " dict") retval = [get_attr(d, attribute) for d in data if ( all([d.get(key, None) == filters[key] for key in filters]))] -- cgit v1.2.3 From f541c25328009355536eda97f8cb7094c8e100b7 Mon Sep 17 00:00:00 2001 From: "Jose A. Rivera" Date: Fri, 24 Mar 2017 11:01:11 -0500 Subject: oo_collect: Allow list elements to be lists of dict Signed-off-by: Jose A. Rivera --- filter_plugins/oo_filters.py | 47 +++++++++++++++++++++++++++++++++----------- 1 file changed, 35 insertions(+), 12 deletions(-) diff --git a/filter_plugins/oo_filters.py b/filter_plugins/oo_filters.py index 6760f9b2d..a0fb78c0e 100644 --- a/filter_plugins/oo_filters.py +++ b/filter_plugins/oo_filters.py @@ -125,34 +125,57 @@ def oo_merge_hostvars(hostvars, variables, inventory_hostname): return merged_hostvars -def oo_collect(data, attribute=None, filters=None): +def oo_collect(data_list, attribute=None, filters=None): """ This takes a list of dict and collects all attributes specified into a list. If filter is specified then we will include all items that match _ALL_ of filters. If a dict entry is missing the key in a filter it will be excluded from the match. - Ex: data = [ {'a':1, 'b':5, 'z': 'z'}, # True, return - {'a':2, 'z': 'z'}, # True, return - {'a':3, 'z': 'z'}, # True, return - {'a':4, 'z': 'b'}, # FAILED, obj['z'] != obj['z'] - ] + Ex: data_list = [ {'a':1, 'b':5, 'z': 'z'}, # True, return + {'a':2, 'z': 'z'}, # True, return + {'a':3, 'z': 'z'}, # True, return + {'a':4, 'z': 'b'}, # FAILED, obj['z'] != obj['z'] + ] attribute = 'a' filters = {'z': 'z'} returns [1, 2, 3] + + This also deals with lists of lists with dict as elements. + Ex: data_list = [ + [ {'a':1, 'b':5, 'z': 'z'}, # True, return + {'a':2, 'b':6, 'z': 'z'} # True, return + ], + [ {'a':3, 'z': 'z'}, # True, return + {'a':4, 'z': 'b'} # FAILED, obj['z'] != obj['z'] + ], + {'a':5, 'z': 'z'}, # True, return + ] + attribute = 'a' + filters = {'z': 'z'} + returns [1, 2, 3, 5] """ - if not isinstance(data, list): + if not isinstance(data_list, list): raise errors.AnsibleFilterError("oo_collect expects to filter on a List") if not attribute: raise errors.AnsibleFilterError("oo_collect expects attribute to be set") + data = [] + retval = [] + + for item in data_list: + if isinstance(item, list): + retval.extend(oo_collect(item, attribute, filters)) + else: + data.append(item) + if filters is not None: if not isinstance(filters, dict): - raise errors.AnsibleFilterError("oo_collect expects filter to be a" - " dict") - retval = [get_attr(d, attribute) for d in data if ( - all([d.get(key, None) == filters[key] for key in filters]))] + raise errors.AnsibleFilterError( + "oo_collect expects filter to be a dict") + retval.extend([get_attr(d, attribute) for d in data if ( + all([d.get(key, None) == filters[key] for key in filters]))]) else: - retval = [get_attr(d, attribute) for d in data] + retval.extend([get_attr(d, attribute) for d in data]) retval = [val for val in retval if val is not None] -- cgit v1.2.3 From 86556ec6012ff2669de712c00a2d80f97ef97ac0 Mon Sep 17 00:00:00 2001 From: "Jose A. Rivera" Date: Tue, 28 Mar 2017 18:36:12 -0500 Subject: oo_filters: Disable pylint too-many-lines test Signed-off-by: Jose A. Rivera --- filter_plugins/oo_filters.py | 1 + 1 file changed, 1 insertion(+) diff --git a/filter_plugins/oo_filters.py b/filter_plugins/oo_filters.py index a0fb78c0e..179febe98 100644 --- a/filter_plugins/oo_filters.py +++ b/filter_plugins/oo_filters.py @@ -1,6 +1,7 @@ #!/usr/bin/python # -*- coding: utf-8 -*- # vim: expandtab:tabstop=4:shiftwidth=4 +# pylint: disable=too-many-lines """ Custom filters for use in openshift-ansible """ -- cgit v1.2.3