diff options
Diffstat (limited to 'playbooks/common')
6 files changed, 60 insertions, 5 deletions
| diff --git a/playbooks/common/openshift-cluster/config.yml b/playbooks/common/openshift-cluster/config.yml index 113b401f9..82f711f40 100644 --- a/playbooks/common/openshift-cluster/config.yml +++ b/playbooks/common/openshift-cluster/config.yml @@ -27,6 +27,9 @@      when: openshift_docker_selinux_enabled is not defined  - include: disable_excluder.yml +  vars: +    # the excluders needs to be disabled no matter what status says +    with_status_check: false    tags:    - always diff --git a/playbooks/common/openshift-cluster/disable_excluder.yml b/playbooks/common/openshift-cluster/disable_excluder.yml index eb146bab8..b2e025cb8 100644 --- a/playbooks/common/openshift-cluster/disable_excluder.yml +++ b/playbooks/common/openshift-cluster/disable_excluder.yml @@ -3,9 +3,15 @@    hosts: l_oo_all_hosts    gather_facts: no    tasks: + +  # During installation the excluders are installed with present state. +  # So no pre-validation check here as the excluders are either to be installed (present = latest) +  # or they are not going to be updated if already installed + +  # disable excluders based on their status    - include_role:        name: openshift_excluder -      tasks_from: status -  - include_role: -      name: openshift_excluder -      tasks_from: unexclude +      tasks_from: disable +    vars: +      openshift_excluder_package_state: present +      docker_excluder_package_state: present diff --git a/playbooks/common/openshift-cluster/initialize_openshift_version.yml b/playbooks/common/openshift-cluster/initialize_openshift_version.yml index 6b40176e1..7f37c606f 100644 --- a/playbooks/common/openshift-cluster/initialize_openshift_version.yml +++ b/playbooks/common/openshift-cluster/initialize_openshift_version.yml @@ -19,6 +19,9 @@      when: "not openshift.common.is_atomic | bool and 'Plugin \"search-disabled-repos\" requires API 2.7. Supported API is 2.6.' in yum_ver_test.stdout"  - include: disable_excluder.yml +  vars: +    # the excluders needs to be disabled no matter what status says +    with_status_check: false    tags:    - always diff --git a/playbooks/common/openshift-cluster/reset_excluder.yml b/playbooks/common/openshift-cluster/reset_excluder.yml index fe86f4c23..7c544ee32 100644 --- a/playbooks/common/openshift-cluster/reset_excluder.yml +++ b/playbooks/common/openshift-cluster/reset_excluder.yml @@ -5,4 +5,4 @@    tasks:    - include_role:        name: openshift_excluder -      tasks_from: reset +      tasks_from: enable diff --git a/playbooks/common/openshift-cluster/upgrades/disable_excluder.yml b/playbooks/common/openshift-cluster/upgrades/disable_excluder.yml new file mode 100644 index 000000000..2a85dc92e --- /dev/null +++ b/playbooks/common/openshift-cluster/upgrades/disable_excluder.yml @@ -0,0 +1,21 @@ +--- +- name: Record excluder state and disable +  hosts: l_oo_all_hosts +  gather_facts: no +  tasks: +  - include: pre/validate_excluder.yml +    vars: +      #repoquery_cmd: repoquery_cmd +      #openshift_upgrade_target: openshift_upgrade_target +      excluder: "{{ item }}" +    with_items: +    - "{{ openshift.common.service_type }}-docker-excluder" +    - "{{ openshift.common.service_type }}-excluder" + +  # disable excluders based on their status +  - include_role: +      name: openshift_excluder +      tasks_from: disable +    vars: +      openshift_excluder_package_state: latest +      docker_excluder_package_state: latest diff --git a/playbooks/common/openshift-cluster/upgrades/pre/validate_excluder.yml b/playbooks/common/openshift-cluster/upgrades/pre/validate_excluder.yml new file mode 100644 index 000000000..5078638b7 --- /dev/null +++ b/playbooks/common/openshift-cluster/upgrades/pre/validate_excluder.yml @@ -0,0 +1,22 @@ +--- +# input variables: +# - repoquery_cmd +# - excluder +# - openshift_upgrade_target +- name: Get available excluder version +  command: > +    {{ repoquery_cmd }} --qf '%{version}' "{{ excluder }}" +  register: excluder_version +  failed_when: false +  changed_when: false + +- name: Docker excluder version detected +  debug: +    msg: "{{ excluder }}: {{ excluder_version.stdout }}" + +- name: Check the available {{ excluder }} version is at most of the upgrade target version +  fail: +    msg: "Available {{ excluder }} version {{ excluder_version.stdout }} is higher than the upgrade target version {{ openshift_upgrade_target }}" +  when: +    - "{{ excluder_version.stdout != '' }}" +    - "{{ excluder_version.stdout.split('.')[0:2] | join('.') | version_compare(openshift_upgrade_target, '>', strict=True) }}" | 
