forked from openzfs/zfs
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
This branch contains the following fixes/improvements. * Fix setting i_flags * Fix wrong operator in xvattr.h * Fix fchange macro in zpl_ioctl_setflags() * Added configure check to use inode_set_flags() * Added a test case for chattr for better test coverage Reviewed-by: Tim Chase <[email protected]> Reviewed-by: Brian Behlendorf <[email protected]> Signed-off-by: Chunwei Chen <[email protected]> Closes openzfs#5486 Closes openzfs#5470 Closes openzfs#5469
- Loading branch information
Showing
13 changed files
with
309 additions
and
18 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,18 @@ | ||
dnl # | ||
dnl # 3.15 API change | ||
dnl # inode_set_flags introduced to set i_flags | ||
dnl # | ||
AC_DEFUN([ZFS_AC_KERNEL_INODE_SET_FLAGS], [ | ||
AC_MSG_CHECKING([whether inode_set_flags() exists]) | ||
ZFS_LINUX_TRY_COMPILE([ | ||
#include <linux/fs.h> | ||
],[ | ||
struct inode inode; | ||
inode_set_flags(&inode, S_IMMUTABLE, S_IMMUTABLE); | ||
],[ | ||
AC_MSG_RESULT(yes) | ||
AC_DEFINE(HAVE_INODE_SET_FLAGS, 1, [inode_set_flags() exists]) | ||
],[ | ||
AC_MSG_RESULT(no) | ||
]) | ||
]) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -5,6 +5,7 @@ SUBDIRS = \ | |
cache \ | ||
cachefile \ | ||
casenorm \ | ||
chattr \ | ||
checksum \ | ||
clean_mirror \ | ||
cli_root \ | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
pkgdatadir = $(datadir)/@PACKAGE@/zfs-tests/tests/functional/chattr | ||
dist_pkgdata_SCRIPTS = \ | ||
setup.ksh \ | ||
cleanup.ksh \ | ||
chattr_001_pos.ksh \ | ||
chattr_002_neg.ksh |
75 changes: 75 additions & 0 deletions
75
tests/zfs-tests/tests/functional/chattr/chattr_001_pos.ksh
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,75 @@ | ||
#!/bin/ksh -p | ||
# | ||
# CDDL HEADER START | ||
# | ||
# The contents of this file are subject to the terms of the | ||
# Common Development and Distribution License (the "License"). | ||
# You may not use this file except in compliance with the License. | ||
# | ||
# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE | ||
# or http://www.opensolaris.org/os/licensing. | ||
# See the License for the specific language governing permissions | ||
# and limitations under the License. | ||
# | ||
# When distributing Covered Code, include this CDDL HEADER in each | ||
# file and include the License file at usr/src/OPENSOLARIS.LICENSE. | ||
# If applicable, add the following below this CDDL HEADER, with the | ||
# fields enclosed by brackets "[]" replaced with your own identifying | ||
# information: Portions Copyright [yyyy] [name of copyright owner] | ||
# | ||
# CDDL HEADER END | ||
# | ||
|
||
# | ||
# Copyright 2009 Sun Microsystems, Inc. All rights reserved. | ||
# Use is subject to license terms. | ||
# | ||
|
||
# | ||
# Copyright (c) 2013 by Delphix. All rights reserved. | ||
# | ||
. $STF_SUITE/include/libtest.shlib | ||
. $STF_SUITE/tests/functional/userquota/userquota_common.kshlib | ||
|
||
# | ||
# | ||
# DESCRIPTION: | ||
# Check whether chattr works as expected | ||
# | ||
# | ||
# STRATEGY: | ||
# 1. Create 3 files | ||
# 2. Use chattr to make them writable, immutable and appendonly | ||
# 3. Try to write and append to each file | ||
# | ||
|
||
set -A files writable immutable append | ||
|
||
function cleanup | ||
{ | ||
for i in ${files[*]}; do | ||
log_must chattr -ia $TESTDIR/$i | ||
log_must rm -f $TESTDIR/$i | ||
done | ||
} | ||
|
||
log_onexit cleanup | ||
|
||
log_assert "Check whether chattr works as expected" | ||
|
||
log_must touch $TESTDIR/writable | ||
log_must touch $TESTDIR/immutable | ||
log_must touch $TESTDIR/append | ||
|
||
log_must chattr -i $TESTDIR/writable | ||
log_must chattr +i $TESTDIR/immutable | ||
log_must chattr +a $TESTDIR/append | ||
|
||
log_must echo test > $TESTDIR/writable | ||
log_must echo test >> $TESTDIR/writable | ||
log_mustnot echo test > $TESTDIR/immutable | ||
log_mustnot echo test >> $TESTDIR/immutable | ||
log_mustnot echo test > $TESTDIR/append | ||
log_must echo test >> $TESTDIR/append | ||
|
||
log_pass "chattr works as expected" |
81 changes: 81 additions & 0 deletions
81
tests/zfs-tests/tests/functional/chattr/chattr_002_neg.ksh
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,81 @@ | ||
#!/bin/ksh -p | ||
# | ||
# CDDL HEADER START | ||
# | ||
# The contents of this file are subject to the terms of the | ||
# Common Development and Distribution License (the "License"). | ||
# You may not use this file except in compliance with the License. | ||
# | ||
# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE | ||
# or http://www.opensolaris.org/os/licensing. | ||
# See the License for the specific language governing permissions | ||
# and limitations under the License. | ||
# | ||
# When distributing Covered Code, include this CDDL HEADER in each | ||
# file and include the License file at usr/src/OPENSOLARIS.LICENSE. | ||
# If applicable, add the following below this CDDL HEADER, with the | ||
# fields enclosed by brackets "[]" replaced with your own identifying | ||
# information: Portions Copyright [yyyy] [name of copyright owner] | ||
# | ||
# CDDL HEADER END | ||
# | ||
|
||
# | ||
# Copyright 2009 Sun Microsystems, Inc. All rights reserved. | ||
# Use is subject to license terms. | ||
# | ||
|
||
# | ||
# Copyright (c) 2013 by Delphix. All rights reserved. | ||
# | ||
. $STF_SUITE/include/libtest.shlib | ||
. $STF_SUITE/tests/functional/userquota/userquota_common.kshlib | ||
|
||
# | ||
# | ||
# DESCRIPTION: | ||
# Check whether unprivileged user can chattr | ||
# | ||
# | ||
# STRATEGY: | ||
# 1. Create 3 files | ||
# 2. Use chattr to make them writable, immutable and appendonly | ||
# 3. Try to chattr with unprivileged user | ||
# | ||
|
||
set -A files writable immutable append | ||
|
||
function cleanup | ||
{ | ||
for i in ${files[*]}; do | ||
log_must chattr -ia $TESTDIR/$i | ||
log_must rm -f $TESTDIR/$i | ||
done | ||
log_must $CHMOD 0755 $TESTDIR | ||
} | ||
|
||
log_onexit cleanup | ||
|
||
log_assert "Check whether unprivileged user can chattr" | ||
|
||
log_must $CHMOD 0777 $TESTDIR | ||
|
||
log_must user_run $QUSER1 touch $TESTDIR/writable | ||
log_must user_run $QUSER1 touch $TESTDIR/immutable | ||
log_must user_run $QUSER1 touch $TESTDIR/append | ||
|
||
log_must chattr -i $TESTDIR/writable | ||
log_must chattr +i $TESTDIR/immutable | ||
log_must chattr +a $TESTDIR/append | ||
|
||
log_must user_run $QUSER1 chattr -i $TESTDIR/writable | ||
log_must user_run $QUSER1 chattr -a $TESTDIR/writable | ||
log_must user_run $QUSER1 chattr +i $TESTDIR/immutable | ||
log_must user_run $QUSER1 chattr +a $TESTDIR/append | ||
|
||
log_mustnot user_run $QUSER1 chattr +i $TESTDIR/writable | ||
log_mustnot user_run $QUSER1 chattr +a $TESTDIR/writable | ||
log_mustnot user_run $QUSER1 chattr -i $TESTDIR/immutable | ||
log_mustnot user_run $QUSER1 chattr -a $TESTDIR/append | ||
|
||
log_pass "Unprivileged user cannot chattr as expected" |
Oops, something went wrong.