This Month in Our Test Infra: November 2024
This is a quick summary of the changes in the test infrastructure for the rust-lang/rust repository1 for November 2024. It also includes brief descriptions of on-going work.
As usual, if you encounter bugs or UX issues when using our test infrastructure, please file an issue. Bugs and papercuts can't be fixed if we don't know about them!
Thanks to everyone who contributed to our test infra!
Highlights
proc-macro
auxiliary build directive
compiletest: Add @ehuss added a //@ proc-macro
directive that
behaves like //@ aux-build
, but it packages the usual //@ force-host
and
//@ no-prefer-dynamic
boilerplate that previously was needed by proc-macro
auxiliaries. If the main test file also uses a sufficiently new edition (i.e.
Edition 2018 onwards), the proc-macro auxiliary is also made available via
extern prelude.
Before: test writer need to write //@ force-host
and //@ no-prefer-dynamic
for each and every proc-macro auxiliary.
// tests/ui/foo/my-main-test.rs
//@ aux-build: my-proc-macro.rs
// tests/ui/foo/auxiliary/my-proc-macro.rs
//@ no-prefer-dynamic
//@ force-host
After: only //@ proc-macro
directive is needed in main test file.
// tests/ui/foo/my-main-test.rs
//@ proc-macro: my-proc-macro.rs
// tests/ui/foo/auxiliary/my-proc-macro.rs
Thanks Eric!
rustc
consider itself a stable compiler when RUSTC_BOOTSTRAP=-1
is set
rustc: make In #132993, I modified
rustc
's stability checking logic to also now recognize RUSTC_BOOTSTRAP=-1
to
force any rustc
to consider itself a stable compiler, regardless of which
channel it is from (e.g. beta or dev or nightly or stable)2. This is
useful for e.g. diagnostics that differ between nightly and stable, and also
provides a way to make the rustc
under test behave as if it was a stable
compiler.
In tests, the //@ rustc-env
directive may be used with
RUSTC_BOOTSTRAP=-1
3.
//@ rustc-env:RUSTC_BOOTSTRAP=-1
//@ compile-flags: -Z unstable-options
//@ regex-error-pattern: error: the option `Z` is only accepted on the nightly compiler
// This will fail because the `rustc` under test rejects the `-Z unstable-options` unstable flag.
PR listing
Improvements
- compiletest:
- rustc:
Cleanups
Documentation updates
- rustc-dev-guide:
- Update
//@ proc-macro
aux build directive docs #2149 - Remove
pretty-expanded
as it no longer exists #2147 - Add instructions to test error code docs #2145
- Document how to acquire cdb.exe #2137
- Mention
RUSTC_BOOTSTRAP
for misc testing #2136 - Document
exact-llvm-major-version
directive #2135 - Document
max-llvm-major-version
directive #2129 - Rename
{ignore,only}-debug
->{ignore,needs}-{rustc,std}-debug-assertions
#2101
- Update
On-going efforts
Note: there are certainly many more spontaneous efforts, this is more what I know is "planned".
-
The test infra here refers to the test harness compiletest and supporting components in our build system bootstrap. This test infra is used mainly by rustc and rustdoc. Other tools like cargo, miri or rustfmt maintain their own test infra. ↩
-
This is only for internal testing usages. Anything else that relies on this that breaks will be considered PEBKAC. ↩
-
The
//@ rustc-env
directive handling has a bug where it's white-space sensitive between the colon and the value, so avoid whitespace for now. ↩