
Ansible 2.1.1 introduces a regression in the way conditional includes are handled which results in every task in the included file being evaluated even if the condition for the include is not met. This extends the run time significantly for a deployment. This patch forces all conditional includes which are not inventory based to be dynamic. Change-Id: Ied462a7b79cb2d6615e110484ea734e136f59034 Related-Bug: https://github.com/ansible/ansible/issues/17687
162 lines
4.8 KiB
YAML
162 lines
4.8 KiB
YAML
---
|
|
# Copyright 2014, Rackspace US, Inc.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
|
|
- include: install-apt.yml
|
|
static: no
|
|
when: ansible_pkg_mgr == 'apt'
|
|
|
|
- name: Create developer mode constraint file
|
|
copy:
|
|
dest: "/opt/developer-pip-constraints.txt"
|
|
content: |
|
|
{% for item in swift_developer_constraints %}
|
|
{{ item }}
|
|
{% endfor %}
|
|
when:
|
|
- swift_developer_mode | bool
|
|
|
|
- name: Clone requirements git repository
|
|
git:
|
|
repo: "{{ swift_requirements_git_repo }}"
|
|
dest: "/opt/requirements"
|
|
clone: yes
|
|
update: yes
|
|
version: "{{ swift_requirements_git_install_branch }}"
|
|
when:
|
|
- swift_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:
|
|
- swift_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 swift_developer_mode | bool
|
|
|
|
- name: Install requires pip packages
|
|
pip:
|
|
name: "{{ swift_requires_pip_packages | join(' ') }}"
|
|
state: latest
|
|
extra_args: "{{ pip_install_options_fact }}"
|
|
register: install_packages
|
|
until: install_packages|success
|
|
retries: 5
|
|
delay: 2
|
|
|
|
- name: Get local venv checksum
|
|
stat:
|
|
path: "/var/cache/{{ swift_venv_download_url | basename }}"
|
|
get_md5: False
|
|
when:
|
|
- not swift_pypy_enabled | bool
|
|
- not swift_developer_mode | bool
|
|
register: local_venv_stat
|
|
|
|
- name: Get remote venv checksum
|
|
uri:
|
|
url: "{{ swift_venv_download_url | replace('tgz', 'checksum') }}"
|
|
return_content: True
|
|
when:
|
|
- not swift_pypy_enabled | bool
|
|
- not swift_developer_mode | bool
|
|
register: remote_venv_checksum
|
|
|
|
# TODO: When project moves to ansible 2 we can pass this a sha256sum which will:
|
|
# a) allow us to remove force: yes
|
|
# b) allow the module to calculate the checksum of dest file which would
|
|
# result in file being downloaded only if provided and dest sha256sum
|
|
# checksums differ
|
|
- name: Attempt venv download
|
|
get_url:
|
|
url: "{{ swift_venv_download_url }}"
|
|
dest: "/var/cache/{{ swift_venv_download_url | basename }}"
|
|
force: yes
|
|
ignore_errors: true
|
|
register: get_venv
|
|
when:
|
|
- not swift_pypy_enabled | bool
|
|
- not swift_developer_mode | bool
|
|
- (local_venv_stat.stat.exists == False or
|
|
{{ local_venv_stat.stat.checksum is defined and local_venv_stat.stat.checksum != remote_venv_checksum.content | trim }})
|
|
|
|
- name: Set swift get_venv fact
|
|
set_fact:
|
|
swift_get_venv: "{{ get_venv }}"
|
|
|
|
- name: Remove existing venv
|
|
file:
|
|
path: "{{ swift_bin | dirname }}"
|
|
state: absent
|
|
when:
|
|
- not swift_pypy_enabled | bool
|
|
- swift_get_venv | changed
|
|
|
|
- name: Create swift venv dir
|
|
file:
|
|
path: "{{ swift_bin | dirname }}"
|
|
state: directory
|
|
register: swift_venv_dir
|
|
|
|
- name: Unarchive pre-built venv
|
|
unarchive:
|
|
src: "/var/cache/{{ swift_venv_download_url | basename }}"
|
|
dest: "{{ swift_bin | dirname }}"
|
|
copy: "no"
|
|
when:
|
|
- not swift_pypy_enabled | bool
|
|
- not swift_developer_mode | bool
|
|
- swift_get_venv | changed or swift_venv_dir | changed
|
|
notify:
|
|
- Restart swift account services
|
|
- Restart swift container services
|
|
- Restart swift object services
|
|
- Restart swift proxy services
|
|
|
|
- name: Install pip packages
|
|
pip:
|
|
name: "{{ swift_pip_packages | join(' ') }}"
|
|
state: latest
|
|
virtualenv: "{{ swift_bin | dirname }}"
|
|
virtualenv_site_packages: "no"
|
|
extra_args: "{{ pip_install_options_fact }}"
|
|
register: install_packages
|
|
until: install_packages|success
|
|
retries: 5
|
|
delay: 2
|
|
when:
|
|
- not swift_pypy_enabled | bool
|
|
- swift_get_venv | failed or swift_developer_mode | bool
|
|
notify:
|
|
- Restart swift account services
|
|
- Restart swift container services
|
|
- Restart swift object services
|
|
- Restart swift proxy services
|
|
|
|
- name: Update virtualenv path
|
|
command: >
|
|
virtualenv-tools --update-path=auto {{ swift_bin | dirname }}
|
|
when:
|
|
- not swift_pypy_enabled | bool
|
|
- not swift_developer_mode | bool
|
|
- swift_get_venv | success
|
|
|
|
- include: swift_pypy_setup.yml
|
|
static: no
|
|
when: swift_pypy_enabled | bool
|