-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathcanary_tests.sh
executable file
·51 lines (39 loc) · 2.12 KB
/
canary_tests.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
#!/bin/bash
set -ex # -e: exit immediately if there are errors. -x: print out every line that runs
echo '' # Give some visual separation to any humans looking at the logs
date '+%Y-%m-%d' # This is to help the logs analysis find today's logs.
if [[ "$(whoami)" != "root" ]] ; then
echo "We must run as root, but currently we're $(whoami) instead."
exit 1
fi
# See https://stackoverflow.com/a/1482133 for an explanation of this next line. It gets the
# directory in which this script resides.
this_dir="$(dirname -- "$( readlink -f -- "$0"; )")";
pushd "$this_dir" > /dev/null
# This script is adapted from
# https://viam.atlassian.net/wiki/spaces/ENG/pages/155451406/Data+ML+Canary+Testing+Bot
systemctl stop viam-canary
# Install the latest rdk. Installing instead of upgrading to ensure we get the latest version and don't get stuck on stable.
curl "https://storage.googleapis.com/packages.viam.com/apps/viam-server/viam-server-latest-$(uname -m).AppImage" -o viam-server
chmod 755 viam-server
./viam-server --aix-install
# It's possible that the config for the "normal" RDK on this board has components attached to it
# because someone was working on the board recently. When we re-install the RDK on the previous
# line, it restarts the "normal" RDK service, even if it was previously stopped. This might take
# ownership of the pins we want to test, so stop it before starting the canary, or we could get
# spurious test failures!
systemctl stop viam-server
systemctl start viam-canary
sleep 120 # The server takes some time to set up its connections; don't talk to it too soon.
git pull --ff-only origin main # Update the test script if necessary
source venv/bin/activate
pip install -r requirements.txt # Install any new dependencies
echo "running tests..."
# Try to get more detailed info for https://viam.atlassian.net/browse/RSDK-6252
export RUST_BACKTRACE=full
# The cron job that runs our script writes stdout to file. If something goes wrong in the tests, it
# will be written to stderr. Redirect that to stdout so it gets written to file, too.
./canary_tests.py 2>&1
echo "done running tests!"
popd > /dev/null # pushd "$this_dir"
exit 0