nfstest_xattr - Man Page

Extended Attributes tests

Synopsis

nfstest_xattr --server <server> [options]

Description

Verify correct functionality of extended attributes

Extended attributes are name:value pairs associated permanently with files and directories, similar to the environment strings associated with a process. An attribute may be defined or undefined. If it is defined, its value may be empty or non-empty. Extended attributes are extensions to the normal attributes which are associated with all inodes in the system. They are often used to provide additional functionality to a filesystem.

Tests are divided into five groups: getxattr, setxattr, removexattr, listxattr and cinfo. The getxattr tests verify the retrieval of extended attribute values. The setxattr tests verify the creation or modification of extended attributes. The removexattr tests verify the removal of extended attributes. The listxattr tests verify the listing of extended attributes. And finally, the cinfo tests verify the change info returned by the server is correct when the file is either modified or not from a different client.

Furthermore, when a different client is holding a read delegation, verify the delegation is recalled only when creating, modifying or removing an extended attribute. On the other hand, verify the read delegation is not recalled when listing attributes or retrieving their values.

Negative testing is included like retrieval or removal of an extended attribute name which does not exist. Creating an attribute which already exists should fail while using XATTR_CREATE flag. Trying to modify an attribute which does not exist should fail if using XATTR_REPLACE flag.

Options

--version

show program's version number and exit

-h, ā€‰--help

show this help message and exit

-f FILE, --file=FILE

File where options are specified besides the system wide file /etc/nfstest, user wide file $HOME/.nfstest or in the current directory .nfstest file

NFS specific options

-s SERVER, --server=SERVER

Server name or IP address

-e EXPORT, --export=EXPORT

Exported file system to mount [default: '/']

--nfsversion=NFSVERSION

NFS version, e.g., 3, 4, 4.1, etc. [default: 4.2]

-m MTPOINT, --mtpoint=MTPOINT

Mount point [default: '/mnt/t']

-p PORT, --port=PORT

NFS server port [default: 2049]

--proto=PROTO

NFS protocol name [default: 'tcp']

--sec=SEC

Security flavor [default: 'sys']

--nconnect=NCONNECT

Multiple TCP connections option [default: '1']

-o MTOPTS, --mtopts=MTOPTS

Mount options [default: 'hard,rsize=4096,wsize=4096']

--datadir=DATADIR

Data directory where files are created, directory is created on the mount point [default: '']

Logging options

-v VERBOSE, --verbose=VERBOSE

Verbose level for debug messages [default: 'opts|info|dbg1|dbg2|dbg3']

--tverbose=TVERBOSE

Verbose level for test messages [default: '1']

--createlog

Create log file

--rexeclog

Create rexec log files

--warnings

Display warnings

--tag=TAG

Informational tag, it is displayed as an INFO message [default: '']

--notty

Do not use terminal colors on output

--isatty

Use terminal colors on output -- useful when running with nohup

Packet trace options

--createtraces

Create a packet trace for each test

--tbsize=TBSIZE

Capture buffer size for tcpdump [default: 192k]

--trcdelay=TRCDELAY

Seconds to delay before stopping packet trace [default: 2.0]

--keeptraces

Do not remove any trace files [default: remove trace files if no errors]

--rmtraces

Remove trace files [default: remove trace files if no errors]

-i INTERFACE, --interface=INTERFACE

Device interface [default: automatically selected]

File options

--nfiles=NFILES

Number of files to create [default: 2]

--filesize=FILESIZE

File size to use for test files [default: 64k]

--rsize=RSIZE

Read size to use when reading files [default: 4k]

--wsize=WSIZE

Write size to use when writing files [default: 4k]

--iodelay=IODELAY

Seconds to delay I/O operations [default: 0.1]

--offset-delta=OFFSET_DELTA

Read/Write offset delta [default: 4k]

Path options

--sudo=SUDO

Full path of binary for sudo [default: '/usr/bin/sudo']

--kill=KILL

Full path of binary for kill [default: '/usr/bin/kill']

--nfsstat=NFSSTAT

Full path of binary for nfsstat [default: '/usr/sbin/nfsstat']

--tcpdump=TCPDUMP

Full path of binary for tcpdump [default: '/usr/sbin/tcpdump']

--iptables=IPTABLES

Full path of binary for iptables [default: '/usr/sbin/iptables']

--messages=MESSAGES

Full path of log messages file [default: '/var/log/messages']

--trcevents=TRCEVENTS

Full path of tracing events directory [default: '/sys/kernel/debug/tracing/events']

--trcpipe=TRCPIPE

Full path of trace pipe file [default: '/sys/kernel/debug/tracing/trace_pipe']

--tmpdir=TMPDIR

Temporary directory [default: '/tmp']

Debug options

--nocleanup

Do not cleanup created files

--notimestamps

Do not display timestamps in debug messages

--bugmsgs=BUGMSGS

File containing test messages to mark as bugs if they failed

--nomount

Do not mount server and run the tests on local disk space

--basename=BASENAME

Base name for all files and logs [default: automatically generated]

--nfsdebug=NFSDEBUG

Set NFS kernel debug flags and save log messages [default: '']

--rpcdebug=RPCDEBUG

Set RPC kernel debug flags and save log messages [default: '']

--tracepoints=TRACEPOINTS

List of trace points modules to enable [default: '']

--nfsstats

Get NFS stats [default: 'False']

--pktdisp

Display main packets related to the given test

--nfserrors

Fail every NFS error found in the packet trace

--client-ipaddr=CLIENT_IPADDR

IP address of localhost

Reporting options

--xunit-report

Generate xUnit compatible test report

--xunit-report-file=XUNIT_REPORT_FILE

Path to xout report file

Test options

--runtest=RUNTEST

Comma separated list of tests to run, if list starts with a '^' then all tests are run except the ones listed [default: 'all']

--num-xattrs=NUM_XATTRS

Number of extended attributes to create for listxattr tests with many attributes [default: 20]

--client=CLIENT

Remote NFS client and options used for delegation tests. Clients are separated by a ',' and each client definition is a list of arguments separated by a ':' given in the following order if positional arguments is used (see examples): clientname:server:export:nfsversion:port:proto:sec:mtpoint [default: 'nfsversion=3:proto=tcp:port=2049']

--client-nfsvers=CLIENT_NFSVERS

Comma separated list of valid NFS versions to use in the --client option. An NFS version from this list, which is different than that given by --nfsversion, is selected and included in the --client option [default: 4.0,4.1]

Tests

ngetxattr01

Verify getting extended attribute

ngetxattr02

Verify getting extended attribute fails when attribute does not exist

dgetxattr01

Verify getting extended attribute
when delegation is granted on second client

dgetxattr02

Verify getting extended attribute fails when attribute does not exist
when delegation is granted on second client

nsetxattr01

Verify setting extended attribute with SETXATTR4_EITHER when attribute does not exist

nsetxattr02

Verify setting extended attribute with SETXATTR4_CREATE when attribute does not exist

nsetxattr03

Verify setting extended attribute with SETXATTR4_REPLACE fails when attribute does not exist

nsetxattr04

Verify setting extended attribute with SETXATTR4_EITHER when attribute already exists

nsetxattr05

Verify setting extended attribute with SETXATTR4_CREATE fails when attribute already exists

nsetxattr06

Verify setting extended attribute with SETXATTR4_REPLACE when attribute already exists

dsetxattr01

Verify setting extended attribute with SETXATTR4_EITHER when attribute does not exist
when delegation is granted on second client

dsetxattr02

Verify setting extended attribute with SETXATTR4_CREATE when attribute does not exist
when delegation is granted on second client

dsetxattr03

Verify setting extended attribute with SETXATTR4_REPLACE fails when attribute does not exist
when delegation is granted on second client

dsetxattr04

Verify setting extended attribute with SETXATTR4_EITHER when attribute already exists
when delegation is granted on second client

dsetxattr05

Verify setting extended attribute with SETXATTR4_CREATE fails when attribute already exists
when delegation is granted on second client

dsetxattr06

Verify setting extended attribute with SETXATTR4_REPLACE when attribute already exists
when delegation is granted on second client

nremovexattr01

Verify removing extended attribute

nremovexattr02

Verify removing extended attribute fails when attribute does not exist

dremovexattr01

Verify removing extended attribute
when delegation is granted on second client

dremovexattr02

Verify removing extended attribute fails when attribute does not exist
when delegation is granted on second client

nlistxattr01

Verify listing extended attributes with no user namespace attributes

nlistxattr02

Verify listing extended attribute

nlistxattr03

Verify listing extended attribute (many attributes)

dlistxattr01

Verify listing extended attributes with no user namespace attributes
when delegation is granted on second client

dlistxattr02

Verify listing extended attribute
when delegation is granted on second client

dlistxattr03

Verify listing extended attribute (many attributes)
when delegation is granted on second client

ncinfo01

Verify SETXATTR change info with SETXATTR4_EITHER when attribute does not exist

ncinfo02

Verify SETXATTR change info with SETXATTR4_EITHER when attribute already exists

ncinfo03

Verify SETXATTR change info with SETXATTR4_CREATE when attribute does not exist

ncinfo04

Verify SETXATTR change info with SETXATTR4_REPLACE when attribute already exists

mcinfo01

Verify SETXATTR change info with SETXATTR4_EITHER when attribute does not exist
when file is modified on second client

mcinfo02

Verify SETXATTR change info with SETXATTR4_EITHER when attribute already exists
when file is modified on second client

mcinfo03

Verify SETXATTR change info with SETXATTR4_CREATE when attribute does not exist
when file is modified on second client

mcinfo04

Verify SETXATTR change info with SETXATTR4_REPLACE when attribute already exists
when file is modified on second client

getxattr

Run all GETXATTR tests: ngetxattr01, ngetxattr02, dgetxattr01,
dgetxattr02

ngetxattr

Run all GETXATTR tests when no open on second client: ngetxattr01,
ngetxattr02

dgetxattr

Run all GETXATTR tests when delegation is granted on second client:
dgetxattr01, dgetxattr02

setxattr

Run all SETXATTR tests: nsetxattr01, nsetxattr02, nsetxattr03,
nsetxattr04, nsetxattr05, nsetxattr06, dsetxattr01, dsetxattr02,
dsetxattr03, dsetxattr04, dsetxattr05, dsetxattr06

nsetxattr

Run all SETXATTR tests when no open on second client: nsetxattr01,
nsetxattr02, nsetxattr03, nsetxattr04, nsetxattr05, nsetxattr06

dsetxattr

Run all SETXATTR tests when delegation is granted on second client:
dsetxattr01, dsetxattr02, dsetxattr03, dsetxattr04, dsetxattr05,
dsetxattr06

removexattr

Run all REMOVEXATTR tests: nremovexattr01, nremovexattr02,
dremovexattr01, dremovexattr02

nremovexattr

Run all REMOVEXATTR tests when no open on second client: nremovexattr01,
nremovexattr02

dremovexattr

Run all REMOVEXATTR tests when delegation is granted on second client:
dremovexattr01, dremovexattr02

listxattr

Run all LISTXATTRS tests: nlistxattr01, nlistxattr02, nlistxattr03,
dlistxattr01, dlistxattr02, dlistxattr03

nlistxattr

Run all LISTXATTRS tests when no open on second client: nlistxattr01,
nlistxattr02, nlistxattr03

dlistxattr

Run all LISTXATTRS tests when delegation is granted on second client:
dlistxattr01, dlistxattr02, dlistxattr03

cinfo

Run all CINFO tests: ncinfo01, ncinfo02, ncinfo03, ncinfo04, mcinfo01,
mcinfo02, mcinfo03, mcinfo04

ncinfo

Run all CINFO tests when no open on second client: ncinfo01, ncinfo02,
ncinfo03, ncinfo04

mcinfo

Run all CINFO tests when file is modified on second client: mcinfo01,
mcinfo02, mcinfo03, mcinfo04

all

Run all tests: ngetxattr01, ngetxattr02, dgetxattr01, dgetxattr02,
nsetxattr01, nsetxattr02, nsetxattr03, nsetxattr04, nsetxattr05,
nsetxattr06, dsetxattr01, dsetxattr02, dsetxattr03, dsetxattr04,
dsetxattr05, dsetxattr06, nremovexattr01, nremovexattr02,
dremovexattr01, dremovexattr02, nlistxattr01, nlistxattr02,
nlistxattr03, dlistxattr01, dlistxattr02, dlistxattr03, ncinfo01,
ncinfo02, ncinfo03, ncinfo04, mcinfo01, mcinfo02, mcinfo03, mcinfo04

Examples

The only required option is --server
$ nfstest_xattr --server 192.168.0.11

Notes

The user id in the local host and the host specified by --client must have access to run commands as root using the 'sudo' command without the need for a password.

The user id must be able to 'ssh' to remote host without the need for a password.

Valid only for NFS version 4.2 and above.

See Also

baseobj(3), formatstr(3), nfstest.test_util(3), nfstest_alloc(1), nfstest_cache(1), nfstest_delegation(1), nfstest_dio(1), nfstest_fcmp(1), nfstest_file(1), nfstest_interop(1), nfstest_io(1), nfstest_lock(1), nfstest_pkt(1), nfstest_pnfs(1), nfstest_posix(1), nfstest_rdma(1), nfstest_sparse(1), nfstest_ssc(1), nfstest_xid(1), packet.nfs.nfs4_const(3)

Bugs

No known bugs.

Author

Jorge Mora (mora@netapp.com)

Referenced By

nfstest(1), nfstest_alloc(1), nfstest_cache(1), nfstest_delegation(1), nfstest_dio(1), nfstest_fcmp(1), nfstest_file(1), nfstest_interop(1), nfstest_io(1), nfstest_lock(1), nfstest_pkt(1), nfstest_pnfs(1), nfstest_posix(1), nfstest_rdma(1), nfstest_sparse(1), nfstest_ssc(1), nfstest_xid(1).

21 March 2023 NFStest 3.2 nfstest_xattr 1.1