7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn#!/bin/sh
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn# apparmor_mount: test proper handling of apparmor in kernels
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn# without mount features
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn# These require the ubuntu lxc package to be installed.
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn# This program is free software; you can redistribute it and/or
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn# modify it under the terms of the GNU Lesser General Public
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn# License as published by the Free Software Foundation; either
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn# version 2.1 of the License, or (at your option) any later version.
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn# This library is distributed in the hope that it will be useful,
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn# but WITHOUT ANY WARRANTY; without even the implied warranty of
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn# Lesser General Public License for more details.
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn# You should have received a copy of the GNU Lesser General Public
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn# License along with this library; if not, write to the Free Software
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn# This test assumes an Ubuntu host
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynset -e
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn
f58236fd702f8979a68a74e17c7a81f37899edf7Serge Hallynif [ -f /proc/self/ns/cgroup ]; then
f58236fd702f8979a68a74e17c7a81f37899edf7Serge Hallyn default_profile="lxc-container-default-cgns (enforce)"
f58236fd702f8979a68a74e17c7a81f37899edf7Serge Hallynelse
f58236fd702f8979a68a74e17c7a81f37899edf7Serge Hallyn default_profile="lxc-container-default (enforce)"
f58236fd702f8979a68a74e17c7a81f37899edf7Serge Hallynfi
f58236fd702f8979a68a74e17c7a81f37899edf7Serge Hallyn
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge HallynFAIL() {
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn echo -n "Failed " >&2
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn echo "$*" >&2
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn exit 1
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn}
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynrun_cmd() {
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn sudo -i -u $TUSER \
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn env http_proxy=${http_proxy:-} https_proxy=${https_proxy:-} \
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn XDG_RUNTIME_DIR=/run/user/$(id -u $TUSER) $*
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn}
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge HallynDONE=0
3a5495cf2f6c1806f5a91d699448b15b510f146ePo-Hsu LinKNOWN_RELEASES="precise trusty xenial yakkety zesty"
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge HallynMOUNTSR=/sys/kernel/security/apparmor/features/mount
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyndnam=`mktemp -d`
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyncname=`basename $dnam`
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyncleanup() {
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn run_cmd lxc-destroy -f -n $cname || true
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn umount -l $MOUNTSR || true
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn rmdir $dnam || true
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn pkill -u $(id -u $TUSER) -9
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn sed -i '/lxcunpriv/d' /run/lxc/nics /etc/lxc/lxc-usernet
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn sed -i '/^lxcunpriv:/d' /etc/subuid /etc/subgid
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn rm -Rf $HDIR /run/user/$(id -u $TUSER)
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn deluser $TUSER
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn if [ $DONE -eq 0 ]; then
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn echo "FAIL"
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn exit 1
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn fi
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn echo "PASS"
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn}
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyntrap cleanup exit
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn# Only run on a normally configured ubuntu lxc system
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynif [ ! -d /sys/class/net/lxcbr0 ]; then
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn echo "lxcbr0 is not configured."
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn exit 1
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynfi
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynif [ "$(id -u)" != "0" ]; then
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn echo "ERROR: Must run as root."
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn exit 1
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynfi
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn# This would be much simpler if we could run it as
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn# root. However, in order to not have the bind mount
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn# of an empty directory over the securitfs 'mount' directory
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn# be removed, we need to do this as non-root.
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynwhich newuidmap >/dev/null 2>&1 || { echo "'newuidmap' command is missing" >&2; exit 1; }
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn# create a test user
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge HallynTUSER=lxcunpriv
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge HallynHDIR=/home/$TUSER
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge HallynARCH=i386
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynif type dpkg >/dev/null 2>&1; then
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn ARCH=$(dpkg --print-architecture)
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynfi
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyndeluser $TUSER && rm -Rf $HDIR || true
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynuseradd $TUSER
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynmkdir -p $HDIR
efdca59e498ce7a7ff0db091d7d2fec01a91b8eaSerge Hallynecho "$TUSER veth lxcbr0 2" >> /etc/lxc/lxc-usernet
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynsed -i '/^lxcunpriv:/d' /etc/subuid /etc/subgid
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynusermod -v 910000-919999 -w 910000-919999 $TUSER
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynmkdir -p $HDIR/.config/lxc/
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyncat > $HDIR/.config/lxc/default.conf << EOF
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynlxc.network.type = veth
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynlxc.network.link = lxcbr0
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynlxc.id_map = u 0 910000 9999
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynlxc.id_map = g 0 910000 9999
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge HallynEOF
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynchown -R $TUSER: $HDIR
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynmkdir -p /run/user/$(id -u $TUSER)
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynchown -R $TUSER: /run/user/$(id -u $TUSER)
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyncd $HDIR
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn
42e5c9878f0d20b3e9682ef441afed2f0228b298Stéphane Graberif which cgm >/dev/null 2>&1; then
42e5c9878f0d20b3e9682ef441afed2f0228b298Stéphane Graber cgm create all $TUSER
42e5c9878f0d20b3e9682ef441afed2f0228b298Stéphane Graber cgm chown all $TUSER $(id -u $TUSER) $(id -g $TUSER)
42e5c9878f0d20b3e9682ef441afed2f0228b298Stéphane Graber cgm movepid all $TUSER $$
42e5c9878f0d20b3e9682ef441afed2f0228b298Stéphane Graberelif [ -e /sys/fs/cgroup/cgmanager/sock ]; then
42e5c9878f0d20b3e9682ef441afed2f0228b298Stéphane Graber for d in $(cut -d : -f 2 /proc/self/cgroup); do
42e5c9878f0d20b3e9682ef441afed2f0228b298Stéphane Graber dbus-send --print-reply --address=unix:path=/sys/fs/cgroup/cgmanager/sock \
42e5c9878f0d20b3e9682ef441afed2f0228b298Stéphane Graber --type=method_call /org/linuxcontainers/cgmanager org.linuxcontainers.cgmanager0_0.Create \
42e5c9878f0d20b3e9682ef441afed2f0228b298Stéphane Graber string:$d string:$TUSER >/dev/null
42e5c9878f0d20b3e9682ef441afed2f0228b298Stéphane Graber
42e5c9878f0d20b3e9682ef441afed2f0228b298Stéphane Graber dbus-send --print-reply --address=unix:path=/sys/fs/cgroup/cgmanager/sock \
42e5c9878f0d20b3e9682ef441afed2f0228b298Stéphane Graber --type=method_call /org/linuxcontainers/cgmanager org.linuxcontainers.cgmanager0_0.Chown \
42e5c9878f0d20b3e9682ef441afed2f0228b298Stéphane Graber string:$d string:$TUSER int32:$(id -u $TUSER) int32:$(id -g $TUSER) >/dev/null
42e5c9878f0d20b3e9682ef441afed2f0228b298Stéphane Graber
42e5c9878f0d20b3e9682ef441afed2f0228b298Stéphane Graber dbus-send --print-reply --address=unix:path=/sys/fs/cgroup/cgmanager/sock \
42e5c9878f0d20b3e9682ef441afed2f0228b298Stéphane Graber --type=method_call /org/linuxcontainers/cgmanager org.linuxcontainers.cgmanager0_0.MovePid \
42e5c9878f0d20b3e9682ef441afed2f0228b298Stéphane Graber string:$d string:$TUSER int32:$$ >/dev/null
42e5c9878f0d20b3e9682ef441afed2f0228b298Stéphane Graber done
42e5c9878f0d20b3e9682ef441afed2f0228b298Stéphane Graberelse
42e5c9878f0d20b3e9682ef441afed2f0228b298Stéphane Graber for d in /sys/fs/cgroup/*; do
177f793ae07431b2db86b5fa1b63cd59f9a66319Serge Hallyn [ -f $d/cgroup.clone_children ] && echo 1 > $d/cgroup.clone_children
42e5c9878f0d20b3e9682ef441afed2f0228b298Stéphane Graber [ ! -d $d/lxctest ] && mkdir $d/lxctest
42e5c9878f0d20b3e9682ef441afed2f0228b298Stéphane Graber chown -R $TUSER: $d/lxctest
42e5c9878f0d20b3e9682ef441afed2f0228b298Stéphane Graber echo $$ > $d/lxctest/tasks
42e5c9878f0d20b3e9682ef441afed2f0228b298Stéphane Graber done
42e5c9878f0d20b3e9682ef441afed2f0228b298Stéphane Graberfi
42e5c9878f0d20b3e9682ef441afed2f0228b298Stéphane Graber
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynrun_cmd mkdir -p $HDIR/.cache/lxc
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn[ -d /var/cache/lxc/download ] && \
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn cp -R /var/cache/lxc/download $HDIR/.cache/lxc && \
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn chown -R $TUSER: $HDIR/.cache/lxc
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn
01c05c821093dc854def146d4bab62885d8eb664Po-Hsu Lin# default release is trusty, or the systems release if recognized
01c05c821093dc854def146d4bab62885d8eb664Po-Hsu Linrelease=trusty
01c05c821093dc854def146d4bab62885d8eb664Po-Hsu Linif [ -f /etc/lsb-release ]; then
01c05c821093dc854def146d4bab62885d8eb664Po-Hsu Lin . /etc/lsb-release
01c05c821093dc854def146d4bab62885d8eb664Po-Hsu Lin rels=$(ubuntu-distro-info --supported 2>/dev/null) ||
01c05c821093dc854def146d4bab62885d8eb664Po-Hsu Lin rels="$KNOWN_RELEASES"
01c05c821093dc854def146d4bab62885d8eb664Po-Hsu Lin for r in $rels; do
01c05c821093dc854def146d4bab62885d8eb664Po-Hsu Lin [ "$DISTRIB_CODENAME" = "$r" ] && release="$r"
01c05c821093dc854def146d4bab62885d8eb664Po-Hsu Lin done
01c05c821093dc854def146d4bab62885d8eb664Po-Hsu Linfi
01c05c821093dc854def146d4bab62885d8eb664Po-Hsu Lin
01c05c821093dc854def146d4bab62885d8eb664Po-Hsu Linrun_cmd lxc-create -t download -n $cname -- -d ubuntu -r $release -a $ARCH
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynecho "test default confined container"
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynrun_cmd lxc-start -n $cname -d
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynrun_cmd lxc-wait -n $cname -s RUNNING
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynpid=`run_cmd lxc-info -p -H -n $cname`
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynprofile=`cat /proc/$pid/attr/current`
f58236fd702f8979a68a74e17c7a81f37899edf7Serge Hallynif [ "x$profile" != "x${default_profile}" ]; then
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn echo "FAIL: confined container was in profile $profile"
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn exit 1
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynfi
8bb165038d60d59084c1fafee171948244f0f86aStéphane Graberrun_cmd lxc-stop -n $cname -k
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynecho "test regular unconfined container"
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynecho "lxc.aa_profile = unconfined" >> $HDIR/.local/share/lxc/$cname/config
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynrun_cmd lxc-start -n $cname -d
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynrun_cmd lxc-wait -n $cname -s RUNNING
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynpid=`run_cmd lxc-info -p -H -n $cname`
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynprofile=`cat /proc/$pid/attr/current`
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynif [ "x$profile" != "xunconfined" ]; then
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn echo "FAIL: unconfined container was in profile $profile"
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn exit 1
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynfi
8bb165038d60d59084c1fafee171948244f0f86aStéphane Graberrun_cmd lxc-stop -n $cname -k
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynecho "masking $MOUNTSR"
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynmount --bind $dnam $MOUNTSR
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynecho "test default confined container"
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynsed -i '/aa_profile/d' $HDIR/.local/share/lxc/$cname/config
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynrun_cmd lxc-start -n $cname -d || true
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynsleep 3
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynpid=`run_cmd lxc-info -p -H -n $cname` || true
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynif [ -n "$pid" -a "$pid" != "-1" ]; then
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn echo "FAIL: confined container started without mount restrictions"
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn echo "pid was $pid"
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn exit 1
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynfi
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynecho "test regular unconfined container"
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynecho "lxc.aa_profile = unconfined" >> $HDIR/.local/share/lxc/$cname/config
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynrun_cmd lxc-start -n $cname -d
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynrun_cmd lxc-wait -n $cname -s RUNNING
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynpid=`run_cmd lxc-info -p -H -n $cname`
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynif [ "$pid" = "-1" ]; then
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn echo "FAIL: unconfined container failed to start without mount restrictions"
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn exit 1
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynfi
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynprofile=`cat /proc/$pid/attr/current`
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynif [ "x$profile" != "xunconfined" ]; then
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn echo "FAIL: confined container was in profile $profile"
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn exit 1
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynfi
8bb165038d60d59084c1fafee171948244f0f86aStéphane Graberrun_cmd lxc-stop -n $cname -k
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynecho "testing override"
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynsed -i '/aa_profile/d' $HDIR/.local/share/lxc/$cname/config
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynecho "lxc.aa_allow_incomplete = 1" >> $HDIR/.local/share/lxc/$cname/config
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynrun_cmd lxc-start -n $cname -d
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynrun_cmd lxc-wait -n $cname -s RUNNING
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynpid=`run_cmd lxc-info -p -H -n $cname`
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynif [ "$pid" = "-1" ]; then
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn echo "FAIL: excepted container failed to start without mount restrictions"
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn exit 1
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynfi
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynprofile=`cat /proc/$pid/attr/current`
f58236fd702f8979a68a74e17c7a81f37899edf7Serge Hallynif [ "x$profile" != "x${default_profile}" ]; then
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn echo "FAIL: confined container was in profile $profile"
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn exit 1
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallynfi
8bb165038d60d59084c1fafee171948244f0f86aStéphane Graberrun_cmd lxc-stop -n $cname -k
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge Hallyn
7aff4f43fd84b021db12b2ffed1a4aa1b4cf65efSerge HallynDONE=1