Enable developer mode

This commit adds the ability to install ceilometer without a repo
server. This pattern is lifted from the os_keystone role and allows
us to further develop functional testing for this role.

Change-Id: Id81a0e8d3cd76d589c0710fb960990ade57a7083
This commit is contained in:
Steve Lewis 2016-03-09 15:13:07 -08:00
parent e704560e49
commit 5727236e96
3 changed files with 66 additions and 5 deletions

View File

@ -20,6 +20,12 @@ verbose: True
## APT Cache options ## APT Cache options
cache_timeout: 600 cache_timeout: 600
ceilometer_git_repo: https://git.openstack.org/openstack/ceilometer
ceilometer_git_install_branch: master
ceilometer_developer_mode: false
ceilometer_developer_constraints:
- "git+{{ ceilometer_git_repo }}@{{ ceilometer_git_install_branch }}#egg=ceilometer"
# Name of the virtual env to deploy into # Name of the virtual env to deploy into
ceilometer_venv_tag: untagged ceilometer_venv_tag: untagged
ceilometer_venv_bin: "/openstack/venvs/ceilometer-{{ ceilometer_venv_tag }}/bin" ceilometer_venv_bin: "/openstack/venvs/ceilometer-{{ ceilometer_venv_tag }}/bin"
@ -109,6 +115,10 @@ ceilometer_apt_packages:
- rsync - rsync
- git - git
# Packages required in developer mode, where packages are built locally
ceilometer_developer_mode_apt_packages:
- libvirt-dev
# ceilometer packages that must be installed before anything else # ceilometer packages that must be installed before anything else
ceilometer_requires_pip_packages: ceilometer_requires_pip_packages:
- virtualenv - virtualenv

View File

@ -31,4 +31,6 @@ galaxy_info:
- openstack - openstack
dependencies: dependencies:
- openstack_openrc - openstack_openrc
- pip_lock_down - role: pip_lock_down
when:
- not ceilometer_developer_mode | bool

View File

@ -43,6 +43,43 @@
- ceilometer-install - ceilometer-install
- ceilometer-apt-packages - ceilometer-apt-packages
- name: Install packages required in Developer Mode
apt:
pkg: "{{ item }}"
state: latest
register: install_packages
until: install_packages|success
retries: 5
delay: 2
with_items: ceilometer_developer_mode_apt_packages
when:
- ceilometer_developer_mode | bool
tags:
- ceilometer-install
- ceilometer-apt-packages
- name: Create developer mode constraint file
copy:
dest: "/opt/developer-pip-constraints.txt"
content: |
{% for item in ceilometer_developer_constraints %}
{{ item }}
{% endfor %}
when:
- ceilometer_developer_mode | bool
tags:
- ceilometer-install
- ceilometer-pip-packages
- name: Set constraint file fact for developer mode
set_fact:
pip_install_options: "{{ pip_install_options|default('') }} --constraint /opt/developer-pip-constraints.txt"
when:
- ceilometer_developer_mode | bool
tags:
- ceilometer-install
- ceilometer-pip-packages
- name: Install requires pip packages - name: Install requires pip packages
pip: pip:
name: "{{ item }}" name: "{{ item }}"
@ -61,7 +98,9 @@
stat: stat:
path: "/var/cache/{{ ceilometer_venv_download_url | basename }}" path: "/var/cache/{{ ceilometer_venv_download_url | basename }}"
get_md5: False get_md5: False
when: ceilometer_venv_enabled | bool when:
- not ceilometer_developer_mode | bool
- ceilometer_venv_enabled | bool
register: local_venv_stat register: local_venv_stat
tags: tags:
- ceilometer-install - ceilometer-install
@ -71,7 +110,9 @@
uri: uri:
url: "{{ ceilometer_venv_download_url | replace('tgz', 'checksum') }}" url: "{{ ceilometer_venv_download_url | replace('tgz', 'checksum') }}"
return_content: True return_content: True
when: ceilometer_venv_enabled | bool when:
- not ceilometer_developer_mode | bool
- ceilometer_venv_enabled | bool
register: remote_venv_checksum register: remote_venv_checksum
tags: tags:
- ceilometer-install - ceilometer-install
@ -90,6 +131,7 @@
ignore_errors: true ignore_errors: true
register: get_venv register: get_venv
when: when:
- not ceilometer_developer_mode | bool
- ceilometer_venv_enabled | bool - ceilometer_venv_enabled | bool
- (local_venv_stat.stat.exists == False or - (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 }}) {{ local_venv_stat.stat.checksum is defined and local_venv_stat.stat.checksum != remote_venv_checksum.content | trim }})
@ -110,6 +152,7 @@
path: "{{ ceilometer_venv_bin | dirname }}" path: "{{ ceilometer_venv_bin | dirname }}"
state: absent state: absent
when: when:
- not ceilometer_developer_mode | bool
- ceilometer_venv_enabled | bool - ceilometer_venv_enabled | bool
- ceilometer_get_venv | changed - ceilometer_get_venv | changed
tags: tags:
@ -121,6 +164,7 @@
path: "{{ ceilometer_venv_bin | dirname }}" path: "{{ ceilometer_venv_bin | dirname }}"
state: directory state: directory
when: when:
- not ceilometer_developer_mode | bool
- ceilometer_venv_enabled | bool - ceilometer_venv_enabled | bool
- ceilometer_get_venv | changed - ceilometer_get_venv | changed
tags: tags:
@ -133,6 +177,7 @@
dest: "{{ ceilometer_venv_bin | dirname }}" dest: "{{ ceilometer_venv_bin | dirname }}"
copy: "no" copy: "no"
when: when:
- not ceilometer_developer_mode | bool
- ceilometer_venv_enabled | bool - ceilometer_venv_enabled | bool
- ceilometer_get_venv | changed - ceilometer_get_venv | changed
notify: Restart ceilometer services notify: Restart ceilometer services
@ -144,6 +189,7 @@
command: > command: >
virtualenv-tools --update-path=auto {{ ceilometer_venv_bin | dirname }} virtualenv-tools --update-path=auto {{ ceilometer_venv_bin | dirname }}
when: when:
- not ceilometer_developer_mode | bool
- ceilometer_venv_enabled | bool - ceilometer_venv_enabled | bool
- ceilometer_get_venv | success - ceilometer_get_venv | success
tags: tags:
@ -164,7 +210,8 @@
with_items: ceilometer_pip_packages with_items: ceilometer_pip_packages
when: when:
- ceilometer_venv_enabled | bool - ceilometer_venv_enabled | bool
- ceilometer_get_venv | failed - ceilometer_get_venv | failed or ceilometer_developer_mode | bool
notify: Restart ceilometer services notify: Restart ceilometer services
tags: tags:
- ceilometer-install - ceilometer-install
@ -180,7 +227,9 @@
retries: 5 retries: 5
delay: 2 delay: 2
with_items: ceilometer_pip_packages with_items: ceilometer_pip_packages
when: not ceilometer_venv_enabled | bool when:
- not ceilometer_developer_mode | bool
- not ceilometer_venv_enabled | bool
notify: Restart ceilometer services notify: Restart ceilometer services
tags: tags:
- ceilometer-install - ceilometer-install