-
Notifications
You must be signed in to change notification settings - Fork 21
/
Copy pathrun-test-docker-image.sh
executable file
·160 lines (140 loc) · 5.55 KB
/
run-test-docker-image.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
#!/usr/bin/env bash
sudo apt-get install jq -y
start=$(date +%s)
exit_cleanly() {
if [ "${skip_build}" != true ]; then
echo "Removing image: ${image_name}..."
docker rmi --force ${image_name}
fi
exit
}
exit_test() {
echo -e $1
docker logs --tail 25 volttron1
docker-compose down
exit_cleanly
}
check_error_code() {
local code=$1
if [ "${code}" -ne 0 ]; then
exit_test $2
fi
}
# Optional parameters; defaults provided for each one
skip_build='' # skip building the image
wait=360 # 6 minutes; wait is used for sleep while the container is setting up Volttron
group='volttron' # group name of the image; will be used to name the image <group>/volttron
tag='test-build' # image tag; will be used to name the image <source image>:<tag>
while getopts 'sw:g:t:' flag; do
case "${flag}" in
s) skip_build=true ;;
w) wait="$OPTARG" ;;
g) group="$OPTARG" ;;
t) tag="$OPTARG" ;;
*) echo "Unexpected option ${flag}"
exit 1 ;;
esac
done
# Set image_name to be used in calls to docker
image_name="volttron/${group}:${tag}"
echo "Test running with following optional parameters: skip_build: ${skip_build}; wait: ${wait}; group: ${group}; tag: ${tag}"
############ Build image
if [ "${skip_build}" = true ]; then
echo "Skipping the build"
else
echo "Building image: ${image_name}"
git submodule update --init --recursive
docker rmi "${image_name}" --force
docker build --no-cache -t "${image_name}" .
fi
###### Test that the image was built
docker images --format "{{.Tag}}: {{.Repository}}" | grep "${tag}: volttron/volttron"
check_error_code $? 'Failed to build image'
############ Setup and start container
attempts=5
echo "Will try at most ${attempts} attempts to start container..."
while [ "${attempts}" -gt 0 ]; do
echo "Attempt number ${attempts} to start container."
docker-compose up --detach
echo "Configuring and starting Volttron platform; this will take approximately several minutes........"
sleep ${wait}
docker ps --filter "name=volttron1" --filter "status=running" | grep 'volttron1'
tmp_code=$?
if [ "${tmp_code}" -eq 1 ]; then
echo "Container failed to start."
docker logs --tail 20 volttron1
docker-compose down
((attempts=attempts-1))
else
# Container was successfully created
break
fi
done
if [ "${attempts}" -eq 0 ]; then
echo "Failed to start container and thus cannot proceed to integration testing. Please check the Dockerfile and/or docker-compose.yml."
exit_cleanly
fi
############# Tests
# The following tests ensure that the container is actually alive and works
echo "Running tests..."
vctl="/home/volttron/.local/bin/vctl"
# Test
# Check expected number of agents based on the number of agents in platform_config.yml; currently 6 agents are installed
echo "Testing for list of agents..."
output=$(docker exec -u volttron volttron1 "${vctl}" list)
check_error_code $? "Failed to get list of agents"
count=$(echo "${output}" | grep "" -c)
if [ "${count}" -ne 6 ]; then
exit_test "Total count of agents were not installed. Current count: ${count} \n Output from vctl list: \n ${output}"
fi
echo "PASSED....CHECKING LIST OF AGENTS."
# Test
# Check the health/status of each agent
declare -a agents_message
agents_message=('listeneragent-3.3' 'platform_driveragent-4.0' 'sqlhistorianagent-3.7.0')
echo "Testing health of agents: ${agents_message[*]} "
for agent in "${agents_message[@]}"
do
echo "Checking health for ${agent}"
output=$(docker exec -u volttron volttron1 ${vctl} health --name ${agent})
message=$(echo ${output} | jq .message)
if [ "${message}" = '"GOOD"' ]; then
echo "Agent is healthy"
else
exit_test "Failing Agent Health test because agent is unhealthy: ${output}"
fi
done
echo "PASSED....CHECKING HEALTH OF AGENTS."
# TODO: check for connected is not null for these agents
#actuatoragent-1.0
#vcplatformagent-4.8
#volttroncentralagent-5.2
## Test
# Check the configuration of the platform which should match the config in platform_config.yml
# For now, we are verifying that the number of lines is the same number of lines in the config block of platform_config.yml (currently set at 8 with the new line)
# because the output is the configuration itself, thus we are using STDOUT to check configuration; not ideal but a start
echo "Testing platform configuration..."
output=$(docker exec -u volttron volttron1 cat /home/volttron/.volttron/config)
check_error_code $? 'Failed to get platform configuration'
count=$(docker exec -u volttron volttron1 cat /home/volttron/.volttron/config | grep "" -c)
if [ "${count}" -ne 8 ]; then
exit_test "Platform not correctly configured. Expected at least 8 lines of configuration. ${output}"
fi
echo "PASSED....CHECKING PLATFORM CONFIG."
# Test
# Check that PlatformWeb is working by calling the discovery endpoint; the output is a JSON consisting of several keys such
# as "server-key", "instance_name"; here we are checking "instance_name" matches the instance name that we set in platform_config.yml
echo "Testing discovery endpoint on web..."
output=$(curl -s 'http://0.0.0.0:8080/discovery/')
check_error_code $? 'Failed to get or parse http://0.0.0.0:8080/discovery'
instance_name=$(echo ${output} | jq .\"instance-name\")
if [[ "$instance_name" != '"volttron1"' ]]; then
exit_test "Failing Discovery Test. Instance name is not correct. instance_name: ${instance_name}. Complete output ${output}"
fi
echo "PASSED....CHECKING DISCOVERY OF WEB UI."
echo "All tests passed; image is cleared to be pushed to repo."
end=$(date +%s)
runtime=$((end-start))
echo "Testing completed in $runtime seconds"
############ Shutdown container/cleanup
exit_cleanly