-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathentrypoint.sh
executable file
·85 lines (66 loc) · 3.02 KB
/
entrypoint.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
#!/usr/bin/env sh
PLANSHOME="${HOME}/testground/plans"
# exit codes determine the result of the CheckRun
# https://docs.github.com/en/actions/creating-actions/setting-exit-codes-for-actions
SUCCESS=0
FAILURE=1
BACKEND="${INPUT_BACKEND_PROTO}"'://'"${INPUT_BACKEND_ADDR}"
# Make sure the input files exist.
test -d "${INPUT_PLAN_DIRECTORY}" || exit "${FALURE}"
test -f "${INPUT_COMPOSITION_FILE}" || exit "${FAILURE}"
REAL_PLAN_DIR=$(realpath $INPUT_PLAN_DIRECTORY)
REAL_COMP_FILE=$(realpath $INPUT_COMPOSITION_FILE)
# link plan to testground home
mkdir -p "${PLANSHOME}"
ln -s "${REAL_PLAN_DIR}" "${PLANSHOME}"
# Run test and wait until finished.
# There is a --wait option, so it might work to use it like this
# testground --endpoint "$BACKEND" run composition -f "$REAL_COMP_FILE" --wait
# However, --wait doesn't always work well particularly for long-running jobs
# so instead, do a long poll.
/testground --endpoint "${BACKEND}" run composition \
-f "${REAL_COMP_FILE}" \
--metadata-repo "${GITHUB_REPOSITORY}" \
--metadata-branch "${GITHUB_REF#refs/heads/}" \
--metadata-commit "${GITHUB_SHA}" | tee run.out
TGID=$(awk '/run is queued with ID/ {print $10}' <run.out)
# Make sure the we received a run ID
if [ -z "$TGID" ]
then
echo "outcome=failure/not_queued" >> $GITHUB_OUTPUT
exit "${FAILURE}"
fi
echo "testground_id=${TGID}" >> $GITHUB_OUTPUT
echo "Got testground ID ${TGID}"
echo -n "Testground started: "; date
echo "Waiting for job to complete."
while [ "${status}" != "complete" -a "${status}" != "canceled" ]
do
sleep 120
status=$(/testground --endpoint "${BACKEND}" status -t "${TGID}" | awk '/Status/ {print $2}')
echo "last polled status is ${status}"
echo "status=${status}" >> $GITHUB_OUTPUT
done
echo -n "Testground ended: "; date
echo getting extended status
/testground --endpoint "${BACKEND}" status -t "${TGID}" --extended | tee extendedstatus.out
# Get the extened status, which includes a "Result" section.
# Capture the line that occurs after "Result:"
extstatus=$(awk '/Result/ {getline; print $0}' <extendedstatus.out)
# First off, there are control characters in this output, and we need to remove that.
# https://github.com/testground/testground/issues/1214
extstatus=$(echo "${extstatus}" | tr -d "[:cntrl:]" | sed 's/\[0m//g')
# test if we got a result at all. The result might be "null". A null result means most likely the
# job was canceled before it began for some reason.
if [ "${extstatus}" == "null" ]
then
echo "outcome=failure/canceled" >> $GITHUB_OUTPUT
exit "$FAILURE"
fi
# Now find the outcome of the test. The extended result is going to look something like this:
# {"journal":{"events":{},"pods_statuses":{}},"outcome":"success","outcomes":{"providers":{"ok":1,"total":1},"requestors":{"ok":1,"total":1}}}
outcome=$(echo "${extstatus}" | jq ".outcome")
echo "the extended status was ${extstatus}"
echo "The outcome of this test was ${outcome}"
echo "outcome=${outcome}" >> $GITHUB_OUTPUT
test "${outcome}" = "\"success\"" && exit "${SUCCESS}" || exit "${FAILURE}"