diff options
7 files changed, 20 insertions, 11 deletions
| diff --git a/roles/etcd/tasks/main.yml b/roles/etcd/tasks/main.yml index e72509c4d..0be042f7f 100644 --- a/roles/etcd/tasks/main.yml +++ b/roles/etcd/tasks/main.yml @@ -38,7 +38,7 @@  - name: Reload systemd units    command: systemctl daemon-reload -  when: openshift.common.is_containerized and ( install_etcd_result | changed ) +  when: openshift.common.is_containerized | bool and ( install_etcd_result | changed )  - name: Validate permissions on the config dir    file: diff --git a/roles/openshift_examples/defaults/main.yml b/roles/openshift_examples/defaults/main.yml index ad21d0f09..976ff7702 100644 --- a/roles/openshift_examples/defaults/main.yml +++ b/roles/openshift_examples/defaults/main.yml @@ -8,7 +8,7 @@ openshift_examples_load_quickstarts: true  content_version: "{{ openshift.common.examples_content_version }}" -examples_base: "{{ openshift.common.config_base if openshift.common.is_containerized else '/usr/share/openshift' }}/examples" +examples_base: "{{ openshift.common.config_base if openshift.common.is_containerized | bool else '/usr/share/openshift' }}/examples"  image_streams_base: "{{ examples_base }}/image-streams"  centos_image_streams: "{{ image_streams_base}}/image-streams-centos7.json"  rhel_image_streams: "{{ image_streams_base}}/image-streams-rhel7.json" diff --git a/roles/openshift_facts/library/openshift_facts.py b/roles/openshift_facts/library/openshift_facts.py index 596e4f894..eb3a89035 100755 --- a/roles/openshift_facts/library/openshift_facts.py +++ b/roles/openshift_facts/library/openshift_facts.py @@ -775,7 +775,7 @@ def set_sdn_facts_if_unset(facts, system_facts):      if 'common' in facts:          use_sdn = facts['common']['use_openshift_sdn']          if not (use_sdn == '' or isinstance(use_sdn, bool)): -            use_sdn = bool(strtobool(str(use_sdn))) +            use_sdn = safe_get_bool(use_sdn)              facts['common']['use_openshift_sdn'] = use_sdn          if 'sdn_network_plugin_name' not in facts['common']:              plugin = 'redhat/openshift-ovs-subnet' if use_sdn else '' @@ -904,7 +904,7 @@ def get_openshift_version(facts, cli_image=None):          _, output, _ = module.run_command(['/usr/bin/openshift', 'version'])          version = parse_openshift_version(output) -    if 'is_containerized' in facts['common'] and facts['common']['is_containerized']: +    if 'is_containerized' in facts['common'] and safe_get_bool(facts['common']['is_containerized']):          container = None          if 'master' in facts:              if 'cluster_method' in facts['master']: @@ -1032,7 +1032,7 @@ def merge_facts(orig, new, additive_facts_to_overwrite, protected_facts_to_overw                  # ha (bool) can not change unless it has been passed                  # as a protected fact to overwrite.                  if key == 'ha': -                    if bool(value) != bool(new[key]): +                    if safe_get_bool(value) != safe_get_bool(new[key]):                          module.fail_json(msg='openshift_facts received a different value for openshift.master.ha')                      else:                          facts[key] = value @@ -1097,6 +1097,15 @@ def get_local_facts_from_file(filename):      return local_facts +def safe_get_bool(fact): +    """ Get a boolean fact safely. + +        Args: +            facts: fact to convert +        Returns: +            bool: given fact as a bool +    """ +    return bool(strtobool(str(fact)))  def set_container_facts_if_unset(facts):      """ Set containerized facts. @@ -1142,7 +1151,7 @@ def set_container_facts_if_unset(facts):          if 'ovs_image' not in facts['node']:              facts['node']['ovs_image'] = ovs_image -    if bool(strtobool(str(facts['common']['is_containerized']))): +    if safe_get_bool(facts['common']['is_containerized']):          facts['common']['admin_binary'] = '/usr/local/bin/oadm'          facts['common']['client_binary'] = '/usr/local/bin/oc'          base_version = get_openshift_version(facts, cli_image).split('-')[0] @@ -1279,7 +1288,7 @@ class OpenShiftFacts(object):          facts = set_aggregate_facts(facts)          facts = set_etcd_facts_if_unset(facts)          facts = set_container_facts_if_unset(facts) -        if not facts['common']['is_containerized']: +        if not safe_get_bool(facts['common']['is_containerized']):              facts = set_installed_variant_rpm_facts(facts)          return dict(openshift=facts) diff --git a/roles/openshift_master/templates/atomic-openshift-master.j2 b/roles/openshift_master/templates/atomic-openshift-master.j2 index 8602a492e..c848e0ac2 100644 --- a/roles/openshift_master/templates/atomic-openshift-master.j2 +++ b/roles/openshift_master/templates/atomic-openshift-master.j2 @@ -1,6 +1,6 @@  OPTIONS=--loglevel={{ openshift.master.debug_level }}  CONFIG_FILE={{ openshift_master_config_file }} -{% if openshift.common.is_containerized %} +{% if openshift.common.is_containerized | bool %}  IMAGE_VERSION={{ openshift_version }}  {% endif %} diff --git a/roles/openshift_master/templates/native-cluster/atomic-openshift-master-api.j2 b/roles/openshift_master/templates/native-cluster/atomic-openshift-master-api.j2 index f953de404..8e2d927aa 100644 --- a/roles/openshift_master/templates/native-cluster/atomic-openshift-master-api.j2 +++ b/roles/openshift_master/templates/native-cluster/atomic-openshift-master-api.j2 @@ -1,6 +1,6 @@  OPTIONS=--loglevel={{ openshift.master.debug_level }} --listen={{ 'https' if openshift.master.api_use_ssl else 'http' }}://{{ openshift.master.bind_addr }}:{{ openshift.master.api_port }} --master={{ openshift.master.loopback_api_url }}  CONFIG_FILE={{ openshift_master_config_file }} -{% if openshift.common.is_containerized %} +{% if openshift.common.is_containerized | bool %}  IMAGE_VERSION={{ openshift_version }}  {% endif %} diff --git a/roles/openshift_master/templates/native-cluster/atomic-openshift-master-controllers.j2 b/roles/openshift_master/templates/native-cluster/atomic-openshift-master-controllers.j2 index 30da9d396..5c6cb2dcb 100644 --- a/roles/openshift_master/templates/native-cluster/atomic-openshift-master-controllers.j2 +++ b/roles/openshift_master/templates/native-cluster/atomic-openshift-master-controllers.j2 @@ -1,6 +1,6 @@  OPTIONS=--loglevel={{ openshift.master.debug_level }} --listen={{ 'https' if openshift.master.api_use_ssl else 'http' }}://{{ openshift.master.bind_addr }}:{{ openshift.master.controllers_port }}  CONFIG_FILE={{ openshift_master_config_file }} -{% if openshift.common.is_containerized %} +{% if openshift.common.is_containerized | bool %}  IMAGE_VERSION={{ openshift_version }}  {% endif %} diff --git a/roles/openshift_node/tasks/main.yml b/roles/openshift_node/tasks/main.yml index 2d3960cd8..83aa590fa 100644 --- a/roles/openshift_node/tasks/main.yml +++ b/roles/openshift_node/tasks/main.yml @@ -79,7 +79,7 @@  - name: Reload systemd units    command: systemctl daemon-reload -  when: openshift.common.is_containerized and ( ( install_node_result  | changed ) +  when: openshift.common.is_containerized | bool and ( ( install_node_result  | changed )      or ( install_ovs_sysconfig | changed ) )  - name: Start and enable openvswitch docker service | 
