Releases: nextest-rs/nextest
nextest-runner 0.71.0
See the changelog for cargo-nextest 0.9.88.
nextest-filtering 0.13.0
Changed
- MSRV updated to Rust 1.81.
- Internal dependency updates.
cargo-nextest 0.9.88
Added
- If nextest's keyboard input handler is enabled, pressing Enter now produces a summary line (e.g.
Running [ 00:00:05] 131/297: 32 running, 131 passed, 1 skipped
). This enables common use cases where Enter is pressed to mark a point in time. - On illumos, Ctrl-T (
SIGINFO
) is now supported as a way to query live status. Querying live status is also supported on BSDs with Ctrl-T, on any Unix viaSIGUSR1
, as well as by pressing thet
key in interactive sessions.
Changed
- If nextest is unable to parse
--target
(and in particular, a custom target), it now fails rather than printing a warning and assuming the host platform. This is being treated as a bugfix because the previous behavior was incorrect.
Fixed
- Custom targets now respect
target_family
predicates likecfg(unix)
. - Nextest now exits cleanly if the progress bar is enabled and writing to standard error fails. This matches the behavior in case the progress bar is disabled.
- If nextest is compiled with a system libzstd that doesn't have multithreading support, archive support no longer fails. Thanks Leandros for your first contribution!
nextest-runner 0.70.0
See the changelog for cargo-nextest 0.9.87.
cargo-nextest 0.9.87
Changed
- On Windows, if a Ctrl-C is received and running tests don't terminate within the
grace period (default 10 seconds), they're now forcibly terminated via a job
object. Previously, nextest would wait indefinitely for tests to exit, unlike
the behavior on Unix platforms where tests are SIGKILLed after the grace period. - The UI has also been updated to make it clearer when tests are forcibly
terminated on Windows.
Fixed
- Fixed a race condition between test cancellation and new tests being started.
Now, once cancellation has begun, no new tests (or retries) will be started.
nextest-runner 0.69.0
See the changelog for cargo-nextest 0.9.86.
cargo-nextest 0.9.86
This is a substantial release with several new features. It's gone through a
period of beta testing, but if you run into issues please file a bug!
Added
Interactive test state querying
Test state can now be queried interactively, via any of the following means:
- Typing in
t
in an interactive terminal. - Pressing
Ctrl-T
, on macOS and other BSD-based platforms where theSIGINFO
signal
is available and recognized by the terminal driver. (SIGINFO
will be supported on
illumos once an upstream Tokio issue is fixed.) - On Unix platforms, sending the nextest process the
SIGUSR1
signal.
This command shows a list of all tests currently running, along with their
status, how long they've been running, and currently-captured standard output
and standard error.
Processing the t
key requires alterations to the terminal, which may lead to
issues in rare circumstances. To disable input key handling, pass in
--no-input-handler
.
--max-fail
runner option
The new --max-fail
option allows you to specify the maximum number of test
failures before nextest stops running tests. This is an extension of the
existing --fail-fast
and --no-fail-fast
options, and is meant to allow users
to strike a balance between running all tests and stopping early.
--fail-fast
is equivalent to--max-fail=1
.--no-fail-fast
is equivalent to--max-fail=all
.
Configuration for --max-fail
will be added in a future release (#1944).
Thanks to AJamesyD for your first contribution!
Extra arguments to the test binary
You can now pass in extra arguments to the test binary at runtime, via the
run-extra-args
configuration option. In combination with a custom test harness
like libtest-mimic
, this can be used to run tests on the main thread of the
process.
For more information, see Passing in extra arguments.
Setup scripts in JUnit output
Setup scripts are now represented in the JUnit output. For more information, see
Setup scripts in JUnit output.
Changed
Tokio task per test
Each test now has a separate Tokio task associated with it. This leads to
greater reliability (each test's task can now panic independently), and is
faster in repos with many small tests.
For example, in one test done against
clap-rs/clap
on Linux, the time reported by
cargo nextest run
goes down from 0.36 seconds to 0.23 seconds.
UI refresh
Several minor improvements to the user interface:
- The progress bar and other UI elements use Unicode characters if available.
- Pressing
Ctrl-C
twice now prints out a "Killing" message. - Some more minor improvements that should lead to a more cohesive user experience.
MSRV update
The MSRV for compiling nextest is now Rust 1.81. (The MSRV for running tests
remains unchanged.)
Fixed
-
Fixed a bug where pressing two Ctrl-Cs in succession would not
SIGKILL
any running tests. -
junit.store-success-output
now works correctly—previously, storage of output is disabled unconditionally. -
In JUnit output, the
testsuite
elements are now listed in the order they are first seen (IndexMap
), rather than in random order (HashMap
). -
When adding extra files to an archive, nextest now ignores empty and
.
path components in the specification while joining the specifiedpath
. This
normalizes paths, meaning that archives won't accidentally get duplicated entries. -
Update
idna
to address RUSTSEC-2024-0421. Since nextest only accesses
domains that do not use punycode, we disable that support entirely. -
Nextest now supports being run in Cargo setups where the
Cargo.toml
that
defines the workspace is not hierarchically above the workspace members. This is
an uncommon setup, but it is supported by Cargo—and now by nextest as well.Thanks to PegasusPlusUS for your first
contribution! -
If an I/O error occurs waiting for a test process to finish, standard output
and standard error are now displayed correctly.
nextest-runner 0.69.0-b.4
See the changelog for cargo-nextest 0.9.86-b.4.
cargo-nextest 0.9.86-b.4
Since beta 3:
Added
- Setup scripts are now represented in the JUnit output. For more information,
see Setup scripts in JUnit output.
Changed
-
Each test now has a separate Tokio task associated with it. This leads to
greater reliability (each test's task can now panic independently), and is
faster in repos with many small tests.For example, in one test done against
clap-rs/clap
on Linux,cargo nextest run
goes down from 0.36 seconds to 0.23 seconds.
Fixed
- Fixed a bug where pressing two Ctrl-Cs in succession would not
SIGKILL
any running tests. junit.store-success-output
now works correctly -- previously, storage of output is disabled unconditionally.- In JUnit output, the
testsuite
elements are now stored in the order they are first seen (IndexMap
), rather than in random order (HashMap
).
nextest-runner 0.69.0-b.3
See the changelog for cargo-nextest 0.9.86-b.3.