Environment variables¶
This section contains information about the environment variables nextest reads and sets.
Environment variables nextest reads¶
Nextest reads some of its command-line options as environment variables. In all cases, passing in a command-line option overrides the respective environment variable.
NEXTEST_PROFILE
- Nextest profile to use while running tests
NEXTEST_TEST_THREADS
- Number of tests to run simultaneously
NEXTEST_RETRIES
- Number of times to retry running tests
NEXTEST_HIDE_PROGRESS_BAR
- If set to
1
, always hide the progress bar NEXTEST_STATUS_LEVEL
- Status level during test runs (see Status levels)
NEXTEST_FINAL_STATUS_LEVEL
- Status level at the end of a test run (see Status levels)
NEXTEST_SUCCESS_OUTPUT
- Display output for passing tests (see Displaying captured test output)
NEXTEST_FAILURE_OUTPUT
- Display output for failing tests (see Displaying captured test output)
NEXTEST_VERBOSE
- Verbose output
Nextest also reads the following environment variables to emulate Cargo's behavior.
CARGO
- Path to the
cargo
binary to use for builds CARGO_TARGET_DIR
- Where to place generated artifacts
CARGO_TARGET_<triple>_RUNNER
- Support for target runners
CARGO_TERM_COLOR
- Default color mode:
always
,auto
, ornever
Cargo-related environment variables nextest reads¶
Nextest delegates to Cargo for the build, which recognizes a number of environment variables. See Environment variables Cargo reads for a full list.
Environment variables nextest sets¶
Nextest exposes these environment variables to your tests at runtime only. They are not set at build time because cargo-nextest may reuse builds done outside of the nextest environment.
NEXTEST
- Always set to
"1"
. NEXTEST_RUN_ID
- Set to a UUID corresponding to a particular nextest run.
NEXTEST_EXECUTION_MODE
- Currently, always set to
process-per-test
. More options may be added in the future if nextest gains the ability to run all tests within the same process (#27). NEXTEST_BIN_EXE_<name>
- The absolute path to a binary target's executable. This is only set when running an integration test or benchmark. The
<name>
is the name of the binary target, exactly as-is. For example,NEXTEST_BIN_EXE_my-program
for a binary namedmy-program
.Binaries are automatically built when the test is built, unless the binary has required features that are not enabled.
When reusing builds from an archive, this is set to the remapped path within the target directory.
NEXTEST_LD_*
andNEXTEST_DYLD_*
- Replicate the values of any environment variables that start with the prefixes
LD_
orDYLD_
, such asLD_PRELOAD
orDYLD_FALLBACK_LIBRARY_PATH
.This is a workaround for macOS's System Integrity Protection environment sanitization. For more, see Dynamic linker environment variables.
For consistency,
NEXTEST_LD_*
andNEXTEST_DYLD_*
are exported on all platforms, not just macOS.
Cargo-related environment variables nextest sets¶
Nextest delegates to Cargo for the build, which controls the environment variables that are set. See Environment variables Cargo sets for crates for a full list.
Nextest also sets these environment variables at runtime, matching the behavior of cargo test
:
CARGO
- Path to the
cargo
binary performing the build.This is set by Cargo, not nextest, so if you invoke nextest with
cargo-nextest nextest run
it will not be set. CARGO_MANIFEST_DIR
- The directory containing the manifest of the test's package.
If
--workspace-remap
is passed in, this is set to the remapped manifest directory. You can obtain the non-remapped directory using the value of this variable at compile-time, e.g.env!("CARGO_MANIFEST_DIR")
. CARGO_PKG_VERSION
- The full version of the test's package.
CARGO_PKG_VERSION_MAJOR
- The major version of the test's package.
CARGO_PKG_VERSION_MINOR
- The minor version of the test's package.
CARGO_PKG_VERSION_PATCH
- The patch version of the test's package.
CARGO_PKG_VERSION_PRE
- The pre-release version of the test's package.
CARGO_PKG_AUTHORS
- Colon-separated list of authors from the manifest of the test's package.
CARGO_PKG_NAME
- The name of the test's package.
CARGO_PKG_DESCRIPTION
- The description from the manifest of the test's package.
CARGO_PKG_HOMEPAGE
- The home page from the manifest of the test's package.
CARGO_PKG_REPOSITORY
- The repository from the manifest of the test's package.
CARGO_PKG_LICENSE
- The license from the manifest of the test's package.
CARGO_PKG_LICENSE_FILE
- The license file from the manifest of the test's package.
OUT_DIR
- The path to the test's build script output directory.
Only set if the crate has a build script.
Additionally, the following environment variables are also set:
- Variables defined by the
[env]
section of.cargo/config.toml
. - 0.9.82 Variables specified in the build script via
cargo::rustc-env
. However, note thatcargo
discourages using these variables at runtime.
Dynamic library paths¶
Nextest sets the dynamic library path at runtime, similar to what Cargo does. This helps with locating shared libraries that are part of the build process. The variable name depends on the platform:
- Windows:
PATH
- macOS:
DYLD_FALLBACK_LIBRARY_PATH
- Unix:
LD_LIBRARY_PATH
Nextest includes the following paths:
- Search paths included from any build script with the
rustc-link-search
instruction. Paths outside of the target directory are removed. If additional libraries on the system are needed in the search path, consider using a setup script to configure the environment. - The base output directory, such as
target/debug
, and the "deps" directory. This enables support fordylib
dependencies and rustc compiler plugins. - 0.9.72 The rustc sysroot library path, to enable proc-macro tests and binaries compiled with
-C prefer-dynamic
to work.