openafs/tests
Cheyenne Wills 95e67f9c3e tests: rx/perf wait for server init before client
The rx/perf test can occasionally fail due to the rxperf server not
being fully initialized before the client started. This can cause test
errors, even without changes to the rx code.

 C_TAP_VERBOSE=1 make check TESTS="rx/perf"
 ...
 rx/perf

 1..4
 ok 1 - Started rxperf server
 not ok 2 - single threaded client ran successfully
 RPC: threads	30, times	1, write bytes	1048576, read bytes...
 ok 3 - multi threaded client ran succesfully
 ok 4 - Server exited succesfully
 FAILED 2 (exit status 1)

Add a routine that waits for the rx_perf server to become available.
Loop several times trying the connection via the rx_perf client, with
a short delay between retries.  If the connection cannot be established,
fail the test.

Clean up trailing whitespace on a couple of lines.

Note: This failure was observed in an OpenAFS buildbot worker that
included a make tests, and which would occasionally fail when there was
no rx related code changes. The intermittent failure could be duplicated
on a slower virtual test system, but would not fail on a faster system.

Thanks to mmeffie@sinenomine.net for the 'wait_for_server' contribution.

Reviewed-on: https://gerrit.openafs.org/15676
Tested-by: BuildBot <buildbot@rampaginggeek.com>
Reviewed-by: Benjamin Kaduk <kaduk@mit.edu>
Reviewed-by: Andrew Deason <adeason@sinenomine.net>
(cherry picked from commit 6ace773fdc)

Change-Id: I75c6cd1e4e724d4803b62e2f74e5307cb8fcb14d
Reviewed-on: https://gerrit.openafs.org/15736
Reviewed-by: Michael Meffie <mmeffie@sinenomine.net>
Tested-by: BuildBot <buildbot@rampaginggeek.com>
Reviewed-by: Andrew Deason <adeason@sinenomine.net>
Reviewed-by: Benjamin Kaduk <kaduk@mit.edu>
2024-05-19 18:03:48 -04:00
..
auth Move key-related warnings to common server code 2023-03-30 11:23:38 -04:00
bozo tests: Accommodate c-tap-harness 4.7 2022-08-04 11:38:21 -04:00
bucoord tests: Accommodate c-tap-harness 4.7 2022-08-04 11:38:21 -04:00
cmd tests: Accommodate c-tap-harness 4.7 2022-08-04 11:38:21 -04:00
common Move key-related warnings to common server code 2023-03-30 11:23:38 -04:00
kauth tests: Accommodate c-tap-harness 4.7 2022-08-04 11:38:21 -04:00
opr tests: Skip SIGBUS test on FreeBSD 2021-03-19 16:49:38 -04:00
ptserver tests: Accommodate c-tap-harness 4.7 2022-08-04 11:38:21 -04:00
rpctestlib Change AFS*_LINUXnn_ENV to AFS*_LINUX_ENV 2022-08-04 12:41:43 -04:00
rx tests: rx/perf wait for server init before client 2024-05-19 18:03:48 -04:00
tap tests: Start using the upstream C TAP harness 2012-05-11 16:36:44 -07:00
tests-lib/perl5 Let mancheck_utils ignore version subcommands 2014-10-08 10:55:22 -04:00
util tests/util/ktime-t.c: Specify EST offset in TZ 2016-10-10 23:17:26 -04:00
venus tests: Accommodate c-tap-harness 4.7 2022-08-04 11:38:21 -04:00
volser tests: Accommodate c-tap-harness 4.7 2022-08-04 11:38:21 -04:00
.gitignore Import C TAP Harness 1.2 as a testing harness 2010-05-29 21:48:19 -07:00
libwrap tests: use exec to call libwrap'd executables 2016-12-16 16:25:58 -05:00
Makefile.in tests: Accommodate c-tap-harness 4.7 2022-08-04 11:38:21 -04:00
README correct whitespace errors in readme files 2013-01-07 07:40:46 -08:00
TESTS opr: Add new softsig implementation 2015-05-26 14:06:18 -04:00

This directory contains a test harness and the beginnings of what is
intended to become the primary OpenAFS test suite.  The tests in this
directory are run when "make check" is run at the top level of the OpenAFS
tree.

runtests is the test harness, and TESTS is the list of tests that it
will run.  If you add a new test, add it to TESTS as well.  All tests must
be executables (possibly shell scripts or Perl scripts) that end in either
".t" or "-t", but should be listed in TESTS without that suffix.

Tests should be organized into subdirectories, and where it makes sense to
do so, those subdirectories should match the subdirectory names under src
in the AFS source tree.  In other words, tests for src/util/* should go in
a directory named util, tests for the libkopenafs library should go in a
directory named kopenafs, and so forth.  To integrate with the build
system, each subdirectory will need to have its own Makefile.in and be
added to the list of generated Makefiles in configure.in at the top
level.   The Makefile.in in this directory will also need to be modified
to recurse into any new directories.  See util/Makefile.in for an example
of how to write a Makefile.in for a new test directory.

The files comprising the test harness are sourced from the C TAP Harness
distribution using the src/external mechanism. The upstream site for that
distribution is at:

    http://www.eyrie.org/~eagle/software/c-tap-harness/

but feel free to propose modifications directly through OpenAFS Gerrit.
Russ Allbery will take care of merging modifications upstream.  However,
OpenAFS-specific modifications should not be made to those files.  To add
additional OpenAFS-specific code to the TAP library, add additional *.c
and *.h (or *.sh) files to the tests/tap directory rather than modifying files
in src/external.

More information can be found in the HOWTO contained in
src/external/c-tap-harness/HOWTO