Currently src/t_truncate_cmtime only tests the truncate down case,
truncate up case should be tested too. A recent ext4 bug shows that we
missed that coverage.
See kernel commit 911af577de4e ("ext4: update c/mtime on truncate up")
Signed-off-by: Eryu Guan <[email protected]>
---
src/t_truncate_cmtime.c | 43 ++++++++++++++++++++++++++++++++++++++-----
1 file changed, 38 insertions(+), 5 deletions(-)
diff --git a/src/t_truncate_cmtime.c b/src/t_truncate_cmtime.c
index b08ca44..4b28c2b 100644
--- a/src/t_truncate_cmtime.c
+++ b/src/t_truncate_cmtime.c
@@ -53,17 +53,18 @@ int do_test(const char *file, int is_ftrunc)
exit(EXIT_FAILURE);
}
+ /* Test [f]truncate(2) down */
sleep(1);
if (is_ftrunc) {
ret = ftruncate(fd, 0);
if (ret == -1) {
- perror("ftruncate(2) failed");
+ perror("ftruncate(2) down failed");
exit(EXIT_FAILURE);
}
} else {
ret = truncate(file, 0);
if (ret == -1) {
- perror("truncate(2) failed");
+ perror("truncate(2) down failed");
exit(EXIT_FAILURE);
}
}
@@ -75,15 +76,47 @@ int do_test(const char *file, int is_ftrunc)
exit(EXIT_FAILURE);
}
- /* Check whether timestamps got updated */
+ /* Check whether timestamps got updated on [f]truncate(2) down */
if (statbuf1.st_ctime == statbuf2.st_ctime) {
fprintf(stderr, "ctime not updated after %s\n",
- is_ftrunc ? "ftruncate" : "truncate");
+ is_ftrunc ? "ftruncate" : "truncate" " down");
ret++;
}
if (statbuf1.st_mtime == statbuf2.st_mtime) {
fprintf(stderr, "mtime not updated after %s\n",
- is_ftrunc ? "ftruncate" : "truncate");
+ is_ftrunc ? "ftruncate" : "truncate" " down");
+ ret++;
+ }
+
+ /* Test [f]truncate(2) up */
+ sleep(1);
+ if (is_ftrunc) {
+ ret = ftruncate(fd, 123);
+ if (ret == -1) {
+ perror("ftruncate(2) up failed");
+ exit(EXIT_FAILURE);
+ }
+ } else {
+ ret = truncate(file, 123);
+ if (ret == -1) {
+ perror("truncate(2) up failed");
+ exit(EXIT_FAILURE);
+ }
+ }
+ ret = fstat(fd, &statbuf1);
+ if (ret == -1) {
+ perror("fstat(2) failed");
+ exit(EXIT_FAILURE);
+ }
+ /* Check whether timestamps got updated on [f]truncate(2) up */
+ if (statbuf1.st_ctime == statbuf2.st_ctime) {
+ fprintf(stderr, "ctime not updated after %s\n",
+ is_ftrunc ? "ftruncate" : "truncate" " up");
+ ret++;
+ }
+ if (statbuf1.st_mtime == statbuf2.st_mtime) {
+ fprintf(stderr, "mtime not updated after %s\n",
+ is_ftrunc ? "ftruncate" : "truncate" " up");
ret++;
}
--
2.4.3
--
To unsubscribe from this list: send the line "unsubscribe fstests" in
the body of a message to [email protected]
More majordomo info at http://vger.kernel.org/majordomo-info.html