Add FMF tests and test scripts
This commit is contained in:
parent
86f674bd92
commit
f577208220
5 changed files with 165 additions and 0 deletions
75
test/browser/browser.sh
Normal file
75
test/browser/browser.sh
Normal file
|
|
@ -0,0 +1,75 @@
|
|||
#!/bin/sh
|
||||
set -eux
|
||||
|
||||
TESTS="$(realpath $(dirname "$0"))"
|
||||
SOURCE="$(realpath $TESTS/../..)"
|
||||
LOGS="$(pwd)/logs"
|
||||
mkdir -p "$LOGS"
|
||||
chmod a+w "$LOGS"
|
||||
|
||||
# HACK: https://bugzilla.redhat.com/show_bug.cgi?id=2033020
|
||||
dnf update -y pam || true
|
||||
|
||||
# install firefox (available everywhere in Fedora and RHEL)
|
||||
# we don't need the H.264 codec, and it is sometimes not available (rhbz#2005760)
|
||||
dnf install --disablerepo=fedora-cisco-openh264 -y --setopt=install_weak_deps=False firefox
|
||||
|
||||
# nodejs 10 is too old for current Cockpit test API
|
||||
if grep -q platform:el8 /etc/os-release; then
|
||||
dnf module switch-to -y nodejs:16
|
||||
fi
|
||||
|
||||
# create user account for logging in
|
||||
if ! id admin 2>/dev/null; then
|
||||
useradd -c Administrator -G wheel admin
|
||||
echo admin:foobar | chpasswd
|
||||
fi
|
||||
|
||||
# set root's password
|
||||
echo root:foobar | chpasswd
|
||||
|
||||
# avoid sudo lecture during tests
|
||||
su -c 'echo foobar | sudo --stdin whoami' - admin
|
||||
|
||||
# create user account for running the test
|
||||
if ! id runtest 2>/dev/null; then
|
||||
useradd -c 'Test runner' runtest
|
||||
# allow test to set up things on the machine
|
||||
mkdir -p /root/.ssh
|
||||
curl https://raw.githubusercontent.com/cockpit-project/bots/main/machine/identity.pub >> /root/.ssh/authorized_keys
|
||||
chmod 600 /root/.ssh/authorized_keys
|
||||
fi
|
||||
chown -R runtest "$SOURCE"
|
||||
|
||||
# disable core dumps, we rather investigate them upstream where test VMs are accessible
|
||||
echo core > /proc/sys/kernel/core_pattern
|
||||
|
||||
## CSR specific setup ##
|
||||
# install cockpit-packagekit and glibc-langpack-en for testAppMenu
|
||||
dnf install -y cockpit-packagekit glibc-langpack-en
|
||||
|
||||
mkdir -p /var/log/journal/
|
||||
cp 1.journal /var/log/journal/1.journal
|
||||
cp binary-rec.journal /var/log/journal/binary-rec.journal
|
||||
|
||||
# Add proxy provider domain for sssd for testSessionRecordingConf test
|
||||
cat > /etc/sssd/sssd.conf <<EOF
|
||||
[sssd]
|
||||
services=nss, pam
|
||||
domains=nssfiles
|
||||
|
||||
[domain/nssfiles]
|
||||
id_provider=proxy
|
||||
proxy_lib_name=files
|
||||
proxy_pam_target=sssd-shadowutils
|
||||
EOF
|
||||
chmod 600 /etc/sssd/sssd.conf
|
||||
systemctl start sssd
|
||||
|
||||
systemctl enable --now cockpit.socket
|
||||
|
||||
# Run tests as unprivileged user
|
||||
su - -c "env TEST_BROWSER=firefox SOURCE=$SOURCE LOGS=$LOGS $TESTS/run-test.sh" runtest
|
||||
|
||||
RC=$(cat $LOGS/exitcode)
|
||||
exit ${RC:-1}
|
||||
Loading…
Add table
Add a link
Reference in a new issue