[LTP] [RFC][PATCH v2 9/9] nfs: Use TST_ALL_FILESYSTEMS=1

Li Wang liwang@redhat.com
Thu Jun 16 08:11:16 CEST 2022


On Fri, Jun 10, 2022 at 5:44 AM Petr Vorel <pvorel@suse.cz> wrote:

> Signed-off-by: Petr Vorel <pvorel@suse.cz>
> ---
> Hi NFS developers,
>
> your comments are welcome. This is an effort how to support NFS tests on
> all filesystems available on SUT. Using $TST_MNTPOINT means test run in
> loop, each time different filesystem is used. It's implemented via
> formatted loop device (the same way as in LTP C API).
>
> Code is also at:
> https://github.com/pevik/ltp/tree/shell/all_filesystems.v2
>
> But this requires restarting NFS server (otherwise legacy
> testcases/lib/daemonlib.sh
> would have to be used), which is IMHO not optimal.
>
> Without that (or only run 'systemctl reload nfs-server' or exportfs -r
> on remote side) it cannot be umounted after testing - debugging with
> fuser, code at:
>
> https://github.com/pevik/ltp/commit/3656d035d43445a107154ef397ef1db2fad2c4f0
>
> The problem is that loop device is still referenced by nfs server and
> thus cannot be unmounted. Can this be somehow fixed? Is it even wanted
> to have tests on loop device (the only reasonable way to support more
> filesystems)? Also tests will run much longer (we could filter out some
> filesystems not supported, if there are any).
>
> # LTP_SINGLE_FS_TYPE=ext2 PATH="/opt/ltp/testcases/bin:$PATH" nfs07.sh -v
> 3 -t tcp -i3
> ## NOTE: testing itself is OK
> nfs07 1 TINFO: initialize 'lhost' 'ltp_ns_veth2' interface
> nfs07 1 TINFO: add local addr 10.0.0.2/24
> nfs07 1 TINFO: add local addr fd00:1:1:1::2/64
> nfs07 1 TINFO: initialize 'rhost' 'ltp_ns_veth1' interface
> nfs07 1 TINFO: add remote addr 10.0.0.1/24
> nfs07 1 TINFO: add remote addr fd00:1:1:1::1/64
> nfs07 1 TINFO: Network config (local -- remote):
> nfs07 1 TINFO: ltp_ns_veth2 -- ltp_ns_veth1
> nfs07 1 TINFO: 10.0.0.2/24 -- 10.0.0.1/24
> nfs07 1 TINFO: fd00:1:1:1::2/64 -- fd00:1:1:1::1/64
> tst_device.c:89: TINFO: Found free device 0 '/dev/loop0'
> tst_supported_fs_types.c:148: TINFO: WARNING: testing only ext2
> tst_supported_fs_types.c:89: TINFO: Kernel supports ext2
> tst_supported_fs_types.c:51: TINFO: mkfs.ext2 does exist
> nfs07 1 TINFO: Testing on ext2
> nfs07 1 TINFO: Formatting ext2 with opts='/dev/loop0'
> nfs07 1 TINFO: timeout per run is 0h 5m 0s
> nfs07 1 TINFO: mount.nfs: (linux nfs-utils 2.6.1)
> nfs07 1 TINFO: setup NFSv3, socket type tcp
> nfs07 1 TINFO: Mounting NFS: mount -v -t nfs -o proto=tcp,vers=3 10.0.0.2:/tmp/LTP_nfs07.A3PIB82iUv/mntpoint/3/tcp
> /tmp/LTP_nfs07.A3PIB82iUv/mntpoint/3/0
> nfs07 1 TPASS: All files and directories were correctly listed
> nfs07 2 TPASS: All files and directories were correctly listed
> nfs07 3 TPASS: All files and directories were correctly listed
> nfs07 4 TINFO: Cleaning up testcase
>
> ## DEBUGGING CODE in nfs_cleanup()
> nfs07 4 TINFO: fuser -mv /tmp/LTP_nfs07.P1XS9smc5w ($TST_TMPDIR)
>                      USER        PID ACCESS COMMAND
> /tmp/LTP_nfs07.P1XS9smc5w:
>                      root     kernel mount /tmp
>                      root       2125 ..c.. tst_timeout_kil
> nfs07 4 TINFO: fuser -mv /tmp/LTP_nfs07.P1XS9smc5w/mntpoint ($TST_MNTPOINT)
>                      USER        PID ACCESS COMMAND
> /tmp/LTP_nfs07.P1XS9smc5w/mntpoint:
>                      root     kernel mount
> /tmp/LTP_nfs07.P1XS9smc5w/mntpoint
> nfs07 4 TINFO: fuser -mv /tmp/LTP_nfs07.P1XS9smc5w/mntpoint/3/0
>                      USER        PID ACCESS COMMAND
> /tmp/LTP_nfs07.P1XS9smc5w/mntpoint/3/0:
>                      root     kernel mount
> /tmp/LTP_nfs07.P1XS9smc5w/mntpoint/3/0
>
> ## from nfs_cleanup()
> ## grep -q "$local_dir" /proc/mounts && umount $local_dir
> nfs07 4 TINFO: umount /tmp/LTP_nfs07.P1XS9smc5w/mntpoint/3/0
> umount: /tmp/LTP_nfs07.P1XS9smc5w/mntpoint: target is busy.
>

Maybe try with `umount -fl`?

unmount manual says:
   -f, --force    force unmount (in case of an unreachable NFS system)
   -l, --lazy      detach the filesystem now, clean up things later

-- 
Regards,
Li Wang
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.linux.it/pipermail/ltp/attachments/20220616/4bdde30d/attachment-0001.htm>


More information about the ltp mailing list