From: Karel Zak Date: Thu, 1 Mar 2012 11:30:14 +0000 (+0100) Subject: tests: add tests for mount --make-* stuff X-Git-Tag: v2.22-rc1~732 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=ee99c9cb37b60630d86492c02ea71e872b22c660;p=thirdparty%2Futil-linux.git tests: add tests for mount --make-* stuff Signed-off-by: Karel Zak --- diff --git a/tests/expected/mount/shared-subtree b/tests/expected/mount/shared-subtree new file mode 100644 index 0000000000..35821117c8 --- /dev/null +++ b/tests/expected/mount/shared-subtree @@ -0,0 +1 @@ +Success diff --git a/tests/expected/mount/shared-subtree-make-private b/tests/expected/mount/shared-subtree-make-private new file mode 100644 index 0000000000..39cdd0ded6 --- /dev/null +++ b/tests/expected/mount/shared-subtree-make-private @@ -0,0 +1 @@ +- diff --git a/tests/expected/mount/shared-subtree-make-shared b/tests/expected/mount/shared-subtree-make-shared new file mode 100644 index 0000000000..8a205e8dc3 --- /dev/null +++ b/tests/expected/mount/shared-subtree-make-shared @@ -0,0 +1 @@ +shared diff --git a/tests/expected/mount/shared-subtree-make-unbindable b/tests/expected/mount/shared-subtree-make-unbindable new file mode 100644 index 0000000000..376cfac471 --- /dev/null +++ b/tests/expected/mount/shared-subtree-make-unbindable @@ -0,0 +1 @@ +unbindable diff --git a/tests/ts/mount/shared-subtree b/tests/ts/mount/shared-subtree new file mode 100755 index 0000000000..a0a76c5496 --- /dev/null +++ b/tests/ts/mount/shared-subtree @@ -0,0 +1,58 @@ +#!/bin/bash + +TS_TOPDIR="$(dirname $0)/../.." +TS_DESC="shared-subtree" + +. $TS_TOPDIR/functions.sh +ts_init "$*" +ts_skip_nonroot + +function get_attr() +{ + # It's usually stupid idea to use 'grep | awk', + # but use paths in awk /regex/ is too tricky... + # + # TODO; improve libmount and findmnt to return the + # shared-subtree flags + # + echo $(grep "$1" /proc/self/mountinfo | \ + awk '{print $7}' | \ + awk -F ':' '{ print $1 }') +} + +[ -d $TS_MOUNTPOINT ] || mkdir -p $TS_MOUNTPOINT + +# bind +$TS_CMD_MOUNT --bind $TS_MOUNTPOINT $TS_MOUNTPOINT + +# check the bind +$TS_CMD_FINDMNT --kernel --target $TS_MOUNTPOINT &> /dev/null +[ "$?" == "0" ] || ts_die "Cannot find binded $TS_MOUNTPOINT in /proc/self/mountinfo" + +# use the same mounpoint for all sub-tests +MOUNTPOINT="$TS_MOUNTPOINT" + + +ts_init_subtest "make-shared" +$TS_CMD_MOUNT --make-shared $MOUNTPOINT >> $TS_OUTPUT 2>&1 +echo "$(get_attr $MOUNTPOINT)" >> $TS_OUTPUT +ts_finalize_subtest + +ts_init_subtest "make-private" +$TS_CMD_MOUNT --make-private $MOUNTPOINT >> $TS_OUTPUT 2>&1 +echo "$(get_attr $MOUNTPOINT)" >> $TS_OUTPUT +ts_finalize_subtest + +ts_init_subtest "make-unbindable" +$TS_CMD_MOUNT --make-unbindable $MOUNTPOINT >> $TS_OUTPUT 2>&1 +echo "$(get_attr $MOUNTPOINT)" >> $TS_OUTPUT +ts_finalize_subtest + + +# clean up +$TS_CMD_UMOUNT $TS_MOUNTPOINT +rmdir $TS_MOUNTPOINT + +ts_log "Success" +ts_finalize +