blob: 1b8a879605924f1bcd62ffd0ddebf5241fc5af43 [file] [log] [blame]
#!/bin/bash
SETS_DEFAULTS="${TCID=test07-2} ${TST_COUNT=1} ${TST_TOTAL=1}"
declare -r TCID
declare -r TST_COUNT
declare -r TST_TOTAL
export TCID TST_COUNT TST_TOTAL
tst_resm TINFO "***************TEST07-2***************"
tst_resm TINFO "bind: create slave then mount master - slave still propagates."
tst_resm TINFO "************************************"
. "${FS_BIND_ROOT}/bin/setup" || (tst_resm TWARN "Setup of bind/test07-2 failed" && tst_exit)
export result=0
trap 'ERR=$? ; ERR_MSG="caught error near: ${BASH_SOURCE[0]}:${FUNCNAME[0]}:${LINENO}:$_ (returned ${ERR})"; break' ERR
while /bin/true ; do
# This loop is for error recovery purposes only
"${FS_BIND_ROOT}/bin/makedir" share parent2
"${FS_BIND_ROOT}/bin/makedir" share share2
mount --bind share2 parent2
"${FS_BIND_ROOT}/bin/makedir" slave parent2
mount --bind "$disk1" share2
check parent2 share2
mount --bind "$disk2" parent2/a
check -n parent2/a share2/a
break
done
trap 'ERR=$? ; tst_resm TWARN "bind/test07-2: caught error near: ${BASH_SOURCE[0]}:${FUNCNAME[0]}:${LINENO}:$_ (returned ${ERR})"' ERR
if [ -n "${ERR_MSG}" ]; then
tst_resm TWARN "bind/test07-2: ${ERR_MSG}"
ERR_MSG=""
result=$ERR
fi
trap '' ERR
{
umount parent2/a
umount parent2
umount parent2
umount parent2
umount share2
umount share2
rm -rf parent* share*
cleanup
} >& /dev/null
if [ $result -ne 0 ]
then
tst_resm TFAIL "bind/test07-2: FAILED: bind: create slave then mount master - slave still propagates."
exit 1
else
tst_resm TPASS "bind/test07-2: PASSED"
exit 0
fi
tst_exit