[LTP] [PATCH 1/1] nfs/nfs08.sh: Add test for NFS cache invalidation

Petr Vorel pvorel@suse.cz
Wed Apr 12 10:21:15 CEST 2023


v4 [1] of not yet upstreamed patch accidentally broke cache invalidation
for directories by clearing NFS_INO_INVALID_DATA inappropriately.
Although it was fixed in v5 [2] thus kernel was not actually broken,
it's better to prevent this in the future.

[1] https://lore.kernel.org/linux-nfs/167649314509.15170.15885497881041431304@noble.neil.brown.name/
[2] https://lore.kernel.org/linux-nfs/167943762461.8008.3152357340238024342@noble.neil.brown.name/

Signed-off-by: Petr Vorel <pvorel@suse.cz>
---
NOTE: although Neil suggested to test on ext2 to make the problems more
obvious (ext2 has low-resolution time stamps) and to use sleep, with
nfs_lib.sh LTP code it works without sleep and on all filesystems.

It'd require more changes in nfs_lib.sh to force ext2 only for nfs08.sh
(other tests are using the library). Not only it's needed, but I also
plan to switch nfs_lib.sh to use all available filesystems via
TST_ALL_FILESYSTEMS=1, therefore ext2 will be among tested filesystems
anyway.

Test fails also on all available NFS versions, thus using the same
approach as the other tests - test all versions, although not sure if
it's really needed. But test runs very quickly (unlike other nfs tests
it's not a stress test), thus I'd keep it.

NOTE: anybody trying to test this patch with TMPDIR (to test different
filesystems) test with this fix [1].

Kind regards,
Petr

[1] https://lore.kernel.org/ltp/20230412073953.1983857-1-pvorel@suse.cz/

 runtest/net.nfs                           | 11 +++++++++++
 testcases/network/nfs/nfs_stress/Makefile |  9 +--------
 testcases/network/nfs/nfs_stress/nfs08.sh | 20 ++++++++++++++++++++
 3 files changed, 32 insertions(+), 8 deletions(-)
 create mode 100755 testcases/network/nfs/nfs_stress/nfs08.sh

diff --git a/runtest/net.nfs b/runtest/net.nfs
index 3249c35cb..72cf4b307 100644
--- a/runtest/net.nfs
+++ b/runtest/net.nfs
@@ -72,6 +72,17 @@ nfs4_ipv6_07 nfs07.sh -6 -v 4 -t tcp
 nfs41_ipv6_07 nfs07.sh -6 -v 4.1 -t tcp
 nfs42_ipv6_07 nfs07.sh -6 -v 4.2 -t tcp
 
+nfs3_08 nfs08.sh -v 3 -t udp
+nfs3t_08 nfs08.sh -v 3 -t tcp
+nfs4_08 nfs08.sh -v 4 -t tcp
+nfs41_08 nfs08.sh -v 4.1 -t tcp
+nfs42_08 nfs08.sh -v 4.2 -t tcp
+nfs3_ipv6_08 nfs08.sh -6 -v 3 -t udp
+nfs3t_ipv6_08 nfs08.sh -6 -v 3 -t tcp
+nfs4_ipv6_08 nfs08.sh -6 -v 4 -t tcp
+nfs41_ipv6_08 nfs08.sh -6 -v 4.1 -t tcp
+nfs42_ipv6_08 nfs08.sh -6 -v 4.2 -t tcp
+
 nfslock3_01 nfslock01.sh -v 3 -t udp
 nfslock3t_01 nfslock01.sh -v 3 -t tcp
 nfslock4_01 nfslock01.sh -v 4 -t tcp
diff --git a/testcases/network/nfs/nfs_stress/Makefile b/testcases/network/nfs/nfs_stress/Makefile
index 8cd095867..5b396dede 100644
--- a/testcases/network/nfs/nfs_stress/Makefile
+++ b/testcases/network/nfs/nfs_stress/Makefile
@@ -9,13 +9,6 @@ include $(top_srcdir)/include/mk/testcases.mk
 nfs04_create_file: CPPFLAGS += -D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE
 nfs05_make_tree: LDLIBS += -lpthread
 
-INSTALL_TARGETS		:= nfs_lib.sh \
-			   nfs01.sh \
-			   nfs02.sh \
-			   nfs03.sh \
-			   nfs04.sh \
-			   nfs05.sh \
-			   nfs06.sh \
-			   nfs07.sh
+INSTALL_TARGETS	:= *.sh
 
 include $(top_srcdir)/include/mk/generic_leaf_target.mk
diff --git a/testcases/network/nfs/nfs_stress/nfs08.sh b/testcases/network/nfs/nfs_stress/nfs08.sh
new file mode 100755
index 000000000..8a0f40242
--- /dev/null
+++ b/testcases/network/nfs/nfs_stress/nfs08.sh
@@ -0,0 +1,20 @@
+#!/bin/sh
+# SPDX-License-Identifier: GPL-2.0-or-later
+# Copyright (c) 2023 Petr Vorel <pvorel@suse.cz>
+# Test reproducer for broken NFS cache invalidation for directories.
+# Based on reproducer from Neil Brown <neilb@suse.de>
+
+TST_TESTFUNC="do_test"
+
+do_test()
+{
+	tst_res TINFO "testing NFS cache invalidation for directories"
+
+	touch 1
+	EXPECT_PASS 'ls | grep 1'
+	touch 2
+	EXPECT_PASS 'ls | grep 2'
+}
+
+. nfs_lib.sh
+tst_run
-- 
2.40.0



More information about the ltp mailing list