cockpit/tests/verify.sh

66 lines
2.3 KiB
Bash
Raw Normal View History

#!/bin/sh
set -eux
2019-07-30 09:07:45 +00:00
# from standard-test-source
SOURCE="$(pwd)/source"
LOGS="$(pwd)/logs"
mkdir -p "$LOGS"
chmod a+w "$LOGS"
# these get mounted into the tasks container
chcon -Rt container_file_t "$SOURCE" "$LOGS"
# create user account for logging in
if ! id admin 2>/dev/null; then
useradd -c Administrator -G wheel admin
echo admin:foobar | chpasswd
fi
# make sure that we can access cockpit through the firewall
systemctl start firewalld
firewall-cmd --add-service=cockpit --permanent
firewall-cmd --add-service=cockpit
# The cockpit/tests container has chromium-browser and other test
# dependencies, which we don't have on RHEL itself. Also, we don't actually
# want to install these on the tested image, so run the test in a container,
# which tests the host. Use a fixed tag to avoid running into failures with
# "latest", as we don't gate container updates on the dist-git tests for now.
RC=0
2020-03-23 08:57:56 +00:00
cat <<EOF | podman run --rm -i -v "$SOURCE:/source:ro" -v "$LOGS:/logs" docker.io/cockpit/tasks:2020-01-30 /bin/sh -eux || RC=$?
# CSP does not like the the invalid host name _gateway, so translate it
HOST=\$(getent hosts _gateway | cut -f1 -d' ')
2019-07-30 09:07:45 +00:00
trap "cp --verbose Test* /logs/ || true" EXIT
# tests need cockpit's bots/ libraries
cd /tmp
git clone --depth=1 https://github.com/cockpit-project/cockpit
cd cockpit
2020-03-23 08:57:56 +00:00
git clone --depth=1 https://github.com/cockpit-project/bots
2019-07-30 09:07:45 +00:00
# copy tests from our source, so that they match the released version
rm -rf test
cp -a /source/test .
2019-07-30 09:07:45 +00:00
# only install a subset to save time/space
npm install axe-core chrome-remote-interface sizzle
2020-03-23 08:57:56 +00:00
export TEST_OS=fedora-32
export TEST_AUDIT_NO_SELINUX=1
# FIXME: testSessionRecordingShell fails
test/verify/check-login -tv --machine \$HOST:22 --browser \$HOST:9090 TestLogin.{testBasic,testExpired,testSELinuxRestrictedUser}
# check-menu is not @nondestructive yet, keep it last
for t in networking-firewall sosreport storage-basic storage-ignored storage-partitions storage-used storage-lvm2 menu accounts; do
test/verify/check-\$t -tv --machine \$HOST:22 --browser \$HOST:9090
done
EOF
# reset system changes from verify tests, for running this multiple times in a row
# HACK: Isolate tests from each other: https://pagure.io/fedora-ci/general/issue/11
rm -f /etc/systemd/system/cockpit.service.d/notls.conf
systemctl daemon-reload
systemctl stop cockpit.service
exit $RC