[LTP] [PATCH v2 1/2] lib: tst_test: Add per filesystem mkfs and mount opts

Li Wang liwang@redhat.com
Fri Mar 21 04:00:44 CET 2025


On Fri, Mar 21, 2025 at 1:31 AM Petr Vorel <pvorel@suse.cz> wrote:

> Hi Cyril, all,
>
> > This commit does:
>
> > * Group the filesystem type, mkfs and mount options into a separate
> >   structure
>
> > * Add an array of these structures to be able to define per filesystem
> >   mkfs and mount options
>
> > The details on the usage should be hopefully clear from the
> > documentation comments for the struct tst_test.
>
> FYI, this merged as cce6188916 ("lib: tst_test: Add per filesystem mkfs and
> mount opts") causes this behavior of none testing run when there is no
> suitable
> filesystem. I found it when trying to bisect something with rapido-linux
> and
> compile kernel without Btrfs and XFS. Don't we want to add some TCONF?
>

I think we need TCONF there. Can you confirm below change makes sense?

--- a/lib/tst_test.c
+++ b/lib/tst_test.c
@@ -1856,6 +1856,7 @@ static int run_tcases_per_fs(void)
        int ret = 0;
        unsigned int i;
        const char *const *filesystems =
tst_get_supported_fs_types(tst_test->skip_filesystems);
+       bool found_valid_fs = false;

        if (!filesystems[0])
                tst_brk(TCONF, "There are no supported filesystems");
@@ -1866,6 +1867,7 @@ static int run_tcases_per_fs(void)
                if (!fs)
                        continue;

+               found_valid_fs = true;
                ret = run_tcase_on_fs(fs, filesystems[i]);

                if (ret == TCONF)
@@ -1877,6 +1879,9 @@ static int run_tcases_per_fs(void)
                do_exit(ret);
        }

+       if (!found_valid_fs)
+               tst_brk(TCONF, "No required filesystems are available");
+
        return ret;
 }



>
> Kind regards,
> Petr
>
> ioctl_ficlone03.c:
>         .filesystems = (struct tst_fs []) {
>                 {.type = "btrfs"},
>                 {.type = "bcachefs"},
>                 {
>                         .type = "xfs",
>                         .min_kver = "4.16",
>                         .mkfs_ver = "mkfs.xfs >= 1.5.0",
>                         .mkfs_opts = (const char *const []) {"-m",
> "reflink=1", NULL},
>                 },
>                 {}
>         },
>
> rapido1:/opt/ltp/testcases/bin# ./ioctl_ficlone03; echo $?
> tst_buffers.c:57: TINFO: Test is using guarded buffers
> tst_tmpdir.c:317: TINFO: Using /tmp/LTP_iocSKLS9l as tmpdir (tmpfs
> filesystem)
> tst_device.c:99: TINFO: Found free device 0 '/dev/loop0'
> tst_test.c:1900: TINFO: LTP version: 20250130-166-g17960d952
> tst_test.c:1904: TINFO: Tested kernel: 4.5.0-00002-g22bd332f11d4 #162 SMP
> Thu Mar 20 18:00:10 CET 2025 x86_64
> tst_kconfig.c:88: TINFO: Parsing kernel config '/.config'
> tst_test.c:1724: TINFO: Overall timeout per run is 0h 00m 31s
> tst_supported_fs_types.c:97: TINFO: Kernel supports ext2
> tst_supported_fs_types.c:62: TINFO: mkfs.ext2 does exist
> tst_supported_fs_types.c:97: TINFO: Kernel supports ext3
> tst_supported_fs_types.c:62: TINFO: mkfs.ext3 does exist
> tst_supported_fs_types.c:97: TINFO: Kernel supports ext4
> tst_supported_fs_types.c:62: TINFO: mkfs.ext4 does exist
> tst_supported_fs_types.c:105: TINFO: Skipping bcachefs because of FUSE
> blacklist
> tst_supported_fs_types.c:97: TINFO: Kernel supports vfat
> tst_supported_fs_types.c:62: TINFO: mkfs.vfat does exist
> tst_supported_fs_types.c:97: TINFO: Kernel supports tmpfs
> tst_supported_fs_types.c:49: TINFO: mkfs is not needed for tmpfs
>
> Summary:
> passed   0
> failed   0
> broken   0
> skipped  0
> warnings 0
> 0
>
> rapido1:/opt/ltp/testcases/bin# grep -e CONFIG_BTRFS_FS -e CONFIG_XFS_FS
> /.config
> + grep -e CONFIG_BTRFS_FS -e CONFIG_XFS_FS /.config
> # CONFIG_XFS_FS is not set
> # CONFIG_BTRFS_FS is not set
>
>

-- 
Regards,
Li Wang


More information about the ltp mailing list