Remove activate-virtualenv and deactivate-virtualenv roles

These roles are no longer necessary now that Ansible supports setting
ansible_python_interpreter via a task- or role-scoped variable.

Change-Id: I4121d01dc83ac028350d4d98d3e1158e15fdfd63
Story: 2006574
Task: 38824
This commit is contained in:
Mark Goddard 2020-02-17 09:22:25 +00:00
parent 2de3a2c578
commit 2e842ab3f5
13 changed files with 81 additions and 170 deletions

View File

@ -18,14 +18,13 @@
os_openstacksdk_state: latest os_openstacksdk_state: latest
os_openstacksdk_upper_constraints_file: "{{ pip_upper_constraints_file }}" os_openstacksdk_upper_constraints_file: "{{ pip_upper_constraints_file }}"
- role: activate-virtualenv
activate_virtualenv_path: "{{ venv }}"
- name: Ensure baremetal compute nodes are inspected in ironic - name: Ensure baremetal compute nodes are inspected in ironic
hosts: baremetal-compute hosts: baremetal-compute
gather_facts: False gather_facts: False
vars: vars:
controller_host: "{{ groups['controllers'][0] }}" controller_host: "{{ groups['controllers'][0] }}"
venv: "{{ virtualenv_path }}/openstacksdk"
ansible_python_interpreter: "{{ venv }}/python"
# Whether to wait for the state transition to complete. # Whether to wait for the state transition to complete.
baremetal_compute_wait: True baremetal_compute_wait: True
# Time to wait for state transition to complete, if baremetal_compute_wait # Time to wait for state transition to complete, if baremetal_compute_wait
@ -46,9 +45,3 @@
# NOTE: Without this, the controller's ansible_host variable will not # NOTE: Without this, the controller's ansible_host variable will not
# be respected when using delegate_to. # be respected when using delegate_to.
ansible_host: "{{ hostvars[controller_host].ansible_host | default(controller_host) }}" ansible_host: "{{ hostvars[controller_host].ansible_host | default(controller_host) }}"
- name: Deactivate the virtual environment on the controller
hosts: controllers[0]
gather_facts: False
roles:
- role: deactivate-virtualenv

View File

@ -18,13 +18,12 @@
os_openstacksdk_state: latest os_openstacksdk_state: latest
os_openstacksdk_upper_constraints_file: "{{ pip_upper_constraints_file }}" os_openstacksdk_upper_constraints_file: "{{ pip_upper_constraints_file }}"
- role: activate-virtualenv
activate_virtualenv_path: "{{ venv }}"
- name: Ensure baremetal compute nodes are manageable in ironic - name: Ensure baremetal compute nodes are manageable in ironic
hosts: baremetal-compute hosts: baremetal-compute
gather_facts: False gather_facts: False
vars: vars:
venv: "{{ virtualenv_path }}/openstacksdk"
ansible_python_interpreter: "{{ venv }}/python"
# Whether to wait for the state transition to complete. # Whether to wait for the state transition to complete.
baremetal_compute_wait: True baremetal_compute_wait: True
# Time to wait for state transition to complete, if baremetal_compute_wait # Time to wait for state transition to complete, if baremetal_compute_wait
@ -41,9 +40,3 @@
os_ironic_state_wait: "{{ baremetal_compute_wait }}" os_ironic_state_wait: "{{ baremetal_compute_wait }}"
os_ironic_state_timeout: "{{ baremetal_compute_timeout }}" os_ironic_state_timeout: "{{ baremetal_compute_timeout }}"
os_ironic_state_delegate_to: "{{ groups['controllers'][0] }}" os_ironic_state_delegate_to: "{{ groups['controllers'][0] }}"
- name: Ensure baremetal compute nodes are available in ironic
hosts: controllers[0]
gather_facts: False
roles:
- role: deactivate-virtualenv

View File

@ -18,13 +18,12 @@
os_openstacksdk_state: latest os_openstacksdk_state: latest
os_openstacksdk_upper_constraints_file: "{{ pip_upper_constraints_file }}" os_openstacksdk_upper_constraints_file: "{{ pip_upper_constraints_file }}"
- role: activate-virtualenv
activate_virtualenv_path: "{{ venv }}"
- name: Ensure baremetal compute nodes are available in ironic - name: Ensure baremetal compute nodes are available in ironic
hosts: baremetal-compute hosts: baremetal-compute
gather_facts: False gather_facts: False
vars: vars:
venv: "{{ virtualenv_path }}/openstacksdk"
ansible_python_interpreter: "{{ venv }}/python"
# Whether to wait for the state transition to complete. # Whether to wait for the state transition to complete.
baremetal_compute_wait: True baremetal_compute_wait: True
# Time to wait for state transition to complete, if baremetal_compute_wait # Time to wait for state transition to complete, if baremetal_compute_wait
@ -41,9 +40,3 @@
os_ironic_state_wait: "{{ baremetal_compute_wait }}" os_ironic_state_wait: "{{ baremetal_compute_wait }}"
os_ironic_state_timeout: "{{ baremetal_compute_timeout }}" os_ironic_state_timeout: "{{ baremetal_compute_timeout }}"
os_ironic_state_delegate_to: "{{ groups['controllers'][0] }}" os_ironic_state_delegate_to: "{{ groups['controllers'][0] }}"
- name: Ensure baremetal compute nodes are available in ironic
hosts: controllers[0]
gather_facts: False
roles:
- role: deactivate-virtualenv

View File

@ -17,11 +17,6 @@
- not ansible_python_interpreter.startswith('/usr/bin') - not ansible_python_interpreter.startswith('/usr/bin')
- block: - block:
# This will cause ansible to use the system python interpreter.
- name: Deactivate the virtualenv
include_role:
name: deactivate-virtualenv
- name: Gather facts - name: Gather facts
setup: setup:
@ -66,12 +61,10 @@
# Site packages are required for using the yum and selinux python # Site packages are required for using the yum and selinux python
# modules, which are not available via PyPI. # modules, which are not available via PyPI.
virtualenv_site_packages: True virtualenv_site_packages: True
vars:
- name: Activate the virtualenv # Use the system python interpreter since the virtualenv might not
include_role: # exist.
name: activate-virtualenv ansible_python_interpreter: /usr/libexec/platform-python
vars:
activate_virtualenv_path: "{{ virtualenv }}"
when: virtualenv is defined when: virtualenv is defined
- block: - block:

View File

@ -3,6 +3,8 @@
hosts: seed-hypervisor:seed:overcloud hosts: seed-hypervisor:seed:overcloud
tags: tags:
- pip - pip
vars:
ansible_python_interpreter: /usr/libexec/platform-python
roles: roles:
- role: pip - role: pip
gather_facts: false gather_facts: false

View File

@ -78,11 +78,6 @@
# so during this transition we manually update them here if necessary. # so during this transition we manually update them here if necessary.
# TODO(mgoddard): Remove this code after a suitable transition period. # TODO(mgoddard): Remove this code after a suitable transition period.
- import_role:
role: activate-virtualenv
vars:
activate_virtualenv_path: "{{ venv }}"
- name: Ensure python-openstackclient is installed - name: Ensure python-openstackclient is installed
pip: pip:
name: python-openstackclient name: python-openstackclient
@ -106,6 +101,8 @@
changed_when: true changed_when: true
when: openstack_networks[0].shared when: openstack_networks[0].shared
environment: "{{ openstack_auth_env }}" environment: "{{ openstack_auth_env }}"
vars:
ansible_python_interpreter: "{{ venv }}/bin/python"
when: not provision_net.shared | bool when: not provision_net.shared | bool
- block: - block:
@ -123,9 +120,8 @@
changed_when: true changed_when: true
when: openstack_networks[0].shared when: openstack_networks[0].shared
environment: "{{ openstack_auth_env }}" environment: "{{ openstack_auth_env }}"
vars:
ansible_python_interpreter: "{{ venv }}/bin/python"
when: when:
- cleaning_net_name != provision_wl_net_name - cleaning_net_name != provision_wl_net_name
- not cleaning_net.shared | bool - not cleaning_net.shared | bool
- import_role:
role: deactivate-virtualenv

View File

@ -1,3 +0,0 @@
---
# Path to a virtualenv to activate.
activate_virtualenv_path:

View File

@ -1,10 +0,0 @@
---
- name: Set a fact containing the current python interpreter
set_fact:
activate_virtualenv_current_python_interpreter: "{{ ansible_python_interpreter | default('/usr/bin/python') }}"
# Note that setting this via a play or task variable seems to not
# evaluate the Jinja variable reference, so we use set_fact.
- name: Update the Ansible python interpreter fact to point to the virtualenv
set_fact:
ansible_python_interpreter: "{{ activate_virtualenv_path }}/bin/python"

View File

@ -1,5 +0,0 @@
---
# Path to a python interpreter to set as the ansible_python_interpreter
# variable. The default uses a variable set by the activate-virtualenv role
# containing the original python interpreter before entering the virtualenv.
deactivate_virtualenv_python_interpreter: "{{ activate_virtualenv_current_python_interpreter | default('/usr/bin/python') }}"

View File

@ -1,6 +0,0 @@
---
# This variable is unset before we set it, and it does not appear to be
# possible to unset a variable in Ansible.
- name: Set a fact to reset the Ansible python interpreter
set_fact:
ansible_python_interpreter: "{{ deactivate_virtualenv_python_interpreter }}"

View File

@ -50,12 +50,6 @@
when: when:
- not item.exists - not item.exists
- name: Activate the virtualenv
include_role:
name: activate-virtualenv
vars:
activate_virtualenv_path: "{{ ipa_images_venv }}"
- name: Ensure we have python-ironicclient installed - name: Ensure we have python-ironicclient installed
pip: pip:
name: python-ironicclient name: python-ironicclient
@ -66,72 +60,71 @@
# To support updating the IPA image, we check the MD5 sum of the cached image # To support updating the IPA image, we check the MD5 sum of the cached image
# files, and compare with the images in Glance (if there are any). # files, and compare with the images in Glance (if there are any).
- name: Gather facts about Ironic Python Agent (IPA) kernel image - block:
os_image_facts: - name: Gather facts about Ironic Python Agent (IPA) kernel image
auth_type: "{{ ipa_images_openstack_auth_type }}" os_image_facts:
auth: "{{ ipa_images_openstack_auth }}" auth_type: "{{ ipa_images_openstack_auth_type }}"
cacert: "{{ ipa_images_openstack_cacert | default(omit, true) }}" auth: "{{ ipa_images_openstack_auth }}"
interface: "{{ ipa_images_openstack_interface | default(omit, true) }}" cacert: "{{ ipa_images_openstack_cacert | default(omit, true) }}"
image: "{{ ipa_images_kernel_name }}" interface: "{{ ipa_images_openstack_interface | default(omit, true) }}"
image: "{{ ipa_images_kernel_name }}"
- name: Set a fact containing the Ironic Python Agent (IPA) kernel image - name: Set a fact containing the Ironic Python Agent (IPA) kernel image
set_fact: set_fact:
ipa_images_kernel_openstack_image: "{{ openstack_image if openstack_image else {} }}" ipa_images_kernel_openstack_image: "{{ openstack_image if openstack_image else {} }}"
- name: Gather facts about Ironic Python Agent (IPA) ramdisk image - name: Gather facts about Ironic Python Agent (IPA) ramdisk image
os_image_facts: os_image_facts:
auth_type: "{{ ipa_images_openstack_auth_type }}" auth_type: "{{ ipa_images_openstack_auth_type }}"
auth: "{{ ipa_images_openstack_auth }}" auth: "{{ ipa_images_openstack_auth }}"
cacert: "{{ ipa_images_openstack_cacert | default(omit, true) }}" cacert: "{{ ipa_images_openstack_cacert | default(omit, true) }}"
interface: "{{ ipa_images_openstack_interface | default(omit, true) }}" interface: "{{ ipa_images_openstack_interface | default(omit, true) }}"
image: "{{ ipa_images_ramdisk_name }}" image: "{{ ipa_images_ramdisk_name }}"
- name: Set a fact containing the Ironic Python Agent (IPA) ramdisk image - name: Set a fact containing the Ironic Python Agent (IPA) ramdisk image
set_fact: set_fact:
ipa_images_ramdisk_openstack_image: "{{ openstack_image if openstack_image else {} }}" ipa_images_ramdisk_openstack_image: "{{ openstack_image if openstack_image else {} }}"
# The os_image module will get confused if there are multiple images with the # The os_image module will get confused if there are multiple images with the
# same name, so rename the old images. They will still be accessible via UUID. # same name, so rename the old images. They will still be accessible via UUID.
- name: Ensure old Ironic Python Agent (IPA) images are renamed - name: Ensure old Ironic Python Agent (IPA) images are renamed
command: > command: >
{{ ipa_images_venv }}/bin/openstack image set {{ item.name }} --name {{ item.name }}.{{ extension }} {{ ipa_images_venv }}/bin/openstack image set {{ item.name }} --name {{ item.name }}.{{ extension }}
vars:
extension: "{{ item.created_at | replace(':', '-') }}~"
with_items:
- name: "{{ ipa_images_kernel_name }}"
created_at: "{{ ipa_images_kernel_openstack_image.created_at | default }}"
checksum: "{{ ipa_images_checksum.results[0].stat.checksum }}"
glance_checksum: "{{ ipa_images_kernel_openstack_image.checksum | default }}"
- name: "{{ ipa_images_ramdisk_name }}"
created_at: "{{ ipa_images_ramdisk_openstack_image.created_at | default }}"
checksum: "{{ ipa_images_checksum.results[1].stat.checksum }}"
glance_checksum: "{{ ipa_images_ramdisk_openstack_image.checksum | default }}"
when:
- item.glance_checksum
- item.checksum != item.glance_checksum
environment: "{{ ipa_images_openstack_auth_env }}"
- name: Ensure Ironic Python Agent (IPA) images are registered with Glance
os_image:
auth_type: "{{ ipa_images_openstack_auth_type }}"
auth: "{{ ipa_images_openstack_auth }}"
cacert: "{{ ipa_images_openstack_cacert | default(omit, true) }}"
interface: "{{ ipa_images_openstack_interface | default(omit, true) }}"
name: "{{ item.name }}"
container_format: "{{ item.format }}"
disk_format: "{{ item.format }}"
state: present
filename: "{{ ipa_images_cache_path }}/{{ item.name }}"
with_items:
- name: "{{ ipa_images_kernel_name }}"
format: aki
- name: "{{ ipa_images_ramdisk_name }}"
format: ari
register: ipa_images_new_images
- include_tasks: set-driver-info.yml
when: ipa_images_update_ironic_nodes | bool
vars: vars:
extension: "{{ item.created_at | replace(':', '-') }}~" ansible_python_interpreter: "{{ ipa_images_venv }}/bin/python"
with_items:
- name: "{{ ipa_images_kernel_name }}"
created_at: "{{ ipa_images_kernel_openstack_image.created_at | default }}"
checksum: "{{ ipa_images_checksum.results[0].stat.checksum }}"
glance_checksum: "{{ ipa_images_kernel_openstack_image.checksum | default }}"
- name: "{{ ipa_images_ramdisk_name }}"
created_at: "{{ ipa_images_ramdisk_openstack_image.created_at | default }}"
checksum: "{{ ipa_images_checksum.results[1].stat.checksum }}"
glance_checksum: "{{ ipa_images_ramdisk_openstack_image.checksum | default }}"
when:
- item.glance_checksum
- item.checksum != item.glance_checksum
environment: "{{ ipa_images_openstack_auth_env }}"
- name: Ensure Ironic Python Agent (IPA) images are registered with Glance
os_image:
auth_type: "{{ ipa_images_openstack_auth_type }}"
auth: "{{ ipa_images_openstack_auth }}"
cacert: "{{ ipa_images_openstack_cacert | default(omit, true) }}"
interface: "{{ ipa_images_openstack_interface | default(omit, true) }}"
name: "{{ item.name }}"
container_format: "{{ item.format }}"
disk_format: "{{ item.format }}"
state: present
filename: "{{ ipa_images_cache_path }}/{{ item.name }}"
with_items:
- name: "{{ ipa_images_kernel_name }}"
format: aki
- name: "{{ ipa_images_ramdisk_name }}"
format: ari
register: ipa_images_new_images
- include_tasks: set-driver-info.yml
when: ipa_images_update_ironic_nodes | bool
- name: Deactivate the virtualenv
include_role:
name: deactivate-virtualenv

View File

@ -9,13 +9,9 @@
with_items: with_items:
- name: python-ironic-inspector-client - name: python-ironic-inspector-client
- name: Activate the virtualenv
include_role:
name: activate-virtualenv
vars:
activate_virtualenv_path: "{{ ironic_inspector_venv }}"
- name: Ensure introspection rules exist - name: Ensure introspection rules exist
vars:
ansible_python_interpreter: "{{ ironic_inspector_venv }}/bin/python"
os_ironic_inspector_rule: os_ironic_inspector_rule:
auth_type: "{{ ironic_inspector_auth_type }}" auth_type: "{{ ironic_inspector_auth_type }}"
auth: "{{ ironic_inspector_auth }}" auth: "{{ ironic_inspector_auth }}"
@ -28,7 +24,3 @@
state: present state: present
inspector_url: "{{ ironic_inspector_url }}" inspector_url: "{{ ironic_inspector_url }}"
with_items: "{{ ironic_inspector_rules }}" with_items: "{{ ironic_inspector_rules }}"
- name: Deactivate the virtualenv
include_role:
name: deactivate-virtualenv

View File

@ -1,17 +1,4 @@
--- ---
- name: Set a fact about the virtualenv
set_fact:
virtualenv: "{{ ansible_python_interpreter | dirname | dirname }}"
when:
- ansible_python_interpreter is defined
- not ansible_python_interpreter.startswith('/bin')
- not ansible_python_interpreter.startswith('/usr/bin')
- name: Deactivate the virtualenv
include_role:
name: deactivate-virtualenv
when: virtualenv is defined
- name: Create local .pip directory for {{ user }} - name: Create local .pip directory for {{ user }}
file: file:
path: "~{{ user }}/.pip" path: "~{{ user }}/.pip"
@ -42,10 +29,3 @@
dest: "~{{ user}}/.pydistutils.cfg" dest: "~{{ user}}/.pydistutils.cfg"
become: True become: True
become_user: "{{ user }}" become_user: "{{ user }}"
- name: Activate the virtualenv
include_role:
name: activate-virtualenv
vars:
activate_virtualenv_path: "{{ virtualenv }}"
when: virtualenv is defined