install rabbitmq-server in serial

In order to prevent race conditions with nodes joining the cluster
simultaneously when the cluster is first formed, we move the rabbitmq
installation play to be 'serial: 1'. However, when the nodes are being
upgraded, it cannot be done in serial so in this case we set 'serial: 0'

The tests are removed from a post_task include in the install play, and
moved to their own play as they need to be run after the entire cluster
has been formed. As well as moving a few generic vars into the
test-vars.yml include, we also pass in the specific version of rabbitmq
to be tested against in the test play.

Fixes-Bug: #1573030

Change-Id: Id119ff9f20ddfd8e1f29598c8c5ce862d2e7fab4
This commit is contained in:
Darren Birkett 2016-05-05 22:36:34 +01:00
parent 4da96df136
commit 5dc67955f0
4 changed files with 74 additions and 49 deletions

View File

@ -13,48 +13,55 @@
# See the License for the specific language governing permissions and # See the License for the specific language governing permissions and
# limitations under the License. # limitations under the License.
- name: Check rabbitmq is running - name: Run functional tests
command: "pgrep rabbit" hosts: rabbitmq_all
delegate_to: "{{ item }}" user: root
when: ansible_ssh_host == item gather_facts: true
with_items: vars_files:
- 10.100.100.101 - test-vars.yml
- 10.100.100.102 tasks:
- 10.100.100.103 - name: Check rabbitmq is running
- name: Open rabbitmq.config command: "pgrep rabbit"
slurp: delegate_to: "{{ item }}"
src: "/etc/rabbitmq/rabbitmq.config" when: ansible_ssh_host == item
register: rabbitmq_config with_items:
- name: Open enabled_plugins - 10.100.100.101
slurp: - 10.100.100.102
src: "/etc/rabbitmq/enabled_plugins" - 10.100.100.103
register: enabled_plugins - name: Open rabbitmq.config
- name: Read rabbitmq_ssl_cert slurp:
stat: src: "/etc/rabbitmq/rabbitmq.config"
path: "{{ rabbitmq_ssl_cert }}" register: rabbitmq_config
register: rabbitmq_ssl_cert_stat - name: Open enabled_plugins
- name: Read rabbitmq_ssl_key slurp:
stat: src: "/etc/rabbitmq/enabled_plugins"
path: "{{ rabbitmq_ssl_key }}" register: enabled_plugins
register: rabbitmq_ssl_key_stat - name: Read rabbitmq_ssl_cert
- name: Read rabbit files stat:
set_fact: path: "{{ rabbitmq_ssl_cert }}"
enabled_plugins_contents: "{{ enabled_plugins.content | b64decode }}" register: rabbitmq_ssl_cert_stat
rabbitmq_config_contents: "{{ rabbitmq_config.content | b64decode }}" - name: Read rabbitmq_ssl_key
rabbitmq_ssl_cert_checksum: "{{ rabbitmq_ssl_cert_stat.stat.checksum }}" stat:
rabbitmq_ssl_key_checksum: "{{ rabbitmq_ssl_key_stat.stat.checksum }}" path: "{{ rabbitmq_ssl_key }}"
- name: Check files contents register: rabbitmq_ssl_key_stat
assert: - name: Read rabbit files
that: set_fact:
- "'rabbitmq_management' in enabled_plugins_contents" enabled_plugins_contents: "{{ enabled_plugins.content | b64decode }}"
- name: Get status of rabbitmq rabbitmq_config_contents: "{{ rabbitmq_config.content | b64decode }}"
command: rabbitmqctl status rabbitmq_ssl_cert_checksum: "{{ rabbitmq_ssl_cert_stat.stat.checksum }}"
register: rabbitmqctl_status rabbitmq_ssl_key_checksum: "{{ rabbitmq_ssl_key_stat.stat.checksum }}"
- name: Ensure SSL cert/key checksums are identical across cluster - name: Check files contents
assert: assert:
that: that:
- hostvars['container1']['rabbitmq_ssl_cert_checksum'] == hostvars['container2']['rabbitmq_ssl_cert_checksum'] == hostvars['container3']['rabbitmq_ssl_cert_checksum'] - "'rabbitmq_management' in enabled_plugins_contents"
- hostvars['container1']['rabbitmq_ssl_key_checksum'] == hostvars['container2']['rabbitmq_ssl_key_checksum'] == hostvars['container3']['rabbitmq_ssl_key_checksum'] - name: Get status of rabbitmq
- name: Ensure expected version of rabbitmq is running command: rabbitmqctl status
assert: register: rabbitmqctl_status
that: rabbitmqctl_status.stdout | search ("rabbit,\"RabbitMQ\",\"{{ rabbitmq_package_version.split('-')[0] }}\"") - name: Ensure SSL cert/key checksums are identical across cluster
assert:
that:
- hostvars['container1']['rabbitmq_ssl_cert_checksum'] == hostvars['container2']['rabbitmq_ssl_cert_checksum'] == hostvars['container3']['rabbitmq_ssl_cert_checksum']
- hostvars['container1']['rabbitmq_ssl_key_checksum'] == hostvars['container2']['rabbitmq_ssl_key_checksum'] == hostvars['container3']['rabbitmq_ssl_key_checksum']
- name: Ensure expected version of rabbitmq is running
assert:
that: rabbitmqctl_status.stdout | search ("rabbit,\"RabbitMQ\",\"{{ rabbitmq_package_version.split('-')[0] }}\"")

View File

@ -13,14 +13,14 @@
# See the License for the specific language governing permissions and # See the License for the specific language governing permissions and
# limitations under the License. # limitations under the License.
# NOTE(mancdaz): rabbitmq cannot be upgraded in serial, so when
# rabbitmq_upgrade=True, serial is set to 0, else it is 1 for installs
- name: Install RabbitMQ server - name: Install RabbitMQ server
hosts: rabbitmq_all hosts: rabbitmq_all
serial: "{{ rabbitmq_upgrade|default(false) | bool | ternary(0, 1)}}"
user: root user: root
gather_facts: true gather_facts: true
roles: roles:
- role: "{{ rolename | basename }}" - role: "{{ rolename | basename }}"
rabbitmq_cookie_token: secrete
post_tasks:
- include: test-functional.yml
vars_files: vars_files:
- test-vars.yml - test-vars.yml

View File

@ -1 +1,3 @@
rabbitmq_cookie_token: secrete rabbitmq_cookie_token: secrete
rabbitmq_ssl_cert: /etc/rabbitmq/rabbitmq.pem
rabbitmq_ssl_key: /etc/rabbitmq/rabbitmq.key

View File

@ -25,6 +25,11 @@
# Install RabbitMQ server # Install RabbitMQ server
- include: test-install-rabbitmq-server.yml - include: test-install-rabbitmq-server.yml
# Run tests
- include: test-functional.yml
vars:
rabbitmq_package_version: "3.6.1-1"
############################# UPGRADE TESTING ############################# ############################# UPGRADE TESTING #############################
# Run container clean up and build # Run container clean up and build
@ -37,7 +42,18 @@
rabbitmq_package_version: "{{ rabbitmq_package_url.split('/')[-1].split('_')[1] }}" rabbitmq_package_version: "{{ rabbitmq_package_url.split('/')[-1].split('_')[1] }}"
rabbitmq_package_sha256: "b8a42321c2f2689dc579911fbb583bd9c4d2ce2f20003d7050d5a324a6d2de42" rabbitmq_package_sha256: "b8a42321c2f2689dc579911fbb583bd9c4d2ce2f20003d7050d5a324a6d2de42"
# Perform upgrade of RabbitMQ server # Run tests
- include: test-functional.yml
vars:
rabbitmq_package_version: "3.5.7-1"
# Perform upgrade of RabbitMQ server (package_version will come
# from role defaults)
- include: test-install-rabbitmq-server.yml - include: test-install-rabbitmq-server.yml
vars: vars:
rabbitmq_upgrade: true rabbitmq_upgrade: true
# Run tests
- include: test-functional.yml
vars:
rabbitmq_package_version: "3.6.1-1"