plugins/test_linux.sh

64 lines
1.3 KiB
Bash
Raw Normal View History

#!/usr/bin/env bash
2017-03-13 17:05:55 +00:00
#
# Run CNI plugin tests.
#
# This needs sudo, as we'll be creating net interfaces.
2017-03-13 17:05:55 +00:00
#
set -e
2019-04-03 18:03:17 +00:00
# switch into the repo root directory
cd "$(dirname "$0")"
2019-04-03 18:03:17 +00:00
# Build all plugins before testing
. ./build_linux.sh
2017-03-13 17:05:55 +00:00
echo "Running tests"
testrun() {
sudo -E sh -c "umask 0; PATH=${GOPATH}/bin:$(pwd)/bin:${PATH} go test -race $*"
2019-04-03 18:03:17 +00:00
}
ensure_sysctl() {
local key
local val
local existing
key="$1"
val="$2"
existing="$(sysctl -ben "$key")"
sysctl -r
if [ "$val" -ne "$existing" ]; then
echo "sudo sysctl -we '$key'='$val'"
sudo sysctl -we "$key"="$val"
fi
}
2019-04-03 18:03:17 +00:00
COVERALLS=${COVERALLS:-""}
2019-04-03 18:03:17 +00:00
if [ -n "${COVERALLS}" ]; then
echo "with coverage profile generation..."
else
2019-04-03 18:03:17 +00:00
echo "without coverage profile generation..."
fi
PKG=${PKG:-$(go list ./... | xargs echo)}
2019-04-03 18:03:17 +00:00
i=0
for t in ${PKG}; do
if [ -n "${COVERALLS}" ]; then
COVERFLAGS="-covermode atomic -coverprofile ${i}.coverprofile"
2019-04-03 18:03:17 +00:00
fi
echo "${t}"
2019-04-03 18:03:17 +00:00
testrun "${COVERFLAGS:-""} ${t}"
i=$((i+1))
done
# Run the pkg/ns tests as non root user
mkdir -p /tmp/cni-rootless
ensure_sysctl kernel.unprivileged_userns_clone 1
ensure_sysctl kernel.apparmor_restrict_unprivileged_userns 0
(export XDG_RUNTIME_DIR=/tmp/cni-rootless; cd pkg/ns/; unshare -rmn go test)