mirror of
https://github.com/ansible-collections/community.general.git
synced 2024-09-14 20:13:21 +02:00
c76e598d61
* Remove superfluous test.
* Use remote_temp_dir instead of output_dir on remote.
* Read certificate from correct place.
* Adjust more places.
* Fix boolean.
* Improve cryptography setup.
* Fix java_keystore changes.
* Need to copy binary from remote.
* Use correct Python for serve script.
* Sleep before downloading.
* Use correct Python interpreter.
* Avoid failing shebang test.
* Fix permission error with macOS 11.1.
* Avoid shebang trouble.
(cherry picked from commit 7c43cc3faa
)
Co-authored-by: Felix Fontein <felix@fontein.de>
106 lines
2.9 KiB
YAML
106 lines
2.9 KiB
YAML
- name: Skip unsupported platforms
|
|
meta: end_play
|
|
when: ansible_distribution == 'CentOS' and ansible_distribution_major_version is not version('7', '>=')
|
|
|
|
- name: Install Nomad and test
|
|
vars:
|
|
nomad_version: 0.12.4
|
|
nomad_uri: https://releases.hashicorp.com/nomad/{{ nomad_version }}/nomad_{{ nomad_version }}_{{ ansible_system | lower }}_{{ nomad_arch }}.zip
|
|
nomad_cmd: '{{ remote_tmp_dir }}/nomad'
|
|
block:
|
|
|
|
- name: register pyOpenSSL version
|
|
command: '{{ ansible_python_interpreter }} -c ''import OpenSSL; print(OpenSSL.__version__)'''
|
|
register: pyopenssl_version
|
|
|
|
- name: Install requests<2.20 (CentOS/RHEL 6)
|
|
pip:
|
|
name: requests<2.20
|
|
register: result
|
|
until: result is success
|
|
when: ansible_distribution_file_variety|default() == 'RedHat' and ansible_distribution_major_version is version('6', '<=')
|
|
|
|
- name: Install python-nomad
|
|
pip:
|
|
name: python-nomad
|
|
register: result
|
|
until: result is success
|
|
|
|
- name: Install jmespath
|
|
pip:
|
|
name: jmespath
|
|
register: result
|
|
until: result is success
|
|
|
|
- when: pyopenssl_version.stdout is version('0.15', '>=')
|
|
block:
|
|
- name: Generate privatekey
|
|
community.crypto.openssl_privatekey:
|
|
path: '{{ remote_tmp_dir }}/privatekey.pem'
|
|
|
|
- name: Generate CSR
|
|
community.crypto.openssl_csr:
|
|
path: '{{ remote_tmp_dir }}/csr.csr'
|
|
privatekey_path: '{{ remote_tmp_dir }}/privatekey.pem'
|
|
subject:
|
|
commonName: localhost
|
|
|
|
- name: Generate selfsigned certificate
|
|
register: selfsigned_certificate
|
|
community.crypto.openssl_certificate:
|
|
path: '{{ remote_tmp_dir }}/cert.pem'
|
|
csr_path: '{{ remote_tmp_dir }}/csr.csr'
|
|
privatekey_path: '{{ remote_tmp_dir }}/privatekey.pem'
|
|
provider: selfsigned
|
|
selfsigned_digest: sha256
|
|
|
|
- name: Install unzip
|
|
package:
|
|
name: unzip
|
|
register: result
|
|
until: result is success
|
|
when: ansible_distribution != "MacOSX"
|
|
|
|
- assert:
|
|
that: ansible_architecture in ['i386', 'x86_64', 'amd64']
|
|
|
|
- set_fact:
|
|
nomad_arch: '386'
|
|
when: ansible_architecture == 'i386'
|
|
|
|
- set_fact:
|
|
nomad_arch: amd64
|
|
when: ansible_architecture in ['x86_64', 'amd64']
|
|
|
|
- name: Download nomad binary
|
|
unarchive:
|
|
src: '{{ nomad_uri }}'
|
|
dest: '{{ remote_tmp_dir }}'
|
|
remote_src: true
|
|
register: result
|
|
until: result is success
|
|
|
|
- vars:
|
|
remote_dir: '{{ echo_remote_tmp_dir.stdout }}'
|
|
block:
|
|
|
|
- command: echo {{ remote_tmp_dir }}
|
|
register: echo_remote_tmp_dir
|
|
|
|
- name: Run tests integration
|
|
block:
|
|
- name: Start nomad (dev mode enabled)
|
|
shell: nohup {{ nomad_cmd }} agent -dev </dev/null >/dev/null 2>&1 &
|
|
|
|
- name: wait nomad up
|
|
wait_for:
|
|
host: localhost
|
|
port: 4646
|
|
delay: 10
|
|
timeout: 60
|
|
|
|
- import_tasks: nomad_job.yml
|
|
always:
|
|
|
|
- name: kill nomad
|
|
shell: pkill nomad
|