|
|
|
---
|
|
|
|
- name: test wait_for with delegate_to
|
|
|
|
wait_for:
|
|
|
|
timeout: 2
|
|
|
|
delegate_to: localhost
|
|
|
|
register: waitfor
|
|
|
|
|
|
|
|
- assert:
|
|
|
|
that:
|
|
|
|
- waitfor is successful
|
|
|
|
- waitfor.elapsed >= 2
|
|
|
|
|
|
|
|
- name: setup create a directory to serve files from
|
|
|
|
file:
|
|
|
|
dest: "{{ files_dir }}"
|
|
|
|
state: directory
|
|
|
|
|
|
|
|
- name: setup webserver
|
|
|
|
copy:
|
|
|
|
src: "testserver.py"
|
|
|
|
dest: "{{ output_dir }}/testserver.py"
|
|
|
|
|
|
|
|
- name: setup a path
|
|
|
|
file:
|
|
|
|
path: "{{ output_dir }}/wait_for_file"
|
|
|
|
state: touch
|
|
|
|
|
|
|
|
- name: setup remove a file after 3s
|
|
|
|
shell: sleep 3 && rm {{ output_dir }}/wait_for_file
|
|
|
|
async: 20
|
|
|
|
poll: 0
|
|
|
|
|
|
|
|
- name: test for absent path
|
|
|
|
wait_for:
|
|
|
|
path: "{{ output_dir }}/wait_for_file"
|
|
|
|
state: absent
|
|
|
|
timeout: 20
|
|
|
|
register: waitfor
|
|
|
|
- name: verify test for absent path
|
|
|
|
assert:
|
|
|
|
that:
|
|
|
|
- waitfor is successful
|
|
|
|
- waitfor.path == "{{ output_dir | expanduser }}/wait_for_file"
|
|
|
|
- waitfor.elapsed >= 2
|
|
|
|
- waitfor.elapsed <= 15
|
|
|
|
|
|
|
|
- name: setup create a file after 3s
|
|
|
|
shell: sleep 3 && touch {{ output_dir }}/wait_for_file
|
|
|
|
async: 20
|
|
|
|
poll: 0
|
|
|
|
|
|
|
|
- name: test for present path
|
|
|
|
wait_for:
|
|
|
|
path: "{{ output_dir }}/wait_for_file"
|
|
|
|
timeout: 5
|
|
|
|
register: waitfor
|
|
|
|
- name: verify test for absent path
|
|
|
|
assert:
|
|
|
|
that:
|
|
|
|
- waitfor is successful
|
|
|
|
- waitfor.path == "{{ output_dir | expanduser }}/wait_for_file"
|
|
|
|
- waitfor.elapsed >= 2
|
|
|
|
- waitfor.elapsed <= 15
|
|
|
|
|
|
|
|
- name: setup write keyword to file after 3s
|
|
|
|
shell: sleep 3 && echo completed > {{output_dir}}/wait_for_keyword
|
|
|
|
async: 20
|
|
|
|
poll: 0
|
|
|
|
|
|
|
|
- name: test wait for keyword in file
|
|
|
|
wait_for:
|
|
|
|
path: "{{output_dir}}/wait_for_keyword"
|
|
|
|
search_regex: completed
|
|
|
|
timeout: 5
|
|
|
|
register: waitfor
|
|
|
|
|
|
|
|
- name: verify test wait for keyword in file
|
|
|
|
assert:
|
|
|
|
that:
|
|
|
|
- waitfor is successful
|
|
|
|
- "waitfor.search_regex == 'completed'"
|
|
|
|
- waitfor.elapsed >= 2
|
|
|
|
- waitfor.elapsed <= 15
|
|
|
|
|
|
|
|
- name: setup write keyword to file after 3s
|
|
|
|
shell: sleep 3 && echo "completed data 123" > {{output_dir}}/wait_for_keyword
|
|
|
|
async: 20
|
|
|
|
poll: 0
|
|
|
|
|
|
|
|
- name: test wait for keyword in file with match groups
|
|
|
|
wait_for:
|
|
|
|
path: "{{output_dir}}/wait_for_keyword"
|
|
|
|
search_regex: completed (?P<foo>\w+) ([0-9]+)
|
|
|
|
timeout: 5
|
|
|
|
register: waitfor
|
|
|
|
|
|
|
|
- name: verify test wait for keyword in file with match groups
|
|
|
|
assert:
|
|
|
|
that:
|
|
|
|
- waitfor is successful
|
|
|
|
- waitfor.elapsed >= 2
|
|
|
|
- waitfor.elapsed <= 15
|
|
|
|
- waitfor['match_groupdict'] | length == 1
|
|
|
|
- waitfor['match_groupdict']['foo'] == 'data'
|
|
|
|
- waitfor['match_groups'] == ['data', '123']
|
|
|
|
|
|
|
|
- name: test wait for port timeout
|
|
|
|
wait_for:
|
|
|
|
port: 12121
|
|
|
|
timeout: 3
|
|
|
|
register: waitfor
|
|
|
|
ignore_errors: true
|
|
|
|
- name: verify test wait for port timeout
|
|
|
|
assert:
|
|
|
|
that:
|
|
|
|
- waitfor is failed
|
|
|
|
- waitfor.elapsed == 3
|
|
|
|
- "waitfor.msg == 'Timeout when waiting for 127.0.0.1:12121'"
|
|
|
|
|
|
|
|
- name: test fail with custom msg
|
|
|
|
wait_for:
|
|
|
|
port: 12121
|
|
|
|
msg: fail with custom message
|
|
|
|
timeout: 3
|
|
|
|
register: waitfor
|
|
|
|
ignore_errors: true
|
|
|
|
- name: verify test fail with custom msg
|
|
|
|
assert:
|
|
|
|
that:
|
|
|
|
- waitfor is failed
|
|
|
|
- waitfor.elapsed == 3
|
|
|
|
- "waitfor.msg == 'fail with custom message'"
|
|
|
|
|
|
|
|
- name: setup start SimpleHTTPServer
|
|
|
|
shell: sleep 3 && cd {{ files_dir }} && {{ ansible_python.executable }} {{ output_dir}}/testserver.py {{ http_port }}
|
|
|
|
async: 120 # this test set can take ~1m to run on FreeBSD (via Shippable)
|
|
|
|
poll: 0
|
|
|
|
|
|
|
|
- name: test wait for port with sleep
|
|
|
|
wait_for:
|
|
|
|
port: "{{ http_port }}"
|
|
|
|
sleep: 3
|
|
|
|
register: waitfor
|
|
|
|
- name: verify test wait for port sleep
|
|
|
|
assert:
|
|
|
|
that:
|
|
|
|
- waitfor is successful
|
|
|
|
- waitfor is not changed
|
|
|
|
- "waitfor.port == {{ http_port }}"
|
|
|
|
|
|
|
|
- name: install psutil using pip (non-Linux only)
|
|
|
|
pip:
|
|
|
|
name: psutil
|
|
|
|
when: ansible_system != 'Linux'
|
|
|
|
|
|
|
|
- name: Copy zombie.py
|
|
|
|
copy:
|
|
|
|
src: zombie.py
|
|
|
|
dest: "{{ output_dir }}"
|
|
|
|
|
|
|
|
- name: Create zombie process
|
|
|
|
shell: "{{ ansible_python.executable }} {{ output_dir }}/zombie"
|
|
|
|
async: 90
|
|
|
|
poll: 0
|
|
|
|
|
|
|
|
- name: test wait for port drained
|
|
|
|
wait_for:
|
|
|
|
port: "{{ http_port }}"
|
|
|
|
state: drained
|
|
|
|
register: waitfor
|
|
|
|
|
|
|
|
- name: verify test wait for port
|
|
|
|
assert:
|
|
|
|
that:
|
|
|
|
- waitfor is successful
|
|
|
|
- waitfor is not changed
|
|
|
|
- "waitfor.port == {{ http_port }}"
|