Skip to content

Passing in extra arguments

0.9.86

Warning

This is an advanced feature, and it can cause your tests to silently stop working if used incorrectly. Use with caution.

In some situations, it can be helpful to pass extra arguments into a test binary at runtime. Nextest supports run-extra-args for this purpose.

Use case: running tests on the main thread

In some environments like macOS, the initial thread created for the process, also known as the main thread or UI thread, is special. Tests in these environments will often require that they always be run on the main thread (see #1959). This is sometimes called "single-threaded mode", but that is a bit of a misnomer. What matters is that the main thread of the test is the same as the main thread of the process.

Even though nextest uses a separate process for each test, that isn't a guarantee that the test will be run on the main thread of the process. In fact, the standard libtest harness and most other harnesses will create a separate thread to run the test in, and use the main thread only to manage the test thread.

As a workaround, some custom test harnesses support passing in arguments to force the test to run on the main thread. For example, with libtest-mimic, passing in --test-threads=1 as an extra argument forces the test to run on the main thread.

For more about custom test harnesses and libtest-mimic, see Custom test harnesses.

You must use a custom test harness

If your goal is to run tests on the main thread of their corresponding processes, --test-threads=1 by itself will not by itself achieve that. The standard libtest harness does not run tests on the main thread with --test-threads=1: see Cargo issue #104053.

You must also use a custom test harness. Our recommendation is libtest-mimic, which follows this behavior with --test-threads=1.

You may also use another custom test harness, though note the compatibility rules. Your harness may use a different argument for this purpose; in that case, replace --test-threads=1 with the appropriate argument in the examples below.

Defining extra arguments

Extra arguments are typically defined via per-test settings.

To run all tests in the gui package's tests/custom-tests.rs target with the --test-threads=1 argument:

Extra arguments in .config/nextest.toml
[[profile.default.overrides]]
filter = "binary_id(gui::custom-tests)"
run-extra-args = ["--test-threads=1"]

The binary_id predicate accepts names shown during cargo nextest run; see Binary IDs for more.

You can also define extra arguments that apply to all tests:

[profile.default]
run-extra-args = ["--test-threads=1"]

If libtest-mimic is in use, the above configuration will run tests on the main thread. (Nextest's CI validates this.)

Nextest provides an advantage compared to cargo test here: with cargo test -- --test-threads=1, tests will run serially. Because nextest runs each test in its own process, setting run-extra-args = ["--test-threads=1"] will cause tests to be run in parallel, with each test executing in the main thread of its process. As a result, test runs with nextest can be many times faster than with cargo test.

Notes

Extra arguments are not passed in at list time, only at runtime. List-time extra arguments may be supported in the future if there's a compelling use case.

Extra arguments are passed directly to the test binary, and nextest does not interpret them in any way. Passing in the wrong arguments can cause your tests to silently stop working.