Page MenuHomeFreeBSD

fusefs: better test coverage for NFS-exported fuse file systems
Needs ReviewPublic

Authored by asomers on Dec 25 2024, 12:51 AM.
Tags
None
Referenced Files
Unknown Object (File)
Mon, Jan 13, 6:30 AM
Unknown Object (File)
Fri, Jan 3, 1:44 AM
Unknown Object (File)
Wed, Jan 1, 9:30 PM
Unknown Object (File)
Tue, Dec 31, 6:41 PM
Unknown Object (File)
Sat, Dec 28, 12:19 AM
Unknown Object (File)
Dec 27 2024, 10:59 AM
Unknown Object (File)
Dec 27 2024, 9:34 AM
Subscribers

Details

Reviewers
rmacklem
Summary

nfsd is odd. It never calls VOP_OPEN or VOP_CLOSE. That causes it to
traverse code paths within fusefs that no userspace process ever will.
But nfsd is awkward to setup and teardown within ATF tests. So to get
coverage of these code paths, add a "-o simulate_nfs" hidden mount
option. When in effect, it will cause fusefs to ignore VOP_OPEN and
VOP_CLOSE, making all accesses approximately similar to what nfsd does.

Add one initial test case that uses this flag; more will follow.

Sponsored by: ConnectWise

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 61324
Build 58208: arc lint + arc unit

Event Timeline

@rmacklem do you think this does a decent job of approximating the peculiarities of nfsd?

I'm not sure I would have called the nfsd "odd". It is one of two
consumers of the VFS/VOP interface (I suppose you might call
the stacked file systems consumers as well?).

Being one of the two, it is definitely different than the local syscall
interface.

But, anyhow, it is definitely different than the local syscall interface
and not just not using VOP_OPEN/VOP_CLOSE. It uses VOP_LOOKUP,
but in a different way than the local syscalls, particularly w.r.t. name caching,
as another example.

If you find it useful for testing, I don't see a problem with doing it, but
I do have to wonder "If you want to test NFS, then why not just test NFS?".

I'm not sure I would have called the nfsd "odd". It is one of two
consumers of the VFS/VOP interface (I suppose you might call
the stacked file systems consumers as well?).

Being one of the two, it is definitely different than the local syscall
interface.

But, anyhow, it is definitely different than the local syscall interface
and not just not using VOP_OPEN/VOP_CLOSE. It uses VOP_LOOKUP,
but in a different way than the local syscalls, particularly w.r.t. name caching,
as another example.

I've noticed that nfsd will do VOP_LOOKUP calls for ".". Are there any other ways that it differs?

If you find it useful for testing, I don't see a problem with doing it, but
I do have to wonder "If you want to test NFS, then why not just test NFS?".

Because NFS exports are a global resource, which makes them difficult to setup and teardown during an ATF test. The /etc/exports file and the nfsd and rpcbind processes (and perhaps statd and mountd too) all need to have just a single user at a time. And the tests might clash with settings that are already in /etc/rc.conf and /etc/exports. Of course, if you know of a way to fix those problems so I can actually use nfsd in the test suite, that would be awesome.

I'm not sure I would have called the nfsd "odd". It is one of two
consumers of the VFS/VOP interface (I suppose you might call
the stacked file systems consumers as well?).

Being one of the two, it is definitely different than the local syscall
interface.

But, anyhow, it is definitely different than the local syscall interface
and not just not using VOP_OPEN/VOP_CLOSE. It uses VOP_LOOKUP,
but in a different way than the local syscalls, particularly w.r.t. name caching,
as another example.

I've noticed that nfsd will do VOP_LOOKUP calls for ".". Are there any other ways that it differs?

Not w.r.t. what it looks up, but in how it is set up.
Compare nfsvno_namei() with namei() in kern/vfs_lookup.c,
for instance.

Then there is the SMR stuff that the name cache code uses.
I don't understand what it is, but I frequently get panics
from it during development and basically just fiddle
with the code until the panic goes away.
(It assumes stuff set up by a process, which doesn't happen
for the kernel threads nfsd uses.)

If you find it useful for testing, I don't see a problem with doing it, but
I do have to wonder "If you want to test NFS, then why not just test NFS?".

Because NFS exports are a global resource, which makes them difficult to setup and teardown during an ATF test. The /etc/exports file and the nfsd and rpcbind processes (and perhaps statd and mountd too) all need to have just a single user at a time. And the tests might clash with settings that are already in /etc/rc.conf and /etc/exports. Of course, if you know of a way to fix those problems so I can actually use nfsd in the test suite, that would be awesome.

Exports, mountd and nfsd can be done in a vnet jail, if that would help?

Exports, mountd and nfsd can be done in a vnet jail, if that would help?

It certainly would help. Are there any good examples of code that creates a temporary vnet jail with nfs inside?

Exports, mountd and nfsd can be done in a vnet jail, if that would help?

It certainly would help. Are there any good examples of code that creates a temporary vnet jail with nfs inside?

I don't know if this helps:
https://people.freebsd.org/~rmacklem/nfsd-vnet-prison-setup.txt
I've always done it with a bsdinstall image. I don't know if that is temporaray enough?