2016-10-12 14:57:53 -07:00
|
|
|
#!/usr/bin/env bash
|
|
|
|
|
|
|
|
set -eux
|
|
|
|
|
2019-03-13 14:04:31 -07:00
|
|
|
# This test does not use "$@" to avoid further increasing the verbosity beyond what is required for the test.
|
|
|
|
# Increasing verbosity from -vv to -vvv can increase the line count from ~400 to ~9K on our centos6 test container.
|
|
|
|
|
2016-10-12 14:57:53 -07:00
|
|
|
# remove old output log
|
|
|
|
rm -f block_test.out
|
|
|
|
# run the test and check to make sure the right number of completions was logged
|
2019-03-13 14:04:31 -07:00
|
|
|
ansible-playbook -vv main.yml -i ../../inventory | tee block_test.out
|
2016-10-12 14:57:53 -07:00
|
|
|
env python -c \
|
|
|
|
'import sys, re; sys.stdout.write(re.sub("\x1B\[([0-9]{1,2}(;[0-9]{1,2})?)?[m|K]", "", sys.stdin.read()))' \
|
|
|
|
<block_test.out >block_test_wo_colors.out
|
|
|
|
[ "$(grep -c 'TEST COMPLETE' block_test.out)" = "$(egrep '^[0-9]+ plays in' block_test_wo_colors.out | cut -f1 -d' ')" ]
|
|
|
|
# cleanup the output log again, to make sure the test is clean
|
|
|
|
rm -f block_test.out block_test_wo_colors.out
|
|
|
|
# run test with free strategy and again count the completions
|
2019-03-13 14:04:31 -07:00
|
|
|
ansible-playbook -vv main.yml -i ../../inventory -e test_strategy=free | tee block_test.out
|
2016-10-12 14:57:53 -07:00
|
|
|
env python -c \
|
|
|
|
'import sys, re; sys.stdout.write(re.sub("\x1B\[([0-9]{1,2}(;[0-9]{1,2})?)?[m|K]", "", sys.stdin.read()))' \
|
|
|
|
<block_test.out >block_test_wo_colors.out
|
|
|
|
[ "$(grep -c 'TEST COMPLETE' block_test.out)" = "$(egrep '^[0-9]+ plays in' block_test_wo_colors.out | cut -f1 -d' ')" ]
|
2018-08-23 20:16:32 -04:00
|
|
|
# cleanup the output log again, to make sure the test is clean
|
|
|
|
rm -f block_test.out block_test_wo_colors.out
|
|
|
|
# run test with host_pinned strategy and again count the completions
|
2019-03-13 14:04:31 -07:00
|
|
|
ansible-playbook -vv main.yml -i ../../inventory -e test_strategy=host_pinned | tee block_test.out
|
2018-08-23 20:16:32 -04:00
|
|
|
env python -c \
|
|
|
|
'import sys, re; sys.stdout.write(re.sub("\x1B\[([0-9]{1,2}(;[0-9]{1,2})?)?[m|K]", "", sys.stdin.read()))' \
|
|
|
|
<block_test.out >block_test_wo_colors.out
|
|
|
|
[ "$(grep -c 'TEST COMPLETE' block_test.out)" = "$(egrep '^[0-9]+ plays in' block_test_wo_colors.out | cut -f1 -d' ')" ]
|
2019-02-26 16:22:32 +10:00
|
|
|
|
|
|
|
# run test that includes tasks that fail inside a block with always
|
|
|
|
rm -f block_test.out block_test_wo_colors.out
|
2019-03-13 14:04:31 -07:00
|
|
|
ansible-playbook -vv block_fail.yml -i ../../inventory | tee block_test.out
|
2019-02-26 16:22:32 +10:00
|
|
|
env python -c \
|
|
|
|
'import sys, re; sys.stdout.write(re.sub("\x1B\[([0-9]{1,2}(;[0-9]{1,2})?)?[m|K]", "", sys.stdin.read()))' \
|
|
|
|
<block_test.out >block_test_wo_colors.out
|
|
|
|
[ "$(grep -c 'TEST COMPLETE' block_test.out)" = "$(egrep '^[0-9]+ plays in' block_test_wo_colors.out | cut -f1 -d' ')" ]
|