diff options
Diffstat (limited to 'roles/openshift_facts/library/openshift_facts.py')
| -rwxr-xr-x | roles/openshift_facts/library/openshift_facts.py | 41 | 
1 files changed, 32 insertions, 9 deletions
| diff --git a/roles/openshift_facts/library/openshift_facts.py b/roles/openshift_facts/library/openshift_facts.py index 10121f82a..78886dcea 100755 --- a/roles/openshift_facts/library/openshift_facts.py +++ b/roles/openshift_facts/library/openshift_facts.py @@ -1032,6 +1032,8 @@ def set_nodename(facts):      if 'node' in facts and 'common' in facts:          if 'cloudprovider' in facts and facts['cloudprovider']['kind'] == 'openstack':              facts['node']['nodename'] = facts['provider']['metadata']['hostname'].replace('.novalocal', '') +        elif 'cloudprovider' in facts and facts['cloudprovider']['kind'] == 'gce': +            facts['node']['nodename'] = '.'.split(facts['provider']['metadata']['hostname'])[0]          else:              facts['node']['nodename'] = facts['common']['hostname'].lower()      return facts @@ -1458,7 +1460,7 @@ def merge_facts(orig, new, additive_facts_to_overwrite, protected_facts_to_overw              dict: the merged facts      """      additive_facts = ['named_certificates'] -    protected_facts = ['ha', 'master_count'] +    protected_facts = ['ha']      # Facts we do not ever want to merge. These originate in inventory variables      # and contain JSON dicts. We don't ever want to trigger a merge @@ -1511,14 +1513,6 @@ def merge_facts(orig, new, additive_facts_to_overwrite, protected_facts_to_overw              # it so we will determine if it is okay to change this              # fact.              elif key in protected_facts and key not in [x.split('.')[-1] for x in protected_facts_to_overwrite]: -                # The master count (int) can only increase unless it -                # has been passed as a protected fact to overwrite. -                if key == 'master_count' and new[key] is not None and new[key] is not '': -                    if int(value) <= int(new[key]): -                        facts[key] = copy.deepcopy(new[key]) -                    else: -                        # pylint: disable=line-too-long -                        module.fail_json(msg='openshift_facts received a lower value for openshift.master.master_count')  # noqa: F405                  # ha (bool) can not change unless it has been passed                  # as a protected fact to overwrite.                  if key == 'ha': @@ -1690,9 +1684,38 @@ def set_builddefaults_facts(facts):              if 'admission_plugin_config' not in facts['master']:                  facts['master']['admission_plugin_config'] = dict()              facts['master']['admission_plugin_config'].update(builddefaults['config']) +            # if the user didn't actually provide proxy values, delete the proxy env variable defaults. +            delete_empty_keys(facts['master']['admission_plugin_config']['BuildDefaults']['configuration']['env']) +      return facts +def delete_empty_keys(keylist): +    """ Delete dictionary elements from keylist where "value" is empty. + +        Args: +          keylist(list): A list of builddefault configuration envs. + +        Returns: +          none + +        Example: +          keylist = [{'name': 'HTTP_PROXY', 'value': 'http://file.rdu.redhat.com:3128'}, +                     {'name': 'HTTPS_PROXY', 'value': 'http://file.rdu.redhat.com:3128'}, +                     {'name': 'NO_PROXY', 'value': ''}] + +          After calling delete_empty_keys the provided list is modified to become: + +                    [{'name': 'HTTP_PROXY', 'value': 'http://file.rdu.redhat.com:3128'}, +                     {'name': 'HTTPS_PROXY', 'value': 'http://file.rdu.redhat.com:3128'}] +    """ +    count = 0 +    for i in range(0, len(keylist)): +        if len(keylist[i - count]['value']) == 0: +            del keylist[i - count] +            count += 1 + +  def set_buildoverrides_facts(facts):      """ Set build overrides | 
