#!/bin/bash -e [ "$1" = "-h" ] || [ "$1" = "--help" ] && echo "Setup a working openQA installation, automating the steps mentioned in the 'custom installation' documentation section. Supports to immediately clone an existing job simply by supplying 'openqa-clone-job' parameters directly for a quickstart" && exit set -xeuo pipefail dbname="${dbname:="openqa"}" dbuser="${dbuser:="geekotest"}" BYPASS_SYSTEMD_CHECK="${BYPASS_SYSTEMD_CHECK:=""}" # ensure that systemd is available (which is not the case in some containers) if [ -z "$BYPASS_SYSTEMD_CHECK" ] && ! systemctl > /dev/null ; then echo "$0 requires systemd to be installed and running as the init daemon with PID=1" exit 1 fi # add extra repos for leap # shellcheck disable=SC1091 . /etc/os-release if [ "$NAME" = "openSUSE Leap" ]; then # avoid using `obs://…` URL to workaround https://bugzilla.opensuse.org/show_bug.cgi?id=1187425 repobase=https://download.opensuse.org/repositories/devel:/openQA zypper -n addrepo -p 90 "$repobase/openSUSE_Leap_${VERSION}" 'devel:openQA' zypper -n addrepo -p 91 "$repobase:/Leap:/${VERSION}/openSUSE_Leap_${VERSION}" "devel:openQA:Leap:${VERSION}" zypper -n --gpg-auto-import-keys refresh fi # install packages zypper -n install --no-recommends openQA-single-instance qemu-arm qemu-ppc qemu-x86 qemu-tools sudo iputils os-autoinst-distri-opensuse-deps if [ "$(uname -m)" = "aarch64" ]; then zypper -n install --no-recommends qemu-uefi-aarch64 fi # this was split into a separate package on newer dist versions - so install it if available if zypper -n search -x qemu-hw-display-virtio-gpu-pci ; then zypper -n install --no-recommends qemu-hw-display-virtio-gpu qemu-hw-display-virtio-gpu-pci fi # setup database systemctl enable --now postgresql su postgres -c "/usr/share/openqa/script/setup-db" $dbuser $dbname # setup webserver and fake-auth setup=/usr/share/openqa/script/configure-web-proxy (command -v $setup && sh -ex $setup) || (curl -s https://raw.githubusercontent.com/os-autoinst/openQA/master/script/configure-web-proxy | bash -ex) sed -i -e 's/#*.*method.*=.*$/method = Fake/' /etc/openqa/openqa.ini if ping -c1 download.suse.de. && (! rpm -q ca-certificates-suse) ; then # add internal CA if executed within suse network if ! zypper info ca-certificates-suse | grep -q ':' ; then # add suse ca repo if needed # use this way of adding the repo to be distro agnostic if [ "$NAME" = "openSUSE Leap" ]; then # avoid using `obs://…` URL to workaround https://bugzilla.opensuse.org/show_bug.cgi?id=1187425 zypper -n addrepo "http://download.suse.de/ibs/SUSE:/CA/openSUSE_Leap_${VERSION}" 'SUSE:CA' else zypper -n addrepo obs://SUSE:CA SUSE:CA fi sed -i -e 's#download.opensuse.org/repositories#download.suse.de/ibs#' /etc/zypp/repos.d/SUSE:CA.repo sed -i -e 's/https/http/' /etc/zypp/repos.d/SUSE:CA.repo zypper -n --gpg-auto-import-keys refresh fi zypper -n install --no-recommends -ly ca-certificates-suse fi # fetch tests and needles if ping -c1 gitlab.suse.de. ; then # use faster local mirror if run from within SUSE network export needles_giturl="https://gitlab.suse.de/openqa/os-autoinst-needles-opensuse-mirror.git" fi /usr/share/openqa/script/fetchneedles if [ ! -e /var/lib/openqa/tests/sle ] ; then ln -s opensuse /var/lib/openqa/tests/sle fi if ping -c1 gitlab.suse.de. ; then sles_needles_giturl="https://gitlab.suse.de/openqa/os-autoinst-needles-sles.git" sles_needles_directory="/var/lib/openqa/tests/opensuse/products/sle/needles" # clone SLE needles if run from within SUSE network if [ ! -d $sles_needles_directory ]; then echo "cloning $sles_needles_giturl shallow. Call 'git fetch --unshallow' for full history" git clone --depth 1 "$sles_needles_giturl" "$sles_needles_directory" fi chown -R $dbuser: /var/lib/openqa/tests/opensuse/products/sle/needles fi # ensure that the hostname is mapped to 127.0.0.1 (needed for livehandler) grep -q "$(hostname)" /etc/hosts || echo "127.0.0.1 $(hostname)" >> /etc/hosts # start daemons systemctl enable --now apache2 systemctl enable --now openqa-webui systemctl enable --now openqa-scheduler # wait for webui to become available while ! curl -sI http://localhost/ | grep 200 ; do sleep 3 done # create api key curl http://localhost/login # create demo user (id=2) API_KEY=$(hexdump -n 8 -e '2/4 "%08X" 1 "\n"' /dev/random) API_SECRET=$(hexdump -n 8 -e '2/4 "%08X" 1 "\n"' /dev/random) echo "INSERT INTO api_keys (key, secret, user_id, t_created, t_updated) VALUES ('${API_KEY}', '${API_SECRET}', 2, NOW(), NOW());" | su postgres -c "psql $dbname" cat >> /etc/openqa/client.conf <