]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
selftests: add listmount() iteration tests
authorChristian Brauner <brauner@kernel.org>
Sun, 15 Dec 2024 20:17:07 +0000 (21:17 +0100)
committerChristian Brauner <brauner@kernel.org>
Thu, 9 Jan 2025 15:58:54 +0000 (16:58 +0100)
Add a forward and backward iteration test for listmount().

Link: https://lore.kernel.org/r/20241215-vfs-6-14-mount-work-v1-3-fd55922c4af8@kernel.org
Signed-off-by: Christian Brauner <brauner@kernel.org>
tools/testing/selftests/filesystems/statmount/Makefile
tools/testing/selftests/filesystems/statmount/listmount_test.c [new file with mode: 0644]

index 3af3136e35a4bc3671c292ab6abe41832a2be85d..14ee91a416509c7c4070fc3115c66bcfd9166011 100644 (file)
@@ -1,6 +1,6 @@
 # SPDX-License-Identifier: GPL-2.0-or-later
 
 CFLAGS += -Wall -O2 -g $(KHDR_INCLUDES)
-TEST_GEN_PROGS := statmount_test statmount_test_ns
+TEST_GEN_PROGS := statmount_test statmount_test_ns listmount_test
 
 include ../../lib.mk
diff --git a/tools/testing/selftests/filesystems/statmount/listmount_test.c b/tools/testing/selftests/filesystems/statmount/listmount_test.c
new file mode 100644 (file)
index 0000000..15f0834
--- /dev/null
@@ -0,0 +1,66 @@
+// SPDX-License-Identifier: GPL-2.0-or-later
+// Copyright (c) 2024 Christian Brauner <brauner@kernel.org>
+
+#define _GNU_SOURCE
+#include <fcntl.h>
+#include <sched.h>
+#include <stdio.h>
+#include <string.h>
+#include <sys/stat.h>
+#include <sys/mount.h>
+#include <unistd.h>
+
+#include "statmount.h"
+#include "../../kselftest_harness.h"
+
+#ifndef LISTMOUNT_REVERSE
+#define LISTMOUNT_REVERSE    (1 << 0) /* List later mounts first */
+#endif
+
+#define LISTMNT_BUFFER 10
+
+/* Check that all mount ids are in increasing order. */
+TEST(listmount_forward)
+{
+       uint64_t list[LISTMNT_BUFFER], last_mnt_id = 0;
+
+       for (;;) {
+               ssize_t nr_mounts;
+
+               nr_mounts = listmount(LSMT_ROOT, 0, last_mnt_id,
+                                     list, LISTMNT_BUFFER, 0);
+               ASSERT_GE(nr_mounts, 0);
+               if (nr_mounts == 0)
+                       break;
+
+               for (size_t cur = 0; cur < nr_mounts; cur++) {
+                       if (cur < nr_mounts - 1)
+                               ASSERT_LT(list[cur], list[cur + 1]);
+                       last_mnt_id = list[cur];
+               }
+       }
+}
+
+/* Check that all mount ids are in decreasing order. */
+TEST(listmount_backward)
+{
+       uint64_t list[LISTMNT_BUFFER], last_mnt_id = 0;
+
+       for (;;) {
+               ssize_t nr_mounts;
+
+               nr_mounts = listmount(LSMT_ROOT, 0, last_mnt_id,
+                                     list, LISTMNT_BUFFER, LISTMOUNT_REVERSE);
+               ASSERT_GE(nr_mounts, 0);
+               if (nr_mounts == 0)
+                       break;
+
+               for (size_t cur = 0; cur < nr_mounts; cur++) {
+                       if (cur < nr_mounts - 1)
+                               ASSERT_GT(list[cur], list[cur + 1]);
+                       last_mnt_id = list[cur];
+               }
+       }
+}
+
+TEST_HARNESS_MAIN