Simplify pip options/constraints mechanism

The current constraints generation for the
installation involves multiple tasks and multiple
variables.

Using multiple tasks extends the installation time
unnecessarily and the additional variables are
unnecessary.

This patch aims to simplify the mechanism and
hopes to speed it up a little.

Change-Id: I2b3aff99b8ee1c8870f89598cf7cf0a2165af3b6
This commit is contained in:
Jesse Pretorius 2016-11-02 13:35:41 +00:00 committed by Jesse Pretorius (odyssey4me)
parent cf56eca98d
commit 2c7c486543
4 changed files with 20 additions and 32 deletions

View File

@ -36,9 +36,6 @@ neutron_vpnaas_git_install_branch: master
neutron_dynamic_routing_git_repo: https://git.openstack.org/openstack/neutron-dynamic-routing neutron_dynamic_routing_git_repo: https://git.openstack.org/openstack/neutron-dynamic-routing
neutron_dynamic_routing_git_install_branch: master neutron_dynamic_routing_git_install_branch: master
neutron_requirements_git_repo: https://git.openstack.org/openstack/requirements
neutron_requirements_git_install_branch: master
calico_git_repo: https://github.com/projectcalico/felix calico_git_repo: https://github.com/projectcalico/felix
calico_git_package_name: calico calico_git_package_name: calico
calico_git_install_branch: master calico_git_install_branch: master

View File

@ -0,0 +1,7 @@
---
upgrade:
- The variables ``neutron_requirements_git_repo`` and
``neutron_requirements_git_install_branch`` have been
removed in favour of using the URL/path to the
upper-constraints file using the
variable ``pip_install_upper_constraints`` instead.

View File

@ -15,16 +15,18 @@
- name: Install Calico pip packages - name: Install Calico pip packages
pip: pip:
name: "{{ item }}" name: "{{ neutron_optional_calico_pip_packages | join(' ') }}"
state: "{{ neutron_pip_package_state }}" state: "{{ neutron_pip_package_state }}"
virtualenv: "{{ neutron_bin | dirname }}" virtualenv: "{{ neutron_bin | dirname }}"
virtualenv_site_packages: "no" virtualenv_site_packages: "no"
extra_args: "{{ pip_install_options_fact }}" extra_args: >-
{{ neutron_developer_mode | ternary('--constraint /opt/developer-pip-constraints.txt', '') }}
{{ (pip_install_upper_constraints is defined) | ternary('--constraint ' + pip_install_upper_constraints | default(''),'') }}
{{ pip_install_options | default('') }}
register: install_packages register: install_packages
until: install_packages|success until: install_packages|success
retries: 5 retries: 5
delay: 2 delay: 2
with_items: "{{ neutron_optional_calico_pip_packages }}"
when: when:
- neutron_services['neutron-server']['group'] in group_names - neutron_services['neutron-server']['group'] in group_names
or neutron_services['calico-felix']['group'] in group_names or neutron_services['calico-felix']['group'] in group_names

View File

@ -26,36 +26,15 @@
{% for item in neutron_developer_constraints %} {% for item in neutron_developer_constraints %}
{{ item }} {{ item }}
{% endfor %} {% endfor %}
when: when: neutron_developer_mode | bool
- neutron_developer_mode | bool
- name: Clone requirements git repository
git:
repo: "{{ neutron_requirements_git_repo }}"
dest: "/opt/requirements"
clone: yes
update: yes
version: "{{ neutron_requirements_git_install_branch }}"
when:
- neutron_developer_mode | bool
- name: Add constraints to pip_install_options fact for developer mode
set_fact:
pip_install_options_fact: "{{ pip_install_options|default('') }} --constraint /opt/developer-pip-constraints.txt --constraint /opt/requirements/upper-constraints.txt"
when:
- neutron_developer_mode | bool
- name: Set pip_install_options_fact when not in developer mode
set_fact:
pip_install_options_fact: "{{ pip_install_options|default('') }}"
when:
- not neutron_developer_mode | bool
- name: Install requires pip packages - name: Install requires pip packages
pip: pip:
name: "{{ neutron_requires_pip_packages | join(' ') }}" name: "{{ neutron_requires_pip_packages | join(' ') }}"
state: "{{ neutron_pip_package_state }}" state: "{{ neutron_pip_package_state }}"
extra_args: "{{ pip_install_options_fact }}" extra_args: >-
{{ (pip_install_upper_constraints is defined) | ternary('--constraint ' + pip_install_upper_constraints | default(''),'') }}
{{ pip_install_options | default('') }}
register: install_packages register: install_packages
until: install_packages|success until: install_packages|success
retries: 5 retries: 5
@ -129,7 +108,10 @@
state: "{{ neutron_pip_package_state }}" state: "{{ neutron_pip_package_state }}"
virtualenv: "{{ neutron_bin | dirname }}" virtualenv: "{{ neutron_bin | dirname }}"
virtualenv_site_packages: "no" virtualenv_site_packages: "no"
extra_args: "{{ pip_install_options_fact }}" extra_args: >-
{{ neutron_developer_mode | ternary('--constraint /opt/developer-pip-constraints.txt', '') }}
{{ (pip_install_upper_constraints is defined) | ternary('--constraint ' + pip_install_upper_constraints | default(''),'') }}
{{ pip_install_options | default('') }}
register: install_packages register: install_packages
until: install_packages|success until: install_packages|success
retries: 5 retries: 5