From: Andreas Gruenbacher <andreas.gruenbacher@gmail.com>
To: fstests@vger.kernel.org
Cc: Christoph Hellwig <hch@lst.de>
Subject: [PATCH] generic/126: Test the permission to set file times
Date: Tue, 12 May 2015 20:37:11 +0200 [thread overview]
Message-ID: <1431455831-13345-1-git-send-email-andreas.gruenbacher@gmail.com> (raw)
Check if setting the file access and modification times to the current time
and to a specific timestamp is allowed when expected.
Signed-off-by: Andreas Gruenbacher <andreas.gruenbacher@gmail.com>
---
src/fs_perms.c | 14 +++++++++++++-
tests/generic/126 | 22 ++++++++++++++++++++++
tests/generic/126.out | 6 ++++++
3 files changed, 41 insertions(+), 1 deletion(-)
diff --git a/src/fs_perms.c b/src/fs_perms.c
index ea188c4..519db5b 100644
--- a/src/fs_perms.c
+++ b/src/fs_perms.c
@@ -37,6 +37,8 @@
#include <stdlib.h>
#include <unistd.h>
#include <sys/wait.h>
+#include <time.h>
+#include <utime.h>
int testsetup(mode_t mode, int cuserId, int cgroupId);
int testfperm(int userId, int groupId, char* fperm);
@@ -57,7 +59,7 @@ int main( int argc, char *argv[]) {
exresult = atoi(argv[7]);
break;
default:
- printf("Usage: %s <mode of file> <UID of file> <GID of file> <UID of tester> <GID of tester> <permission to test r|w|x> <expected result as 0|1>\n",argv[0]);
+ printf("Usage: %s <mode of file> <UID of file> <GID of file> <UID of tester> <GID of tester> <permission to test r|w|x|t|T> <expected result as 0|1>\n",argv[0]);
exit(0);
}
@@ -113,6 +115,16 @@ int testfperm(int userId, int groupId, char* fperm) {
seteuid(0);
setegid(0);
return(nuthertmpi);
+ } else if (!strcmp("t", fperm)) {
+ return utime("test.file", NULL) ? 0 : 1;
+ } else if (!strcmp("T", fperm)) {
+ time_t now = time(NULL);
+ struct utimbuf times = {
+ .actime = now - 1,
+ .modtime = now - 1
+ };
+
+ return utime("test.file", ×) ? 0 : 1;
} else {
if((testfile=fopen("test.file",fperm))){
fclose(testfile);
diff --git a/tests/generic/126 b/tests/generic/126
index a22d587..45500af 100755
--- a/tests/generic/126
+++ b/tests/generic/126
@@ -70,5 +70,27 @@ $QA_FS_PERMS 200 99 99 200 99 w 1
$QA_FS_PERMS 040 99 99 99 500 r 1
$QA_FS_PERMS 400 99 99 200 99 r 1
+# Check if setting the file access and modification times to the current time
+# (t) and to a specific timestamp (T) is allowed when expected.
+#
+# From utime(2): Changing timestamps is permitted when: either the process has
+# appropriate privileges, or the effective user ID equals the user ID of the
+# file, or [the process is trying to set the timestamps to the current time]
+# and the process has write permission for the file.
+#
+# Note that the last of these tests will always wrongly succeed over NFSv2.
+# For NFSv3+, that test will wrongly succeed until kernel commit
+# "Disable NFSv2 timestamp workaround for NFSv3+".
+
+# The owner:
+$QA_FS_PERMS 600 99 99 99 99 t 1
+$QA_FS_PERMS 600 99 99 99 99 T 1
+
+# Other processes with and without write permission:
+$QA_FS_PERMS 600 99 99 100 99 t 0
+$QA_FS_PERMS 600 99 99 100 99 T 0
+$QA_FS_PERMS 660 99 99 100 99 t 1
+$QA_FS_PERMS 660 99 99 100 99 T 0
+
status=0
exit
diff --git a/tests/generic/126.out b/tests/generic/126.out
index 3347930..ad0e592 100644
--- a/tests/generic/126.out
+++ b/tests/generic/126.out
@@ -17,3 +17,9 @@ w a 020 file owned by (99/99) as user/group(99/500) FAIL
w a 200 file owned by (99/99) as user/group(200/99) FAIL
r a 040 file owned by (99/99) as user/group(99/500) FAIL
r a 400 file owned by (99/99) as user/group(200/99) FAIL
+t a 600 file owned by (99/99) as user/group(99/99) PASS
+T a 600 file owned by (99/99) as user/group(99/99) PASS
+t a 600 file owned by (99/99) as user/group(100/99) PASS
+T a 600 file owned by (99/99) as user/group(100/99) PASS
+t a 660 file owned by (99/99) as user/group(100/99) PASS
+T a 660 file owned by (99/99) as user/group(100/99) PASS
--
2.4.0
next reply other threads:[~2015-05-12 18:37 UTC|newest]
Thread overview: 8+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-05-12 18:37 Andreas Gruenbacher [this message]
2015-05-12 23:40 ` [PATCH] generic/126: Test the permission to set file times Dave Chinner
2015-05-13 0:07 ` [PATCH] generic/326: " Andreas Gruenbacher
2015-05-14 3:19 ` Dave Chinner
2015-05-14 7:56 ` Andreas Grünbacher
2015-05-14 10:30 ` Dave Chinner
2015-05-14 13:50 ` Andreas Gruenbacher
2015-05-14 13:50 ` [PATCH] generic/087,126: Test the permission to set file times Andreas Gruenbacher
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1431455831-13345-1-git-send-email-andreas.gruenbacher@gmail.com \
--to=andreas.gruenbacher@gmail.com \
--cc=fstests@vger.kernel.org \
--cc=hch@lst.de \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox