1c33b5a9f0
cryptography upgrade caused fatal error when pycrypto was not installed
191 lines
5.1 KiB
Bash
Executable file
191 lines
5.1 KiB
Bash
Executable file
#!/bin/bash -eux
|
|
|
|
set -o pipefail
|
|
|
|
source_root=$(python -c "from os import path; print(path.abspath(path.join(path.dirname('$0'), '../../..')))")
|
|
|
|
test_flags="${TEST_FLAGS:-}"
|
|
test_platform="${PLATFORM}"
|
|
test_version="${VERSION}"
|
|
|
|
test_target=(${TARGET})
|
|
|
|
instance_id="${INSTANCE_ID:-}"
|
|
start_instance=
|
|
|
|
if [ "${instance_id}" == "" ]; then
|
|
instance_id=$(python -c 'import uuid; print(uuid.uuid4())')
|
|
start_instance=1
|
|
fi
|
|
|
|
# Set this to a non-empty value to skip immediate termination of the remote instance after tests finish.
|
|
# The remote instance will still be auto-terminated when the remote time limit is reached.
|
|
keep_instance="${KEEP_INSTANCE:-}"
|
|
|
|
# Force ansible color output by default.
|
|
# To disable color force mode use FORCE_COLOR=0
|
|
force_color="${FORCE_COLOR:-1}"
|
|
|
|
if [ "${SHIPPABLE:-}" = "true" ]; then
|
|
test_auth="shippable"
|
|
else
|
|
test_auth="remote"
|
|
fi
|
|
|
|
case "${test_platform}" in
|
|
"windows")
|
|
ci_endpoint="https://14blg63h2i.execute-api.us-east-1.amazonaws.com"
|
|
;;
|
|
"freebsd")
|
|
ci_endpoint="https://14blg63h2i.execute-api.us-east-1.amazonaws.com"
|
|
;;
|
|
"osx")
|
|
ci_endpoint="https://osx.testing.ansible.com"
|
|
;;
|
|
*)
|
|
echo "unsupported platform: ${test_platform}"
|
|
exit 1
|
|
;;
|
|
esac
|
|
|
|
env
|
|
|
|
case "${test_platform}" in
|
|
"windows")
|
|
args=""
|
|
;;
|
|
*)
|
|
ssh_key="${HOME}/.ssh/id_rsa"
|
|
args="--public-key=${ssh_key}.pub"
|
|
if [ ! -f "${ssh_key}.pub" ]; then
|
|
ssh-keygen -q -t rsa -N '' -f "${ssh_key}"
|
|
fi
|
|
;;
|
|
esac
|
|
|
|
pre_cleanup=
|
|
|
|
function cleanup
|
|
{
|
|
if [ "${pre_cleanup}" != '' ]; then
|
|
"${pre_cleanup}"
|
|
fi
|
|
|
|
if [ "${keep_instance}" = '' ]; then
|
|
"${source_root}/test/utils/shippable/ansible-core-ci" --endpoint "${ci_endpoint}" -v stop "${instance_id}"
|
|
fi
|
|
|
|
echo "instance_id: ${instance_id}"
|
|
}
|
|
|
|
trap cleanup EXIT INT TERM
|
|
|
|
if [ ${start_instance} ]; then
|
|
# shellcheck disable=SC2086
|
|
"${source_root}/test/utils/shippable/ansible-core-ci" --endpoint "${ci_endpoint}" -v \
|
|
start --id "${instance_id}" "${test_auth}" "${test_platform}" "${test_version}" ${args}
|
|
fi
|
|
|
|
pip install "${source_root}" --upgrade
|
|
pip install -r "${source_root}/test/utils/shippable/remote-requirements.txt" --upgrade
|
|
pip list
|
|
|
|
cd "${source_root}"
|
|
source hacking/env-setup
|
|
cd test/integration
|
|
|
|
case "${test_platform}" in
|
|
"windows")
|
|
inventory_template="${source_root}/test/integration/inventory.winrm.template"
|
|
inventory_file="${source_root}/test/integration/inventory.winrm"
|
|
ping_module="win_ping"
|
|
ping_host="windows"
|
|
test_function="test_windows"
|
|
;;
|
|
*)
|
|
inventory_template="${source_root}/test/integration/inventory.remote.template"
|
|
inventory_file="${source_root}/test/integration/inventory.remote"
|
|
ping_module="ping"
|
|
ping_host="remote"
|
|
test_function="test_remote"
|
|
;;
|
|
esac
|
|
|
|
"${source_root}/test/utils/shippable/ansible-core-ci" --endpoint "${ci_endpoint}" -v \
|
|
get "${instance_id}" \
|
|
--template "${inventory_template}" \
|
|
> "${inventory_file}" \
|
|
|
|
# hack to make sure instance is responding before beginning tests
|
|
n=60
|
|
for i in $(seq 1 ${n}); do
|
|
echo "Verifying host is responding ($i of $n)"
|
|
if \
|
|
ANSIBLE_SSH_ARGS='' \
|
|
ANSIBLE_HOST_KEY_CHECKING=False \
|
|
ANSIBLE_FORCE_COLOR="${force_color}" \
|
|
ansible -m "${ping_module}" -i "${inventory_file}" "${ping_host}"; then
|
|
break
|
|
fi
|
|
sleep 5
|
|
done
|
|
|
|
test_windows() {
|
|
JUNIT_OUTPUT_DIR="${source_root}/shippable/testresults" \
|
|
ANSIBLE_FORCE_COLOR="${force_color}" \
|
|
ANSIBLE_CALLBACK_WHITELIST=junit \
|
|
TEST_FLAGS="${test_flags}" \
|
|
LC_ALL=en_US.utf-8 \
|
|
make "${test_target[@]}"
|
|
}
|
|
|
|
test_remote() {
|
|
endpoint=$("${source_root}/test/utils/shippable/ansible-core-ci" --endpoint "${ci_endpoint}" get \
|
|
"${instance_id}" \
|
|
--template <(echo "@ansible_user@@ansible_host"))
|
|
ssh_port=$("${source_root}/test/utils/shippable/ansible-core-ci" --endpoint "${ci_endpoint}" get \
|
|
"${instance_id}" \
|
|
--template <(echo "@ansible_port"))
|
|
|
|
(
|
|
cat <<EOF
|
|
env \
|
|
PLATFORM='${test_platform}' \
|
|
REPOSITORY_URL='${REPOSITORY_URL:-}' \
|
|
REPO_NAME='${REPO_NAME:-}' \
|
|
PULL_REQUEST='${PULL_REQUEST:-}' \
|
|
BRANCH='${BRANCH:-}' \
|
|
COMMIT='${COMMIT:-}' \
|
|
FORCE_COLOR='${force_color}' \
|
|
TARGET='${test_target[*]}' \
|
|
TEST_FLAGS='${test_flags}' \
|
|
/bin/sh -e /tmp/remote-integration.sh
|
|
EOF
|
|
) > /tmp/remote-script.sh
|
|
|
|
(
|
|
cat <<EOF
|
|
put "${source_root}/test/utils/shippable/remote-integration.sh" "/tmp/remote-integration.sh"
|
|
put "/tmp/remote-script.sh" "/tmp/remote-script.sh"
|
|
EOF
|
|
) | sftp -b - -o StrictHostKeyChecking=no -P "${ssh_port}" "${endpoint}"
|
|
|
|
pre_cleanup=test_remote_cleanup
|
|
|
|
case "${test_platform}" in
|
|
"osx")
|
|
become="sudo -i PATH=/usr/local/bin:\$PATH"
|
|
;;
|
|
*)
|
|
become="su -l root -c"
|
|
;;
|
|
esac
|
|
|
|
ssh -p "${ssh_port}" "${endpoint}" "${become}" "'chmod +x /tmp/remote-script.sh; /tmp/remote-script.sh'"
|
|
}
|
|
|
|
test_remote_cleanup() {
|
|
scp -r -P "${ssh_port}" "${endpoint}:/tmp/shippable" "${source_root}"
|
|
}
|
|
|
|
"${test_function}"
|