-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathrun_test_suite.sh
executable file
·183 lines (156 loc) · 6.31 KB
/
run_test_suite.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
#!/bin/bash
#
# Author: Riyad Preukschas <riyad@informatik.uni-bremen.de>
# License: Mozilla Public License 2.0
# SPDX-License-Identifier: MPL-2.0
#
# Builds Podman starts an API server and runs the docker-py integration tests
# against it. It collects engine information, test and server logs for each run.
set -euo pipefail
# NOTE: change these to match your environment
readonly PODMAN_REPO_PATH="${PODMAN_REPO_PATH:-$HOME/src/podman}"
readonly DOCKER_PY_REPO_PATH="${DOCKER_PY_REPO_PATH:-$HOME/src/docker-py}"
readonly DOCKER_PY_VENV_PATH="${DOCKER_PY_VENV_PATH:-$HOME/.virtualenvs/docker-py}"
readonly LOGS_PATH="${LOGS_PATH:-${DOCKER_PY_REPO_PATH}/logs}"
readonly PODMAN_BIN="${PODMAN_BIN:-${PODMAN_REPO_PATH}/bin/podman}"
readonly PODMAN_SOCKET_PATH="${PODMAN_SOCKET_PATH:-unix:${PODMAN_REPO_PATH}/docker-py-test.sock}"
readonly BUILDAH_BIN="$(command -v buildah)"
export DOCKER_HOST="${DOCKER_HOST:-${PODMAN_SOCKET_PATH}}"
function usage() {
echo "Usage: $0 <SUITE_TAG> [OPTIONS] [<PYTEST_ARGS ...>]"
echo " Builds Podman starts an API server and runs the docker-py"
echo " integration tests against it. It collects engine information,"
echo " test and server logs for each run."
echo ""
echo "OPTIONS"
echo " -c,--checkout \"<BRANCH>\" Podman branch/commit to checkout. Set this to"
echo " '' to prevent doing acheckout. (default: main)"
echo " -m,--message \"<MESSAGE>\" Message/comment/note to attach to this test run"
echo " --no-cleanup Do not stop and remove Podman and Buildah"
echo " containers before running the tests"
echo " --no-kill Do not kill all podman processes before"
echo " running the tests"
echo " -h,--help Display this help text and exit"
echo ""
echo "ENVIRONMENT VARIABLES"
echo " PODMAN_REPO_PATH Directory where your podman source code lives"
echo " (default: ~/src/podman)"
echo " DOCKER_PY_REPO_PATH Directory where your docker-py source code lives"
echo " (default: ~/src/docker-py)"
echo " DOCKER_PY_VENV_PATH Directory where your Python virtual env for docker-py"
echo " lives (default: ~/.virtualenvs/docker-py)"
echo " LOGS_PATH Directory where you want logs from test suites saved"
echo " (default: \$DOCKER_PY_REPO_PATH/logs)"
echo " PODMAN_BIN Use this binary as the podman command (default: ./bin/podman)"
echo " PODMAN_SOCKET_PATH Use this as the socket path for the API server"
echo " (default: unix:${PODMAN_REPO_PATH}/docker-py-test.sock)"
}
parse_command_line_args() {
if [[ $# -eq 0 ]]; then
usage
exit 1
elif [[ $# -eq 1 && ( "$1" = '-h' || "$1" = '--help' ) ]]; then
usage
exit 0
fi
OPT_CHECKOUT_PODMAN='main'
OPT_CLEANUP_CONTAINERS='1'
OPT_KILL_PODMAN='1'
OPT_MESSAGE=''
OPT_SUITE_TAG="${1}"
shift
OPT_PYTEST_ARGS=''
while [[ $# -gt 0 ]]
do
case "$1" in
-h|--help)
usage
exit 0
;;
-c|--checkout)
readonly OPT_CHECKOUT_PODMAN="$2"
shift
;;
-m|--message)
readonly OPT_MESSAGE="$2"
shift
;;
--no-cleanup)
readonly OPT_CLEANUP_CONTAINERS=''
;;
--no-kill)
readonly OPT_KILL_PODMAN=''
;;
*)
# the rest of the arguments are for pytest
break
;;
esac
shift
done
readonly OPT_PYTEST_ARGS=( "${@}" )
}
function main() {
parse_command_line_args "$@"
cd "${PODMAN_REPO_PATH}"
if [[ -n "${OPT_CHECKOUT_PODMAN}" ]]; then
git checkout "${OPT_CHECKOUT_PODMAN}"
local PODMAN_COMMIT_ID="$(git log -1 --format=%H)"
local PODMAN_COMMIT_DATE="$(git log -1 --format=%cI)"
fi
local LOG_BASE_NAME="${LOGS_PATH}/pytest_integration_${OPT_SUITE_TAG}_${PODMAN_COMMIT_DATE:-}_${PODMAN_COMMIT_ID:-}"
if [[ -n "${OPT_MESSAGE}" ]]; then
LOG_BASE_NAME="${LOG_BASE_NAME}_${OPT_MESSAGE}"
fi
make -j "$(nproc)" podman
if [[ -n "${OPT_CLEANUP_CONTAINERS}" ]]; then
echo "Cleaning up ..."
"${PODMAN_BIN}" stop -a
"${PODMAN_BIN}" rm -a
[[ -x "${BUILDAH_BIN}" ]] && "${BUILDAH_BIN}" rm -a
fi
if [[ -n "${OPT_KILL_PODMAN}" ]]; then
killall -r 'podman.*' || true
fi
"${PODMAN_BIN}" info --format json > "${LOG_BASE_NAME}.podman-info.json"
echo "Starting API service ..."
"${PODMAN_BIN}" system service -t 0 "${PODMAN_SOCKET_PATH}" > "${LOG_BASE_NAME}.server.log" 2>&1 &
echo "Saving logs to \"${LOG_BASE_NAME}.pytest.log\" ..."
cd "${DOCKER_PY_REPO_PATH}"
source "${DOCKER_PY_VENV_PATH}/bin/activate"
set +o pipefail # disable pipefail
# pytest returns with non-zero exit code when tests fail :/
pytest -c pytest_podman_apiv2.ini --junitxml="${LOG_BASE_NAME}.junit.xml" "${OPT_PYTEST_ARGS[@]}" | tee "${LOG_BASE_NAME}.pytest.log"
set +o pipefail # re.enable pipefail
echo "Saving logs to \"${LOG_BASE_NAME}.pytest.log\" ... Done."
if [[ -n "${OPT_CLEANUP_CONTAINERS}" ]]; then
echo "Cleaning up ..."
[[ -x "${BUILDAH_BIN}" ]] && "${BUILDAH_BIN}" rm -a
"${PODMAN_BIN}" rm -af
set +e # disable errexit
# podman image rm ... returns non-zero exit code when any of the images don't exist
# we could use --ignore for podman versions > 3.4?!?
"${PODMAN_BIN}" image rm \
localhost/docker-py-test-build-with-dockerignore \
docker.io/library/docker-py-test-build-with-dockerignore \
localhost/dup-txt-tag \
docker.io/library/dup-txt-tag \
localhost/isolation \
docker.io/library/isolation \
localhost/some-tag \
docker.io/library/some-tag \
189596303490 \
sha256:e7b300aee9f9bf3433d32bc9305bfdd22183beb59d933b48d77ab56ba53a197a \
f2a91732366c d1165f221234 feb5d9fea6a5
# 189596303490 => quay.io/libpod/rootless-cni-infra
# f2a91732366c,d1165f221234,feb5d9fea6a5 => docker.io/library/hello-world
"${PODMAN_BIN}" image ls | grep dockerpytest | awk '{ print $1 }' | xargs "${PODMAN_BIN}" image rm
"${PODMAN_BIN}" image prune -f
"${PODMAN_BIN}" network ls | grep dockerpytest | awk '{ print $1 }' | xargs "${PODMAN_BIN}" network rm
set -e # re-enable errexit
fi
# kill backgrounbd jobs (i.e. Podman API server)
kill "$(jobs -p)"
echo "All done."
}
main "${@}"