29c6aae2fc
* try to load unqualified plugins from whitelist * necessary for backcompat loading of unqualified collectionized callback plugins redirected from <= 2.9 core * also added de-duping from actual loaded name * add tests * add warning test * group test script entries by topic * shorten warning text grep because wrapping is dumb * fix adhoc callback loading behavior * collections pass over whitelist wasn't respecting `_run_additional_callbacks` * adds regression tests for same * avoid `grep -L` in tests since it breaks the world
108 lines
4.6 KiB
Bash
Executable file
108 lines
4.6 KiB
Bash
Executable file
#!/usr/bin/env bash
|
|
|
|
set -eux
|
|
|
|
export ANSIBLE_COLLECTIONS_PATH=$PWD/collection_root_user:$PWD/collection_root_sys
|
|
export ANSIBLE_GATHERING=explicit
|
|
export ANSIBLE_GATHER_SUBSET=minimal
|
|
export ANSIBLE_HOST_PATTERN_MISMATCH=error
|
|
|
|
# FUTURE: just use INVENTORY_PATH as-is once ansible-test sets the right dir
|
|
ipath=../../$(basename "${INVENTORY_PATH:-../../inventory}")
|
|
export INVENTORY_PATH="$ipath"
|
|
|
|
echo "--- validating callbacks"
|
|
# validate FQ callbacks in ansible-playbook
|
|
ANSIBLE_CALLBACK_WHITELIST=testns.testcoll.usercallback ansible-playbook noop.yml | grep "usercallback says ok"
|
|
# use adhoc for the rest of these tests, must force it to load other callbacks
|
|
export ANSIBLE_LOAD_CALLBACK_PLUGINS=1
|
|
# validate redirected callback
|
|
ANSIBLE_CALLBACK_WHITELIST=formerly_core_callback ansible localhost -m debug 2>&1 | grep -- "usercallback says ok"
|
|
# validate missing redirected callback
|
|
ANSIBLE_CALLBACK_WHITELIST=formerly_core_missing_callback ansible localhost -m debug 2>&1 | grep -- "Skipping 'formerly_core_missing_callback'"
|
|
# validate redirected + removed callback (fatal)
|
|
ANSIBLE_CALLBACK_WHITELIST=formerly_core_removed_callback ansible localhost -m debug 2>&1 | grep -- "testns.testcoll.removedcallback has been removed"
|
|
# validate warning on logical duplicate (FQ + unqualified that are the same)
|
|
ANSIBLE_CALLBACK_WHITELIST=testns.testcoll.usercallback,formerly_core_callback ansible localhost -m debug 2>&1 | grep -- "Skipping callback 'formerly_core_callback'"
|
|
# ensure non existing callback does not crash ansible
|
|
ANSIBLE_CALLBACK_WHITELIST=charlie.gomez.notme ansible localhost -m debug 2>&1 | grep -- "Skipping 'charlie.gomez.notme'"
|
|
unset ANSIBLE_LOAD_CALLBACK_PLUGINS
|
|
# adhoc normally shouldn't load non-default plugins- let's be sure
|
|
output=$(ANSIBLE_CALLBACK_WHITELIST=testns.testcoll.usercallback ansible localhost -m debug)
|
|
if [[ "${output}" =~ "usercallback says ok" ]]; then echo fail; exit 1; fi
|
|
|
|
echo "--- validating docs"
|
|
# test documentation
|
|
ansible-doc testns.testcoll.testmodule -vvv | grep -- "- normal_doc_frag"
|
|
# same with symlink
|
|
ln -s "${PWD}/testcoll2" ./collection_root_sys/ansible_collections/testns/testcoll2
|
|
ansible-doc testns.testcoll2.testmodule2 -vvv | grep "Test module"
|
|
# now test we can list with symlink
|
|
ansible-doc -l -vvv| grep "testns.testcoll2.testmodule2"
|
|
|
|
echo "testing bad doc_fragments (expected ERROR message follows)"
|
|
# test documentation failure
|
|
ansible-doc testns.testcoll.testmodule_bad_docfrags -vvv 2>&1 | grep -- "unknown doc_fragment"
|
|
|
|
echo "--- validating default collection"
|
|
# test adhoc default collection resolution (use unqualified collection module with playbook dir under its collection)
|
|
|
|
echo "testing adhoc default collection support with explicit playbook dir"
|
|
ANSIBLE_PLAYBOOK_DIR=./collection_root_user/ansible_collections/testns/testcoll ansible localhost -m testmodule
|
|
|
|
# we need multiple plays, and conditional import_playbook is noisy and causes problems, so choose here which one to use...
|
|
if [[ ${INVENTORY_PATH} == *.winrm ]]; then
|
|
export TEST_PLAYBOOK=windows.yml
|
|
else
|
|
export TEST_PLAYBOOK=posix.yml
|
|
|
|
echo "testing default collection support"
|
|
ansible-playbook -i "${INVENTORY_PATH}" collection_root_user/ansible_collections/testns/testcoll/playbooks/default_collection_playbook.yml "$@"
|
|
fi
|
|
|
|
echo "--- validating collections support in playbooks/roles"
|
|
# run test playbooks
|
|
ansible-playbook -i "${INVENTORY_PATH}" -v "${TEST_PLAYBOOK}" "$@"
|
|
|
|
if [[ ${INVENTORY_PATH} != *.winrm ]]; then
|
|
ansible-playbook -i "${INVENTORY_PATH}" -v invocation_tests.yml "$@"
|
|
fi
|
|
|
|
echo "--- validating inventory"
|
|
# test collection inventories
|
|
ansible-playbook inventory_test.yml -i a.statichost.yml -i redirected.statichost.yml "$@"
|
|
|
|
# test adjacent with --playbook-dir
|
|
export ANSIBLE_COLLECTIONS_PATH=''
|
|
ANSIBLE_INVENTORY_ANY_UNPARSED_IS_FAILED=1 ansible-inventory --list --export --playbook-dir=. -v "$@"
|
|
|
|
# use an inventory source with caching enabled
|
|
ansible-playbook -i a.statichost.yml -i ./cache.statichost.yml -v check_populated_inventory.yml
|
|
|
|
# Check that the inventory source with caching enabled was stored
|
|
if [[ "$(find ./inventory_cache -type f ! -path "./inventory_cache/.keep" | wc -l)" -ne "1" ]]; then
|
|
echo "Failed to find the expected single cache"
|
|
exit 1
|
|
fi
|
|
|
|
CACHEFILE="$(find ./inventory_cache -type f ! -path './inventory_cache/.keep')"
|
|
|
|
if [[ $CACHEFILE != ./inventory_cache/prefix_* ]]; then
|
|
echo "Unexpected cache file"
|
|
exit 1
|
|
fi
|
|
|
|
# Check the cache for the expected hosts
|
|
|
|
if [[ "$(grep -wc "cache_host_a" "$CACHEFILE")" -ne "1" ]]; then
|
|
echo "Failed to cache host as expected"
|
|
exit 1
|
|
fi
|
|
|
|
if [[ "$(grep -wc "dynamic_host_a" "$CACHEFILE")" -ne "0" ]]; then
|
|
echo "Cached an incorrect source"
|
|
exit 1
|
|
fi
|
|
|
|
./vars_plugin_tests.sh
|
|
|