| #! /bin/bash |
| # SPDX-License-Identifier: GPL-2.0 |
| # Copyright (c) 2019 Alibaba Group. All Rights Reserved. |
| # |
| # FS QA Test No. 545 |
| # |
| # Check that we can't set the FS_APPEND_FL and FS_IMMUTABLE_FL inode |
| # flags without capbility CAP_LINUX_IMMUTABLE |
| # |
| seq=`basename $0` |
| seqres=$RESULT_DIR/$seq |
| echo "QA output created by $seq" |
| |
| here=`pwd` |
| tmp=/tmp/$$ |
| status=1 # failure is the default! |
| trap "_cleanup; exit \$status" 0 1 2 3 15 |
| |
| _cleanup() |
| { |
| # Cleanup of flags on both file in case test is aborted |
| # (i.e. CTRL-C), so we have no immutable/append-only files |
| $CHATTR_PROG -ia $workdir/file1 >/dev/null 2>&1 |
| $CHATTR_PROG -ia $workdir/file2 >/dev/null 2>&1 |
| |
| cd / |
| rm -rf $tmp.* $workdir |
| } |
| |
| # get standard environment, filters and checks |
| . ./common/rc |
| . ./common/filter |
| . ./common/attr |
| |
| # real QA test starts here |
| _supported_fs generic |
| |
| _require_test |
| _require_chattr i |
| _require_chattr a |
| _require_command "$CAPSH_PROG" "capsh" |
| |
| workdir="$TEST_DIR/test-$seq" |
| rm -rf $workdir |
| mkdir $workdir |
| |
| echo "Create the original files" |
| touch $workdir/file1 |
| touch $workdir/file2 |
| |
| do_filter_output() |
| { |
| grep -o "Operation not permitted" |
| } |
| |
| echo "Try to chattr +ia with capabilities CAP_LINUX_IMMUTABLE" |
| $CHATTR_PROG +a $workdir/file1 |
| $CHATTR_PROG +i $workdir/file1 |
| |
| echo "Try to chattr +ia/-ia without capability CAP_LINUX_IMMUTABLE" |
| $CAPSH_PROG --drop=cap_linux_immutable -- -c "$CHATTR_PROG +a $workdir/file2" 2>&1 | do_filter_output |
| $CAPSH_PROG --drop=cap_linux_immutable -- -c "$CHATTR_PROG +i $workdir/file2" 2>&1 | do_filter_output |
| |
| $CAPSH_PROG --drop=cap_linux_immutable -- -c "$CHATTR_PROG -i $workdir/file1" 2>&1 | do_filter_output |
| $CAPSH_PROG --drop=cap_linux_immutable -- -c "$CHATTR_PROG -a $workdir/file1" 2>&1 | do_filter_output |
| |
| echo "Try to chattr -ia with capability CAP_LINUX_IMMUTABLE" |
| $CHATTR_PROG -i $workdir/file1 |
| $CHATTR_PROG -a $workdir/file1 |
| |
| # success, all done |
| status=0 |
| exit |