-
Notifications
You must be signed in to change notification settings - Fork 12
/
Copy pathregression_test_script
executable file
·128 lines (116 loc) · 3.77 KB
/
regression_test_script
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
#!/bin/bash
set -e
echo "Starting up ..."
default_time_out=30
default_image_name="opendap/hyrax:c7-snapshot"
default_endpoint="http://localhost:8080/opendap"
time_out="${default_time_out}"
test_image_name="${default_image_name}"
end_point="${default_endpoint}"
netrc_file=""
tests=""
while getopts "ht:i:e:n:" OPTION; do
case $OPTION in
h)
echo "-h help -t time_out -i image_name -e end_point_url -n netrc_file test1 test2 ..."
exit 0
;;
t)
time_out=$OPTARG
;;
i)
test_image_name=$OPTARG
;;
e)
end_point=$OPTARG
;;
n)
netrc_file="--netrc ${OPTARG}"
;;
*)
echo "Incorrect options provided"
exit 1
;;
esac
done
shift $(($OPTIND - 1))
tests="$@"
echo "Using following configurations:" >&2
echo "Time out duration: ${time_out}" >&2
echo "Image name: ${test_image_name}" >&2
echo "End point: ${end_point}" >&2
echo "Tests: ${tests}" >&2
function waitForHyrax() {
# Don't fail on errors, they're expected...
set +e
let start=`date "+%s"`
done_flag="";
while test -z "${done_flag}"
do
echo -n "."
curl -s -c cookies -b cookies -n --netrc-file ${netrc_file} -L ${end_point} > /dev/null
status=$?
# echo "cURL status: ${status}";
if [ ${status} -eq 0 ]
then
echo ""
echo "Endpoint may have been retrieved. Checking again..."
# What happens next: We get the response headers "-I" and look
# for the string "HTTP/" because we know there will be redirects.
# We use tail to look at the last HTTP/ header and if that status is
# 200 we're off to the races.
set -x; # Echo the stuff
curl -s -c cookies -b cookies -n ${netrc_file} -I -L ${end_point} | grep "HTTP/" | tail -1 | grep 200 > /dev/null;
found=$?;
set +x; # Stop echoing the stuff...
# echo "cURL found: ${found}";
if [ ${found} -eq 0 ]; then
echo "The Test Endpoint URL: ${end_point} returned a status of 200"
done_flag="yup";
fi
fi
let now=$(date "+%s")
let elapsed=$now-$start;
# echo "elapsed: $elapsed"
if [ ${elapsed} -gt ${time_out} ]
then
echo ""
echo "ERROR: Hyrax FAILED To Start! Waited for ${elapsed} seconds"
exit 1;
fi
done
# Now we can fail on errors again.
set -e
echo "Hyrax has arrived!"
}
# Dump all other containers
containers=$(docker ps -aq);
if test -n "${containers}"
then
echo "Removing containers: ${containers}";
docker rm -f ${containers};
fi
#start Hyrax
container_id=$(docker run -d -h hyrax -p 8080:8080 --name=hyrax ${test_image_name})
waitForHyrax
echo "############################################################################"
echo "# Testing the following image: ${test_image_name}"
set -x
docker exec -it hyrax /bin/bash -c "cd hyrax_regression_tests; ./testsuite --hyraxurl=\"${end_point}\" ${netrc_file} ${tests}; "
#./show_fails"
echo "############################################################################"
echo "# Checking beslog2json.awk"
echo "# Acquiring bes.log from docker image."
docker cp hyrax:/var/log/bes/bes.log .
echo "############################################################################"
echo "# head ./bes.log"
head ./bes.log
cat ./bes.log | ./builds/ngap/beslog2json.py --all > ./bes.json
echo "############################################################################"
echo "# head -20 ./bes.json"
head -n 10 ./bes.json
echo "# tail -20 ./bes.json"
tail -n 20 ./bes.json
echo "############################################################################"
jq '.' ./bes.json > /dev/null
echo "JQ STATUS: $?"