-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtest.sh
executable file
·135 lines (116 loc) · 3.85 KB
/
test.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
#!/usr/bin/env bash
set -e
# shellcheck disable=SC2155
export _SCRIPT_DIR=$(cd -- "$(dirname -- "${BASH_SOURCE[0]}")" &>/dev/null && pwd)
# shellcheck source=_functions.sh
source "$_SCRIPT_DIR/_functions.sh"
# shellcheck source=_variables.sh
source "$_SCRIPT_DIR/_variables.sh"
_DIRS=()
while [[ $# -gt 0 ]]; do
case "$1" in
--help | -h)
echo "Usage: $(basename "$0") TEST_DIR1 [TEST_DIR2]..."
echo ""
echo "Sequentially run and check results of tests defined in directories passed as arguments,"
echo "print summary."
echo ""
echo "Specifically, for each provided argument:"
echo "1. call '_test_run.sh TEST_DIR' to run the test (see '_test_run.sh --help')"
echo "2. call '_test_check.sh --id TEST_ID --dir TEST_DIR' to check the results (see '_test_check.sh --help')"
exit 0
;;
*)
_DIRS+=("$1")
shift
;;
esac
done
assert_installed yc jq curl
_logv 1 "YC CLI provile: ${VAR_CLI_PROFILE:-"current aka <$(yc_ config profile list | grep ' ACTIVE')>"}"
_logv 1 ""
_log -f <<EOF
Execution:
|--------------------
| folder: ${VAR_FOLDER_ID:-$(yc_ config get folder-id)}
| skip results check: $VAR_SKIP_TEST_CHECK
|
| data bucket: $VAR_DATA_BUCKET
| extra test labels: $VAR_TEST_EXTRA_LABELS
| extra test description: $VAR_TEST_EXTRA_DESCRIPTION
|
| output local dir: $VAR_OUTPUT_DIR
|--------------------
EOF
_log ""
if [[ -z "${VAR_FOLDER_ID:-$(yc_ config get folder-id)}" ]]; then
_log "Folder ID must be specified either via YC_LT_FOLDER_ID or via CLI profile."
exit 1
fi
declare -i _tests_total="${#_DIRS[@]}"
declare -i _tests_failed=0
declare _tests_failure_reports=()
_log_push_stage ""
_log_push_stage ""
for _test_dir in "${_DIRS[@]}"; do
_log_pop_stage
_log_pop_stage
_log_push_stage "[$_test_dir]"
_log_push_stage "[ENTER]"
_log "Checking..."
if [[ ! -d "$_test_dir" ]]; then
_msg="FAILED: test dir does not exist"
_tests_failure_reports+=("$(_log "$_msg" 2> >(tee /dev/stderr))")
_tests_failed=$((_tests_failed + 1))
continue
fi
_test_id=
_log_stage "[RUN]"
_log "Running..."
if _test=$(run_script "$_SCRIPT_DIR/_test_run.sh" "$_test_dir"); then
_test_id=$(jq -r '.id' <<< "$_test")
_logv 1 "ID=$_test_id"
_logv 1 "STATUS=$(jq -r '.summary.status' <<< "$_test")"
_log "FINISHED: $(yc_test_url "$_test_id")/test-report)"
else
_msg="FAILED: error; test=$_test"
_tests_failure_reports+=("$(_log "$_msg" 2> >(tee /dev/stderr))")
_tests_failed=$((_tests_failed + 1))
continue
fi
_log_stage "[CHECK]"
if [[ "${VAR_SKIP_TEST_CHECK:-0}" == 0 ]]; then
_out_dir="$VAR_OUTPUT_DIR/$_test_id"
_resfile="$_out_dir/check_result.txt"
mkdir -p "$_out_dir"
_log "Performing checks..."
if run_script "$_SCRIPT_DIR/_test_check.sh" --id "$_test_id" --dir "$_test_dir" -o "$_out_dir" >"$_resfile"; then
_logv 1 -f <"$_resfile"
_log "ALL CHECKS PASSED"
else
_log -f <"$_resfile"
_msg="FAILED: checks did not pass. Result in $_resfile"
_tests_failure_reports+=("$(_log "$_msg" 2> >(tee /dev/stderr))")
_tests_failed=$((_tests_failed + 1))
fi
else
_log "skipped due to YC_LT_SKIP_TEST_CHECK"
fi
_log ""
done
_log_pop_stage
_log_pop_stage
_log_stage ""
_summary_header="[ OK - $((_tests_total - _tests_failed)) | FAILED - $_tests_failed ]"
_log "==================== $_summary_header ===================="
_log ""
if ((_tests_failed != 0)); then
_log "$_tests_failed out of $_tests_total tests have failed:"
for _msg in "${_tests_failure_reports[@]}"; do
_log "$_msg"
done
fi
_log ""
_log "==================== $_summary_header ===================="
echo "$_tests_failed"
exit "$_tests_failed"