mirror of https://github.com/ansible/ansible.git
You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
117 lines
5.6 KiB
Bash
117 lines
5.6 KiB
Bash
#!/usr/bin/env bash
|
|
|
|
set -eux
|
|
|
|
export ANSIBLE_FORCE_HANDLERS
|
|
|
|
ANSIBLE_FORCE_HANDLERS=false
|
|
|
|
# simple handler test
|
|
ansible-playbook test_handlers.yml -i inventory.handlers -v "$@" --tags scenario1
|
|
|
|
# simple from_handlers test
|
|
ansible-playbook from_handlers.yml -i inventory.handlers -v "$@" --tags scenario1
|
|
|
|
ansible-playbook test_listening_handlers.yml -i inventory.handlers -v "$@"
|
|
|
|
[ "$(ansible-playbook test_handlers.yml -i inventory.handlers -v "$@" --tags scenario2 -l A \
|
|
| grep -E -o 'RUNNING HANDLER \[test_handlers : .*]')" = "RUNNING HANDLER [test_handlers : test handler]" ]
|
|
|
|
# Test forcing handlers using the linear and free strategy
|
|
for strategy in linear free; do
|
|
|
|
export ANSIBLE_STRATEGY=$strategy
|
|
|
|
# Not forcing, should only run on successful host
|
|
[ "$(ansible-playbook test_force_handlers.yml -i inventory.handlers -v "$@" --tags normal \
|
|
| grep -E -o CALLED_HANDLER_. | sort | uniq | xargs)" = "CALLED_HANDLER_B" ]
|
|
|
|
# Forcing from command line
|
|
[ "$(ansible-playbook test_force_handlers.yml -i inventory.handlers -v "$@" --tags normal --force-handlers \
|
|
| grep -E -o CALLED_HANDLER_. | sort | uniq | xargs)" = "CALLED_HANDLER_A CALLED_HANDLER_B" ]
|
|
|
|
# Forcing from command line, should only run later tasks on unfailed hosts
|
|
[ "$(ansible-playbook test_force_handlers.yml -i inventory.handlers -v "$@" --tags normal --force-handlers \
|
|
| grep -E -o CALLED_TASK_. | sort | uniq | xargs)" = "CALLED_TASK_B CALLED_TASK_D CALLED_TASK_E" ]
|
|
|
|
# Forcing from command line, should call handlers even if all hosts fail
|
|
[ "$(ansible-playbook test_force_handlers.yml -i inventory.handlers -v "$@" --tags normal --force-handlers -e fail_all=yes \
|
|
| grep -E -o CALLED_HANDLER_. | sort | uniq | xargs)" = "CALLED_HANDLER_A CALLED_HANDLER_B" ]
|
|
|
|
# Forcing from ansible.cfg
|
|
[ "$(ANSIBLE_FORCE_HANDLERS=true ansible-playbook test_force_handlers.yml -i inventory.handlers -v "$@" --tags normal \
|
|
| grep -E -o CALLED_HANDLER_. | sort | uniq | xargs)" = "CALLED_HANDLER_A CALLED_HANDLER_B" ]
|
|
|
|
# Forcing true in play
|
|
[ "$(ansible-playbook test_force_handlers.yml -i inventory.handlers -v "$@" --tags force_true_in_play \
|
|
| grep -E -o CALLED_HANDLER_. | sort | uniq | xargs)" = "CALLED_HANDLER_A CALLED_HANDLER_B" ]
|
|
|
|
# Forcing false in play, which overrides command line
|
|
[ "$(ansible-playbook test_force_handlers.yml -i inventory.handlers -v "$@" --tags force_false_in_play --force-handlers \
|
|
| grep -E -o CALLED_HANDLER_. | sort | uniq | xargs)" = "CALLED_HANDLER_B" ]
|
|
|
|
unset ANSIBLE_STRATEGY
|
|
|
|
done
|
|
|
|
[ "$(ansible-playbook test_handlers_include.yml -i ../../inventory -v "$@" --tags playbook_include_handlers \
|
|
| grep -E -o 'RUNNING HANDLER \[.*]')" = "RUNNING HANDLER [test handler]" ]
|
|
|
|
[ "$(ansible-playbook test_handlers_include.yml -i ../../inventory -v "$@" --tags role_include_handlers \
|
|
| grep -E -o 'RUNNING HANDLER \[test_handlers_include : .*]')" = "RUNNING HANDLER [test_handlers_include : test handler]" ]
|
|
|
|
[ "$(ansible-playbook test_handlers_include_role.yml -i ../../inventory -v "$@" \
|
|
| grep -E -o 'RUNNING HANDLER \[test_handlers_include_role : .*]')" = "RUNNING HANDLER [test_handlers_include_role : test handler]" ]
|
|
|
|
# Notify handler listen
|
|
ansible-playbook test_handlers_listen.yml -i inventory.handlers -v "$@"
|
|
|
|
# Notify inexistent handlers results in error
|
|
set +e
|
|
result="$(ansible-playbook test_handlers_inexistent_notify.yml -i inventory.handlers "$@" 2>&1)"
|
|
set -e
|
|
grep -q "ERROR! The requested handler 'notify_inexistent_handler' was not found in either the main handlers list nor in the listening handlers list" <<< "$result"
|
|
|
|
# Notify inexistent handlers without errors when ANSIBLE_ERROR_ON_MISSING_HANDLER=false
|
|
ANSIBLE_ERROR_ON_MISSING_HANDLER=false ansible-playbook test_handlers_inexistent_notify.yml -i inventory.handlers -v "$@"
|
|
|
|
ANSIBLE_ERROR_ON_MISSING_HANDLER=false ansible-playbook test_templating_in_handlers.yml -v "$@"
|
|
|
|
# https://github.com/ansible/ansible/issues/36649
|
|
output_dir=/tmp
|
|
set +e
|
|
result="$(ansible-playbook test_handlers_any_errors_fatal.yml -e output_dir=$output_dir -i inventory.handlers -v "$@" 2>&1)"
|
|
set -e
|
|
[ ! -f $output_dir/should_not_exist_B ] || (rm -f $output_dir/should_not_exist_B && exit 1)
|
|
|
|
# https://github.com/ansible/ansible/issues/47287
|
|
[ "$(ansible-playbook test_handlers_including_task.yml -i ../../inventory -v "$@" | grep -E -o 'failed=[0-9]+')" = "failed=0" ]
|
|
|
|
# https://github.com/ansible/ansible/issues/71222
|
|
ansible-playbook test_role_handlers_including_tasks.yml -i ../../inventory -v "$@"
|
|
|
|
# https://github.com/ansible/ansible/issues/27237
|
|
set +e
|
|
result="$(ansible-playbook test_handlers_template_run_once.yml -i inventory.handlers "$@" 2>&1)"
|
|
set -e
|
|
grep -q "handler A" <<< "$result"
|
|
grep -q "handler B" <<< "$result"
|
|
|
|
# Test an undefined variable in another handler name isn't a failure
|
|
ansible-playbook 58841.yml "$@" --tags lazy_evaluation 2>&1 | tee out.txt ; cat out.txt
|
|
grep out.txt -e "\[WARNING\]: Handler 'handler name with {{ test_var }}' is unusable"
|
|
[ "$(grep out.txt -ce 'handler ran')" = "1" ]
|
|
[ "$(grep out.txt -ce 'handler with var ran')" = "0" ]
|
|
|
|
# Test templating a handler name with a defined variable
|
|
ansible-playbook 58841.yml "$@" --tags evaluation_time -e test_var=myvar | tee out.txt ; cat out.txt
|
|
[ "$(grep out.txt -ce 'handler ran')" = "0" ]
|
|
[ "$(grep out.txt -ce 'handler with var ran')" = "1" ]
|
|
|
|
# Test the handler is not found when the variable is undefined
|
|
ansible-playbook 58841.yml "$@" --tags evaluation_time 2>&1 | tee out.txt ; cat out.txt
|
|
grep out.txt -e "ERROR! The requested handler 'handler name with myvar' was not found"
|
|
grep out.txt -e "\[WARNING\]: Handler 'handler name with {{ test_var }}' is unusable"
|
|
[ "$(grep out.txt -ce 'handler ran')" = "0" ]
|
|
[ "$(grep out.txt -ce 'handler with var ran')" = "0" ]
|