summaryrefslogtreecommitdiff
path: root/tests/xfs/296
blob: efd303e213e29dcc4b625b0268c386bc6ffd3845 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
#! /bin/bash
# SPDX-License-Identifier: GPL-2.0
# Copyright (c) 2013 Red Hat, Inc.  All Rights Reserved.
#
# FS QA Test No. 296
#
# Test that xfsdump/restore preserves file capabilities
#
. ./common/preamble
_begin_fstest dump auto quick

# Override the default cleanup function.
_cleanup()
{
    _cleanup_dump
    cd /
    rm -f $tmp.*
}

# Import common functions.
. ./common/filter
. ./common/dump

# real QA test starts here

# Modify as appropriate.
_supported_fs xfs
_require_scratch
_require_command "$SETCAP_PROG" setcap
_require_command "$GETCAP_PROG" getcap
_scratch_mkfs_xfs >>$seqres.full || _fail "mkfs failed"
_scratch_mount

mkdir -p $dump_dir
echo test > $dump_dir/testfile
# Set a generic xattr
setfattr -n user.name -v value $dump_dir/testfile
# Now set the cap (which is also an xattr)
$SETCAP_PROG cap_setgid,cap_setuid+ep $dump_dir/testfile
# And make sure they are there on the source
echo "Checking for xattr on source file"
getfattr --absolute-names -m user.name $dump_dir/testfile | _dir_filter
echo "Checking for capability on source file"
_getcap $dump_dir/testfile | _dir_filter
getfattr --absolute-names -m security.capability $dump_dir/testfile | _dir_filter

_do_dump_file -f $tmp.df.0
_prepare_restore_dir
_do_restore_file
# Basic dump/restore checks first - the file is there, right?
_ls_compare_sub
_diff_compare

echo "Checking for xattr on restored file"
getfattr --absolute-names -m user.name $restore_dir/$dump_sdir/testfile | _dir_filter
echo "Checking for capability on restored file"
_getcap $restore_dir/$dump_sdir/testfile | _dir_filter
getfattr --absolute-names -m security.capability $restore_dir/$dump_sdir/testfile | _dir_filter

status=0
exit