2019-02-18 17:17:31 +00:00
|
|
|
#!/bin/bash
|
|
|
|
# Note: execute this file from the project root directory
|
|
|
|
|
|
|
|
#####
|
|
|
|
#
|
|
|
|
# Builds tar images and tests them with Docker and systemd-nspawn
|
|
|
|
#
|
|
|
|
#####
|
|
|
|
|
2019-06-17 12:35:31 +00:00
|
|
|
set -e
|
|
|
|
|
2019-02-18 17:17:31 +00:00
|
|
|
. /usr/share/beakerlib/beakerlib.sh
|
2019-06-17 12:35:31 +00:00
|
|
|
. $(dirname $0)/lib/lib.sh
|
2019-02-18 17:17:31 +00:00
|
|
|
|
2019-03-08 10:29:11 +00:00
|
|
|
CLI="${CLI:-./src/bin/composer-cli}"
|
2019-02-18 17:17:31 +00:00
|
|
|
|
|
|
|
|
|
|
|
rlJournalStart
|
|
|
|
rlPhaseStartSetup
|
|
|
|
rlAssertExists /usr/bin/docker
|
2019-05-20 09:49:17 +00:00
|
|
|
rlRun -t -c "systemctl restart docker"
|
2019-02-18 17:17:31 +00:00
|
|
|
rlPhaseEnd
|
|
|
|
|
|
|
|
rlPhaseStartTest "compose start"
|
|
|
|
rlAssertEquals "SELinux operates in enforcing mode" "$(getenforce)" "Enforcing"
|
|
|
|
UUID=`$CLI compose start example-http-server tar`
|
|
|
|
rlAssertEquals "exit code should be zero" $? 0
|
|
|
|
|
|
|
|
UUID=`echo $UUID | cut -f 2 -d' '`
|
|
|
|
rlPhaseEnd
|
|
|
|
|
|
|
|
rlPhaseStartTest "compose finished"
|
|
|
|
if [ -n "$UUID" ]; then
|
2019-06-17 12:35:31 +00:00
|
|
|
until $CLI compose details $UUID | grep 'FINISHED\|FAILED'; do
|
2019-02-18 17:17:31 +00:00
|
|
|
sleep 10
|
|
|
|
rlLogInfo "Waiting for compose to finish ..."
|
|
|
|
done;
|
|
|
|
else
|
|
|
|
rlFail "Compose UUID is empty!"
|
|
|
|
fi
|
|
|
|
|
2019-06-17 12:35:31 +00:00
|
|
|
# Running a compose can lead to a different selinux policy in the
|
|
|
|
# kernel, which may break docker. Reload the policy from the host and
|
|
|
|
# restart docker as a workaround.
|
|
|
|
# See https://bugzilla.redhat.com/show_bug.cgi?id=1711813
|
|
|
|
semodule -R
|
|
|
|
systemctl restart docker
|
|
|
|
|
2019-02-18 17:17:31 +00:00
|
|
|
rlRun -t -c "$CLI compose image $UUID"
|
|
|
|
IMAGE="$UUID-root.tar.xz"
|
|
|
|
rlPhaseEnd
|
|
|
|
|
|
|
|
rlPhaseStartTest "Verify tar image with Docker"
|
|
|
|
rlRun -t -c "docker import $IMAGE composer/$UUID:latest"
|
|
|
|
|
|
|
|
# verify we can run a container with this image
|
2019-05-20 09:49:17 +00:00
|
|
|
rlRun -t -c "docker run --rm --entrypoint /usr/bin/cat composer/$UUID /etc/redhat-release"
|
2019-02-18 17:17:31 +00:00
|
|
|
rlPhaseEnd
|
|
|
|
|
|
|
|
rlPhaseStartTest "Verify tar image with systemd-nspawn"
|
|
|
|
if [ -f /usr/bin/systemd-nspawn ]; then
|
2019-06-17 12:35:31 +00:00
|
|
|
NSPAWN_DIR=`mktemp -d /var/tmp/nspawn.XXXX`
|
|
|
|
rlRun -t -c "tar -xJf $IMAGE -C $NSPAWN_DIR"
|
2019-02-18 17:17:31 +00:00
|
|
|
|
|
|
|
# verify we can run a container with this image
|
|
|
|
rlRun -t -c "systemd-nspawn -D $NSPAWN_DIR cat /etc/redhat-release"
|
|
|
|
else
|
|
|
|
rlLogInfo "systemd-nspawn not found!"
|
|
|
|
fi
|
|
|
|
rlPhaseEnd
|
|
|
|
|
|
|
|
rlPhaseStartCleanup
|
|
|
|
rlRun -t -c "rm -rf $IMAGE $NSPAWN_DIR"
|
|
|
|
rlRun -t -c "$CLI compose delete $UUID"
|
|
|
|
rlRun -t -c "docker rmi composer/$UUID"
|
|
|
|
rlPhaseEnd
|
|
|
|
|
|
|
|
rlJournalEnd
|
|
|
|
rlJournalPrintText
|