CI: Use python 3 for local kolla-ansible execution

This change switches the CI jobs to use python 3 for local execution of
the kolla-ansible commands.

For upgrades, we use python 2 for the previous (Train) deploy, then
reinstall using python 3 for the (Ussuri) upgrade.

NOTE: This is separate from the python interpreter used on remote hosts,
which is configured via ansible_python_interpreter.

Partially Implements: blueprint python-3
Related: blueprint drop-py2-support

Change-Id: I5bdc165f68b7bde1f9ef30fe8216f2a44e6d4706
This commit is contained in:
Mark Goddard 2019-11-26 10:48:52 +00:00
parent c320077f08
commit a5408f425b
2 changed files with 50 additions and 12 deletions

View File

@ -22,6 +22,8 @@
openstack_core_enabled: "{{ openstack_core_enabled }}" openstack_core_enabled: "{{ openstack_core_enabled }}"
openstack_core_tested: "{{ scenario in ['core', 'ceph', 'cinder-lvm', 'cells'] }}" openstack_core_tested: "{{ scenario in ['core', 'ceph', 'cinder-lvm', 'cells'] }}"
dashboard_enabled: "{{ openstack_core_enabled }}" dashboard_enabled: "{{ openstack_core_enabled }}"
# TODO(mgoddard): Remove when previous_release is ussuri.
playbook_python_version: "{{ '2' if is_upgrade and previous_release == 'train' else '3' }}"
- name: Prepare disks for Ceph or LVM - name: Prepare disks for Ceph or LVM
script: "setup_disks.sh {{ disk_type }}" script: "setup_disks.sh {{ disk_type }}"
@ -152,10 +154,13 @@
- "{{ kolla_ansible_src_dir }}" - "{{ kolla_ansible_src_dir }}"
- "ansible{{ ansible_version_constraint }}" - "ansible{{ ansible_version_constraint }}"
- "ara<1.0.0" - "ara<1.0.0"
# TODO(mgoddard): Always use pip3 when previous_release is ussuri.
executable: "pip{{ playbook_python_version }}"
become: true become: true
# TODO(mgoddard): Always use python3 when previous_release is ussuri.
- name: get ARA callback plugin path - name: get ARA callback plugin path
command: "python -m ara.setup.callback_plugins" command: "python{{ playbook_python_version }} -m ara.setup.callback_plugins"
changed_when: false changed_when: false
register: ara_callback_plugins register: ara_callback_plugins
@ -172,7 +177,7 @@
remote_src: true remote_src: true
- name: generate passwords - name: generate passwords
shell: "{{ kolla_ansible_src_dir }}/tools/generate_passwords.py" command: kolla-genpwd
- name: slurp kolla passwords - name: slurp kolla passwords
slurp: slurp:
@ -195,13 +200,6 @@
- all - all
delegate_to: "{{ item }}" delegate_to: "{{ item }}"
- name: Install Python 3 package for Kolla
package:
name: python3
when:
need_build_image
become: true
- name: Record the running state of the environment as seen by the setup module - name: Record the running state of the environment as seen by the setup module
shell: shell:
cmd: ansible all -i {{ kolla_inventory_path }} -e ansible_user={{ ansible_user }} -m setup > /tmp/logs/ansible/initial-setup cmd: ansible all -i {{ kolla_inventory_path }} -e ansible_user={{ ansible_user }} -m setup > /tmp/logs/ansible/initial-setup
@ -361,9 +359,43 @@
when: "{{ scenario == 'ceph' }}" when: "{{ scenario == 'ceph' }}"
when: item.when | default(true) when: item.when | default(true)
# TODO(mgoddard): Remove this block when previous_release is ussuri.
- block:
- name: remove ansible and ARA for python 2
pip:
name:
- ansible
- ara
executable: pip2
state: absent
become: true
- name: install ansible and ARA for python 3
vars:
# Test latest ansible version on Ubuntu, minimum supported on others.
ansible_version_constraint: "{{ '>=2.6' if base_distro == 'ubuntu' else '<2.7' }}"
pip:
name:
- "ansible{{ ansible_version_constraint }}"
- "ara<1.0.0"
executable: pip3
become: true
- name: get ARA callback plugin path
command: "python3 -m ara.setup.callback_plugins"
changed_when: false
register: ara_callback_plugins
- name: template ansible.cfg
template:
src: "{{ kolla_ansible_local_src_dir }}/tests/templates/ansible.cfg.j2"
dest: /etc/ansible/ansible.cfg
become: true
- name: upgrade kolla-ansible - name: upgrade kolla-ansible
pip: pip:
name: "{{ kolla_ansible_src_dir }}" name: "{{ kolla_ansible_src_dir }}"
executable: pip3
become: true become: true
# Update passwords.yml to include any new passwords added in this # Update passwords.yml to include any new passwords added in this
@ -378,11 +410,11 @@
remote_src: true remote_src: true
- name: generate new passwords - name: generate new passwords
shell: "{{ kolla_ansible_src_dir }}/tools/generate_passwords.py" command: kolla-genpwd
- name: merge old and new passwords - name: merge old and new passwords
shell: >- command: >-
{{ kolla_ansible_src_dir }}/tools/merge_passwords.py kolla-mergepwd
--old /etc/kolla/passwords.yml.old --old /etc/kolla/passwords.yml.old
--new /etc/kolla/passwords.yml --new /etc/kolla/passwords.yml
--final /etc/kolla/passwords.yml --final /etc/kolla/passwords.yml

View File

@ -1,4 +1,10 @@
--- ---
# Force the use of python2 on remote hosts. This is necessary for delegate_to:
# localhost, which will otherwise use the local python interpreter (python3).
# On CentOS 7, that fails due to a lack of python3 bindings for SELinux.
# https://bugs.centos.org/view.php?id=16389
ansible_python_interpreter: /usr/bin/python2
kolla_base_distro: "{{ base_distro }}" kolla_base_distro: "{{ base_distro }}"
kolla_install_type: "{{ install_type }}" kolla_install_type: "{{ install_type }}"
network_interface: "{{ api_interface_name }}" network_interface: "{{ api_interface_name }}"