- if ! installed ansible-playbook; then
- # TODO: Consider moving to requirements.txt?
- pip install ansible==2.7.8 || die "Install ansible via PIP failed!"
+ hosts=($(fgrep host "${WORKING_TOPOLOGY}" | cut -d ":" -f 2)) || {
+ die "Failed to read hosts from working topology!"
+ }
+ pushd "${CSIT_DIR}"/fdio.infra.ansible || die "Pushd failed!"
+ export ANSIBLE_HOST_KEY_CHECKING=False
+ export ANSIBLE_STDOUT_CALLBACK=yaml
+ export ANSIBLE_PIPELINING=true
+ ansible-playbook \
+ --vault-password-file=vault_pass \
+ --extra-vars '@vault.yml' \
+ --inventory inventories/$INVENTORY_PATH/hosts site.yaml \
+ --limit "$(echo ${hosts[@]//\"})" \
+ --module-name shell \
+ --args \"$(echo $@)\" || die "Failed to run ansible on host!"
+ popd || die "Popd failed!"
+}
+
+function ansible_playbook () {
+
+ # Run ansible playbook on hosts in working topology file. Ansible scope is
+ # determined by tags passed as parameters to this function.
+ #
+ # Variable read:
+ # - ${WORKING_TOPOLOGY} - Reserved working topology.
+ # - ${CSIT_DIR} - CSIT main directory, where ansible playbooks are located.
+ # - ${FLAVOR} - Node flavor string, see common.sh
+
+ set -exuo pipefail
+
+ case "$FLAVOR" in
+ "aws")
+ INVENTORY_PATH="cloud_inventory"
+ ;;
+ *)
+ INVENTORY_PATH="lf_inventory"
+ ;;
+ esac
+
+ if ! installed sshpass; then
+ die "Please install sshpass!"