8af9723c37
- save compose logs under /var/log/$TEST - save qemu logs under /var/log/$TEST/qemu.log - download everything to $TEST_ATTACHMENTS so it can be saved in CI results
128 lines
3.9 KiB
Bash
Executable File
128 lines
3.9 KiB
Bash
Executable File
#!/bin/bash
|
|
# Note: execute this file from the project root directory
|
|
|
|
set -eu
|
|
|
|
export BEAKERLIB_DIR=$(mktemp -d /tmp/composer-test.XXXXXX)
|
|
CLI="${CLI:-}"
|
|
|
|
function setup_tests {
|
|
local share_dir=$1
|
|
local blueprints_dir=$2
|
|
|
|
# explicitly enable sshd for live-iso b/c it is disabled by default
|
|
# due to security concerns (no root password required)
|
|
sed -i.orig 's/^services.*/services --disabled="network" --enabled="NetworkManager,sshd"/' $share_dir/composer/live-iso.ks
|
|
# explicitly enable logging in with empty passwords via ssh, because
|
|
# the default sshd setting for PermitEmptyPasswords is 'no'
|
|
awk -i inplace "
|
|
/%post/ && FLAG != 2 {FLAG=1}
|
|
/%end/ && FLAG == 1 {print \"sed -i 's/.*PermitEmptyPasswords.*/PermitEmptyPasswords yes/' /etc/ssh/sshd_config\"; FLAG=2}
|
|
{print}" \
|
|
$share_dir/composer/live-iso.ks
|
|
|
|
# do a backup of the original blueprints directory and get rid of the git
|
|
# directory (otherwise all of the initial changes in blueprints would have
|
|
# to be done using blueprints push)
|
|
cp -r $blueprints_dir ${blueprints_dir}.orig
|
|
rm -rf $blueprints_dir/git
|
|
|
|
# append a section with additional option on kernel command line to example-http-server blueprint
|
|
# which is used for building of most of the images
|
|
cat >> $blueprints_dir/example-http-server.toml << __EOF__
|
|
|
|
[customizations.kernel]
|
|
append = "custom_cmdline_arg console=ttyS0,115200n8"
|
|
__EOF__
|
|
}
|
|
|
|
function teardown_tests {
|
|
local share_dir=$1
|
|
local blueprints_dir=$2
|
|
|
|
mv $share_dir/composer/live-iso.ks.orig $share_dir/composer/live-iso.ks
|
|
rm -rf $blueprints_dir
|
|
mv ${blueprints_dir}.orig $blueprints_dir
|
|
}
|
|
|
|
# cloud credentials
|
|
if [ -f "~/.config/lorax-test-env" ]; then
|
|
. ~/.config/lorax-test-env
|
|
fi
|
|
|
|
if [ -f "/var/tmp/lorax-test-env" ]; then
|
|
. /var/tmp/lorax-test-env
|
|
fi
|
|
|
|
if [ -z "$CLI" ]; then
|
|
export top_srcdir=`pwd`
|
|
. ./tests/testenv.sh
|
|
|
|
BLUEPRINTS_DIR=`mktemp -d '/tmp/composer-blueprints.XXXXX'`
|
|
export BLUEPRINTS_DIR
|
|
cp ./tests/pylorax/blueprints/*.toml $BLUEPRINTS_DIR
|
|
|
|
SHARE_DIR=`mktemp -d '/tmp/composer-share.XXXXX'`
|
|
cp -R ./share/* $SHARE_DIR
|
|
chmod a+rx -R $SHARE_DIR
|
|
|
|
setup_tests $SHARE_DIR $BLUEPRINTS_DIR
|
|
# start the lorax-composer daemon
|
|
./src/sbin/lorax-composer --sharedir $SHARE_DIR $BLUEPRINTS_DIR &
|
|
else
|
|
export PACKAGE="composer-cli"
|
|
export BLUEPRINTS_DIR="/var/lib/lorax/composer/blueprints"
|
|
systemctl stop lorax-composer
|
|
setup_tests /usr/share/lorax /var/lib/lorax/composer/blueprints
|
|
systemctl start lorax-composer
|
|
fi
|
|
|
|
|
|
# wait for the backend to become ready
|
|
tries=0
|
|
until curl -m 15 --unix-socket /run/weldr/api.socket http://localhost:4000/api/status | grep 'db_supported.*true'; do
|
|
tries=$((tries + 1))
|
|
if [ $tries -gt 50 ]; then
|
|
exit 1
|
|
fi
|
|
sleep 5
|
|
echo "DEBUG: Waiting for backend API to become ready before testing ..."
|
|
done;
|
|
|
|
export BEAKERLIB_JOURNAL=0
|
|
if [ -z "$*" ]; then
|
|
# invoke cli/ tests which can be executed without special preparation
|
|
./tests/cli/test_blueprints_sanity.sh
|
|
./tests/cli/test_compose_sanity.sh
|
|
else
|
|
# execute other cli tests which need more adjustments in the calling environment
|
|
# or can't be executed inside Travis CI
|
|
for TEST in "$@"; do
|
|
$TEST
|
|
done
|
|
fi
|
|
|
|
|
|
if [ -z "$CLI" ]; then
|
|
# stop lorax-composer and remove /run/weldr/api.socket
|
|
# only if running against source
|
|
pkill -9 lorax-composer
|
|
rm -f /run/weldr/api.socket
|
|
teardown_tests $SHARE_DIR $BLUEPRINTS_DIR
|
|
else
|
|
systemctl stop lorax-composer
|
|
teardown_tests /usr/share/lorax /var/lib/lorax/composer/blueprints
|
|
# start lorax-composer again so we can continue with manual or other kinds
|
|
# of testing on the same system
|
|
systemctl start lorax-composer
|
|
fi
|
|
|
|
. $BEAKERLIB_DIR/TestResults
|
|
|
|
if [ $TESTRESULT_RESULT_ECODE != 0 ]; then
|
|
echo "Test failed. Leaving log in $BEAKERLIB_DIR"
|
|
exit $TESTRESULT_RESULT_ECODE
|
|
fi
|
|
|
|
rm -rf $BEAKERLIB_DIR
|