mirror of
https://gitlab.com/apparmor/apparmor.git
synced 2025-03-04 08:24:42 +01:00
Write a regression test for mediating file access in unbindable mounts
Signed-off-by: Ryan Lee <ryan.lee@canonical.com>
This commit is contained in:
parent
e8f1ac4791
commit
f249c6d58f
1 changed files with 45 additions and 0 deletions
45
tests/regression/apparmor/file_unbindable_mount.sh
Normal file
45
tests/regression/apparmor/file_unbindable_mount.sh
Normal file
|
@ -0,0 +1,45 @@
|
|||
#! /bin/bash
|
||||
# Copyright (C) 2024 Canonical, Ltd.
|
||||
#
|
||||
# This program is free software; you can redistribute it and/or
|
||||
# modify it under the terms of the GNU General Public License as
|
||||
# published by the Free Software Foundation, version 2 of the
|
||||
# License.
|
||||
|
||||
#=NAME file_unbindable_mount
|
||||
#=DESCRIPTION
|
||||
# Verifies that file rules work across unbindable mounts
|
||||
#=END
|
||||
|
||||
pwd=`dirname $0`
|
||||
pwd=`cd $pwd ; /bin/pwd`
|
||||
|
||||
bin=$pwd
|
||||
|
||||
. "$bin/prologue.inc"
|
||||
|
||||
backing_file="$tmpdir/loop_file"
|
||||
mount_target="$tmpdir/mount_target"
|
||||
|
||||
mkdir ${mount_target}
|
||||
fallocate -l 512K ${backing_file}
|
||||
mkfs.fat -F 32 ${backing_file} > /dev/null 2> /dev/null
|
||||
|
||||
losetup -f ${backing_file} || fatalerror 'Unable to set up a loop device'
|
||||
loop_device="$(/sbin/losetup -n -O NAME -l -j ${backing_file})"
|
||||
|
||||
mount --make-unbindable ${loop_device} ${mount_target}
|
||||
fallocate -l 16K ${mount_target}/a_file
|
||||
# echo is also a builtin, making things a bit more complicated
|
||||
cp $(type -P echo) ${mount_target}/echo
|
||||
|
||||
settest file_unbindable_mount "${bin}/complain"
|
||||
|
||||
genprofile ${mount_target}/a_file:r ${mount_target}/echo:ix
|
||||
runchecktest "Read file in unbindable mount" pass read ${mount_target}/a_file
|
||||
runchecktest "Exec in unbindable mount" pass exec ${mount_target}/echo PASS
|
||||
|
||||
umount ${loop_device}
|
||||
|
||||
losetup -d ${loop_device}
|
||||
rm ${backing_file}
|
Loading…
Add table
Reference in a new issue