63 KiB
UI Test Suite Categories
This is a high-level summary of the organization of the UI test suite (tests/ui/
). It is not intended to be prescriptive, but instead provide a quick survey of existing groupings.
For now, only immediate subdirectories under tests/ui/
are described, but these subdirectories can themselves include a SUMMARY.md
to further describe their own organization and intent, should that be helpful.
tests/ui/abi
These tests deal with Application Binary Interfaces (ABI), mostly relating to function name mangling (and the #[no_mangle]
attribute), calling conventions, or compiler flags which affect ABI.
Tests for unsupported ABIs can be made cross-platform by using the extern "rust-invalid"
ABI, which is considered unsupported on every platform.
tests/ui/allocator
These tests exercise #![feature(allocator_api)]
and the #[global_allocator]
attribute.
See Allocator traits and std::heap
#32838.
tests/ui/alloc-error
These tests exercise alloc error handling.
See https://doc.rust-lang.org/std/alloc/fn.handle_alloc_error.html.
tests/ui/annotate-snippet
These tests exercise the annotate-snippets
-based emitter implementation.
annotate-snippets
is an initiative to share the diagnostics emitting infrastructure between rustc and cargo to reduce duplicate maintenance effort and divergence. See https://github.com/rust-lang/rust/issues/59346 about the initiative.
tests/ui/anon-params
These tests deal with anonymous parameters (no name, only type), a deprecated feature that becomes a hard error in Edition 2018.
tests/ui/argfile
: External files providing command line arguments
These tests exercise rustc reading command line arguments from an externally provided argfile (@argsfile
).
See Implement @argsfile
to read arguments from command line #63576.
tests/ui/array-slice-vec
: Arrays, slices and vectors
Exercises various aspects surrounding basic collection types []
, &[]
and Vec
. E.g. type-checking, out-of-bounds indices, attempted instructions which are allowed in other programming languages, and more.
tests/ui/argument-suggestions
: Argument suggestions
Calling a function with the wrong number of arguments causes a compilation failure, but the compiler is able to, in some cases, provide suggestions on how to fix the error, such as which arguments to add or delete. These tests exercise the quality of such diagnostics.
tests/ui/asm
: asm!
macro
These tests exercise the asm!
macro, which is used for adding inline assembly.
See:
This directory contains subdirectories representing various architectures such as riscv
or aarch64
. If a test is specifically related to an architecture's particularities, it should be placed within the appropriate subdirectory.Architecture-agnostic tests should be placed below tests/ui/asm/
directly.
tests/ui/associated-consts
: Associated Constants
These tests exercise associated constants in traits and impls, on aspects such as definitions, usage, and type checking in associated contexts.
tests/ui/associated-inherent-types
: Inherent Associated Types
These tests cover associated types defined directly within inherent impls (not in traits).
See RFC 0195 Associated items - Inherent associated items.
tests/ui/associated-item
: Associated Items
Tests for all kinds of associated items within traits and implementations. This directory serves as a catch-all for tests that don't fit the other more specific associated item directories.
tests/ui/associated-type-bounds
: Associated Type Bounds
These tests exercise associated type bounds, the feature that gives users a shorthand to express nested type bounds that would otherwise need to be expressed with nested impl Trait
or broken into several where
clauses.
See:
tests/ui/associated-types
: Trait Associated Types
Tests focused on associated types. If the associated type is not in a trait definition, it belongs in the tests/ui/associated-inherent-types/
directory. Aspects exercised include e.g. default associated types, overriding defaults, and type inference.
See Associated Types | Reference.
tests/ui/async-await
: Async/Await
Tests for the async/await related features. E.g. async functions, await expressions, and their interaction with other language features.
tests/ui/attributes
: Compiler Attributes
Tests for language attributes and compiler attributes. E.g. built-in attributes like #[derive(..)]
, #[cfg(..)]
, and #[repr(..)]
, or proc-macro attributes. See Attributes | Reference.
tests/ui/auto-traits
: Auto Traits
There are built-in auto traits (Send
, Sync
, etc.) but it is possible to define more with the unstable keyword auto
through #![feature(auto_traits)]
.
tests/ui/autodiff
: Automatic Differentiation
The #[autodiff]
macro supports automatic differentiation.
See Tracking Issue for autodiff #124509.
tests/ui/autoref-autoderef
: Automatic Referencing/Dereferencing
Tests for automatic referencing and dereferencing behavior, such as automatically adding reference operations (&
or &mut
) to make a value match a method's receiver type. Sometimes abbreviated as "auto-ref" or "auto-deref".
tests/ui/auxiliary/
: Auxiliary files for tests directly under tests/ui
.
This top-level auxiliary
subdirectory contains support files for tests immediately under tests/ui/
.
FIXME(#133895): tests immediately under tests/ui/
should be rehomed to more suitable subdirectories, after which this subdirectory can be removed.
tests/ui/backtrace/
: Backtraces
Runtime panics and error handling generate backtraces to assist in debugging and diagnostics.
tests/ui/bench/
: Benchmarks and performance
This directory was originally meant to contain tests related to time complexity and benchmarking.
However, only a single test was ever added to this category: https://github.com/rust-lang/rust/pull/32062
FIXME: It is also unclear what would happen were this test to "fail" - would it cause the test suite to remain stuck on this test for a much greater duration than normal?
tests/ui/binding/
: Pattern Binding
Tests for pattern binding in match expressions, let statements, and other binding contexts. E.g. binding modes and refutability. See Patterns | Reference.
tests/ui/binop/
: Binary operators
Tests for binary operators (such as ==
, &&
or ^
). E.g. overloading, type checking, and diagnostics for invalid operations.
tests/ui/blind/
: struct
or mod
inside a mod
having a duplicate identifier
Tests exercising name resolution.
FIXME: Probably move to tests/ui/resolve/
.
tests/ui/block-result/
: Block results and returning
Tests for block expression results. E.g. specifying the correct return types, semicolon handling, type inference, and expression/statement differences (for example, the difference between 1
and 1;
).
tests/ui/bootstrap/
: RUSTC_BOOTSTRAP environment variable
Meta tests for stability mechanisms surrounding RUSTC_BOOTSTRAP
, which is coordinated between rustc
and the build system, bootstrap
.
tests/ui/borrowck/
: Borrow Checking
Tests for borrow checking. E.g. lifetime analysis, borrowing rules, and diagnostics.
tests/ui/box/
: Box Behavior
Tests for Box<T>
smart pointer and #![feature(box_patterns)]
. E.g. allocation, deref coercion, and edge cases in box pattern matching and placement.
See:
tests/ui/btreemap/
: B-Tree Maps
Tests focused on BTreeMap
collections and their compiler interactions. E.g. collection patterns, iterator behavior, and trait implementations specific to BTreeMap
. See std::collections::BTreeMap
.
tests/ui/builtin-superkinds/
: Built-in Trait Hierarchy Tests
Tests for built-in trait hierarchy (Send, Sync, Sized, etc.) and their supertrait relationships. E.g. auto traits and marker trait constraints.
See RFC 3729: Hierarchy of Sized traits.
Defining custom auto traits with the auto
keyword belongs to tests/ui/auto-traits/
instead.
tests/ui/cast/
: Type Casting
Tests for type casting using the as
operator. Includes tests for valid/invalid casts between primitive types, trait objects, and custom types. For example, check that trying to cast i32
into bool
results in a helpful error message.
See Type cast expressions | Reference.
tests/ui/cfg/
: Configuration Attribute
Tests for #[cfg]
conditional compilation attribute. E.g. feature flags, target architectures, and other configuration predicates and options.
See Conditional compilation | Reference.
tests/ui/check-cfg/
: Configuration Checks
Tests for the --check-cfg
compiler mechanism for checking cfg configurations, for #[cfg(..)]
and cfg!(..)
.
See Checking conditional configurations | The rustc book.
tests/ui/closure_context/
: Closure type inference in context
Tests for closure type inference with respect to surrounding scopes, mostly quality of diagnostics.
tests/ui/closure-expected-type/
: Closure type inference
Tests targeted at how we deduce the types of closure arguments. This process is a result of some heuristics which take into account the expected type we have alongside the actual types that we get from inputs.
FIXME: Appears to have significant overlap with tests/ui/closure_context
and tests/ui/functions-closures/closure-expected-type
. Needs further investigation.
tests/ui/closures/
: General Closure Tests
Any closure-focused tests that does not fit in the other more specific closure subdirectories belong here. E.g. syntax, move
, lifetimes.
tests/ui/cmse-nonsecure/
: cmse-nonsecure
ABIs
Tests for extern "cmse-nonsecure-call"
and extern "cmse-nonsecure-entry"
functions. Used specifically for the Armv8-M architecture, the former marks Secure functions with additional behaviours, such as adding a special symbol and constraining the number of parameters, while the latter alters function pointers to indicate they are non-secure and to handle them differently than usual.
See:
tests/ui/codegen/
: Code Generation
Tests that exercise code generation. E.g. codegen flags (starting with -C
on the command line), LLVM IR output, optimizations (and the various opt-level
s), and target-specific code generation (such as tests specific to x86_64
).
tests/ui/codemap_tests/
: Source Mapping
Tests that exercise source code mapping.
tests/ui/coercion/
: Type Coercion
Tests for implicit type coercion behavior, where the types of some values are changed automatically when compatible depending on the context. E.g. automatic dereferencing or downgrading a &mut
into a &
.
See Type coercions | Reference.
tests/ui/coherence/
: Trait Implementation Coherence
Tests for trait coherence rules, which govern where trait implementations can be defined. E.g. orphan rule, and overlap checks.
See Coherence | rustc-dev-guide.
tests/ui/coinduction/
: Coinductive Trait Resolution
Tests for coinduction in trait solving which may involve infinite proof trees.
See:
This directory only contains one highly specific test. Other coinduction tests can be found down the deeply located tests/ui/traits/next-solver/cycles/coinduction/
subdirectory.
tests/ui/command/
: std::process::Command
This directory is actually for the standard library std::process::Command
type, where some tests are too difficult or inconvenient to write as unit tests or integration tests within the standard library itself.
FIXME: the test command-line-diagnostics
seems to have been misplaced in this category.
tests/ui/compare-method/
: Trait implementation and definition comparisons
Some traits' implementation must be compared with their definition, checking for problems such as the implementation having stricter requirements (such as needing to implement Copy
).
This subdirectory is not intended comparison traits (PartialEq
, Eq
, PartialOrd
, Ord
).
tests/ui/compiletest-self-test/
: compiletest "meta" tests
Meta test suite of the test harness compiletest
itself.
tests/ui/conditional-compilation/
: Conditional Compilation
Tests for #[cfg]
attribute or --cfg
flags, used to compile certain files or code blocks only if certain conditions are met (such as developing on a specific architecture).
FIXME: There is significant overlap with tests/ui/cfg
, which even contains a tests/ui/cfg/conditional-compile.rs
test. Also investigate tests/ui/check-cfg
.
tests/ui/confuse-field-and-method/
: Field/Method Ambiguity
If a developer tries to create a struct
where one of the fields is a closure function, it becomes unclear whether struct.field()
is accessing the field itself or trying to call the closure function within as a method.
FIXME: does this really need to be its own immediate subdirectory?
tests/ui/const-generics/
: Constant Generics
Tests for const generics, allowing types to be parameterized by constant values. It is generally observed in the form <const N: Type>
after the fn
or struct
keywords. Includes tests for const expressions in generic contexts and associated type bounds.
See:
- Tracking Issue for complex generic constants:
feature(generic_const_exprs)
#76560 - Const generics | Reference
tests/ui/const_prop/
: Constant Propagation
Tests exercising ConstProp
mir-opt pass (mostly regression tests). See https://blog.rust-lang.org/inside-rust/2019/12/02/const-prop-on-by-default/.
tests/ui/const-ptr/
: Constant Pointers
Tests exercise const raw pointers. E.g. pointer arithmetic, casting and dereferencing, always with a const
.
See:
tests/ui/consts/
: General Constant Evaluation
Anything to do with constants, which does not fit in the previous two const
categories, goes here. This does not always imply use of the const
keyword - other values considered constant, such as defining an enum variant as enum Foo { Variant = 5 }
also counts.
tests/ui/contracts/
: Contracts feature
Tests exercising #![feature(contracts)]
.
See Tracking Issue for Contracts #128044.
tests/ui/coroutine/
: Coroutines feature and gen
blocks
Tests for #![feature(coroutines)]
and gen
blocks, it belongs here.
See:
tests/ui/coverage-attr/
: #[coverage]
attribute
Tests for #![feature(coverage_attribute)]
. See Tracking issue for function attribute #[coverage]
.
tests/ui/crate-loading/
: Crate Loading
Tests for crate resolution and loading behavior, including extern crate
declarations, --extern
flags, or the use
keyword.
tests/ui/cross/
: Various tests related to the concept of "cross"
FIXME: The unifying topic of these tests appears to be that their filenames begin with the word "cross". The similarities end there - one test is about "cross-borrowing" a Box<T>
into &T
, while another is about a global trait used "across" files. Some of these terminology are really outdated and does not match the current terminology. Additionally, "cross" is also way too generic, it's easy to confuse with cross-compile.
tests/ui/cross-crate/
: Cross-Crate Interaction
Tests for behavior spanning multiple crates, including visibility rules, trait implementations, and type resolution across crate boundaries.
tests/ui/custom_test_frameworks/
Tests for #[bench]
, #[test_case]
attributes and the custom_test_frameworks
lang item.
See Tracking issue for eRFC 2318, Custom test frameworks #50297.
tests/ui/c-variadic/
: C Variadic Function
Tests for FFI with C varargs (va_list
).
tests/ui/cycle-trait/
: Trait Cycle Detection
Tests for detection and handling of cyclic trait dependencies.
tests/ui/dataflow_const_prop/
Contains a single regression test for const prop in SwitchInt
pass crashing when ptr2int
transmute is involved.
FIXME: A category with a single test. Maybe it would fit inside the category const-prop
or some kind of mir-opt
directory.
tests/ui/debuginfo/
Tests for generation of debug information (DWARF, etc.) including variable locations, type information, and source line mapping. Also exercises -C split-debuginfo
and -C debuginfo
.
tests/ui/definition-reachable/
: Definition Reachability
Tests to check whether definitions are reachable.
tests/ui/delegation/
: #![feature(fn_delegation)]
Tests for #![feature(fn_delegation)]
. See Implement function delegation in rustc #3530 for the proposed prototype experimentation.
tests/ui/dep-graph/
: -Z query-dep-graph
These tests use the unstable command line option query-dep-graph
to examine the dependency graph of a Rust program, which is useful for debugging.
tests/ui/deprecation/
: Deprecation Attribute
Tests for #[deprecated]
attribute and deprecated_in_future
internal lint.
tests/ui/deref-patterns/
: #![feature(deref_patterns)]
and #![feature(string_deref_patterns)]
Tests for #![feature(deref_patterns)]
and #![feature(string_deref_patterns)]
. See Deref patterns | The Unstable book.
FIXME: May have some overlap with tests/ui/pattern/deref-patterns
.
tests/ui/derived-errors/
: Derived Error Messages
Tests for quality of diagnostics involving suppression of cascading errors in some cases to avoid overwhelming the user.
tests/ui/derives/
: Derive Macro
Tests for built-in derive macros (Debug
, Clone
, etc.) when used in conjunction with built-in #[derive(..)]
attributes.
tests/ui/deriving/
: Derive Macro
FIXME: Coalesce with tests/ui/derives
.
tests/ui/dest-prop/
Destination Propagation
FIXME: Contains a single test for the DestProp
mir-opt, should probably be rehomed.
tests/ui/destructuring-assignment/
Exercises destructuring assignments. See RFC 2909 Destructuring assignment.
tests/ui/diagnostic-flags/
These tests revolve around command-line flags which change the way error/warning diagnostics are emitted. For example, --error-format=human --color=always
.
FIXME: Check redundancy with annotate-snippet
, which is another emitter.
tests/ui/diagnostic_namespace/
Exercises #[diagnostic::*]
namespaced attributes. See RFC 3368 Diagnostic attribute namepsace.
tests/ui/diagnostic-width/
: --diagnostic-width
Everything to do with --diagnostic-width
.
tests/ui/did_you_mean/
Tests for miscellaneous suggestions.
tests/ui/directory_ownership/
: Declaring mod
inside a block
Exercises diagnostics for when a code block attempts to gain ownership of a non-inline module with a mod
keyword placed inside of it.
tests/ui/disallowed-deconstructing/
: Incorrect struct deconstruction
Exercises diagnostics for disallowed struct destructuring.
tests/ui/dollar-crate/
: $crate
used with the use
keyword
There are a few rules - which are checked in this directory - to follow when using $crate
- it must be used in the start of a use
line and is a reserved identifier.
FIXME: There are a few other tests in other directories with a filename starting with dollar-crate
. They should perhaps be redirected here.
tests/ui/drop/
: Drop
and drop order
Not necessarily about Drop
and its implementation, but also about the drop order of fields inside a struct.
tests/ui/drop-bounds/
Tests for linting on bounding a generic type on Drop
.
tests/ui/dropck/
: Drop Checking
Mostly about checking the validity of Drop
implementations.
See:
tests/ui/dst/
: Dynamically Sized Types
Tests for dynamically-sized types (DSTs). See Dynamically Sized Types | Reference.
tests/ui/duplicate/
: Duplicate Symbols
Tests about duplicated symbol names and associated errors, such as using the #[export_name]
attribute to rename a function with the same name as another function.
tests/ui/dynamically-sized-types/
: Dynamically Sized Types
FIXME: should be coalesced with tests/ui/dst
.
tests/ui/dyn-compatibility/
: Dyn-compatibility
Tests for dyn-compatibility of traits.
See:
Previously known as "object safety".
tests/ui/dyn-drop/
: dyn Drop
FIXME: Contains a single test, used only to check the dyn_drop
lint (which is normally warn
level).
tests/ui/dyn-keyword/
: dyn
and Dynamic Dispatch
The dyn
keyword is used to highlight that calls to methods on the associated Trait are dynamically dispatched. To use the trait this way, it must be dyn-compatible - tests about dyn-compatibility belong in tests/ui/dyn-compatibility/
, while more general tests on dynamic dispatch belong here.
See dyn
keyword.
tests/ui/editions/
: Rust edition-specific peculiarities
These tests run in specific Rust editions, such as Rust 2015 or Rust 2018, and check errors and functionality related to specific now-deprecated idioms and features.
FIXME: Maybe regroup rust-2018
, rust-2021
and rust-2024
under this umbrella?
tests/ui/empty/
: Various tests related to the concept of "empty"
FIXME: These tests need better homes, this is not very informative.
tests/ui/entry-point/
: main
function
Tests exercising the main
entry-point.
tests/ui/enum/
General-purpose tests on enum
s. See Enumerations | Reference.
tests/ui/enum-discriminant/
enum
variants can be differentiated independently of their potential field contents with discriminant
, which returns the type Discriminant<T>
. See std::mem::discriminant
.
tests/ui/env-macro/
: env!
Exercises env!
and option_env!
macros.
tests/ui/ergonomic-clones/
See RFC 3680 Ergonomic clones.
tests/ui/error-codes/
: Error codes
Tests for errors with dedicated error codes.
tests/ui/error-emitter/
Quite similar to ui/diagnostic-flags
in some of its tests, this category checks some behaviours of Rust's error emitter into the user's terminal window, such as truncating error in the case of an excessive amount of them.
tests/ui/errors/
These tests are about very different topics, only unified by the fact that they result in errors.
FIXME: "Errors" is way too generic, the tests probably need to be rehomed into more descriptive subdirectories.
tests/ui/explain/
: rustc --explain EXXXX
Accompanies tests/ui/error-codes/
, exercises the --explain
cli flag.
tests/ui/explicit/
: Errors involving the concept of "explicit"
This category contains three tests: two which are about the specific error explicit use of destructor method
, and one which is about explicit annotation of lifetimes: https://doc.rust-lang.org/stable/rust-by-example/scope/lifetime/explicit.html.
FIXME: Rehome the two tests about the destructor method with drop
-related categories, and rehome the last test with a category related to lifetimes.
tests/ui/explicit-tail-calls/
Exercises #![feature(explicit_tail_calls)]
and the become
keyword. See Explicit Tail Calls #3407.
tests/ui/expr/
: Expressions
A broad directory for tests on expressions.
tests/ui/extern/
Tests on the extern
keyword and extern
blocks and functions.
tests/ui/extern-flag/
: --extern
command line flag
Tests for the --extern
CLI flag.
tests/ui/feature-gates/
Tests on feature-gating, and the #![feature(..)]
mechanism itself.
tests/ui/ffi-attrs/
: #![feature(ffi_const, ffi_pure)]
The #[ffi_const]
and #[ffi_pure]
attributes applies clang's const
and pure
attributes to foreign functions declarations, respectively. These attributes are the core element of the tests in this category.
See:
tests/ui/fmt/
Exercises the format!
macro.
tests/ui/fn/
A broad category of tests on functions.
tests/ui/fn-main/
FIXME: Serves a duplicate purpose with ui/entry-point
, should be combined.
tests/ui/for/
: for
keyword
Tests on the for
keyword and some of its associated errors, such as attempting to write the faulty pattern for _ in 0..1 {} else {}
.
FIXME: Should be merged with ui/for-loop-while
.
tests/ui/force-inlining/
: #[rustc_force_inline]
Tests for #[rustc_force_inline]
, which will force a function to always be labelled as inline by the compiler (it will be inserted at the point of its call instead of being used as a normal function call.) If the compiler is unable to inline the function, an error will be reported. See https://github.com/rust-lang/rust/pull/134082.
tests/ui/foreign/
: Foreign Function Interface (FFI)
Tests for extern "C"
and extern "Rust
.
FIXME: Check for potential overlap/merge with ui/c-variadic
and/or ui/extern
.
tests/ui/for-loop-while/
Anything to do with loops and for
, loop
and while
keywords to express them.
FIXME: After ui/for
is merged into this, also carry over its SUMMARY text.
tests/ui/frontmatter/
Tests for #![feature(frontmatter)]
. See Tracking Issue for frontmatter
#136889.
tests/ui/fully-qualified-type/
Tests for diagnostics when there may be identically named types that need further qualifications to disambiguate.
tests/ui/functional-struct-update/
Functional Struct Update is the name for the idiom by which one can write ..<expr>
at the end of a struct literal expression to fill in all remaining fields of the struct literal by using <expr>
as the source for them.
See RFC 0736 Privacy-respecting Functional Struct Update.
tests/ui/function-pointer/
Tests on function pointers, such as testing their compatibility with higher-ranked trait bounds.
See:
tests/ui/functions-closures/
Tests on closures. See Closure expressions | Reference.
tests/ui/generic-associated-types/
Tests on Generic Associated Types (GATs).
tests/ui/generic-const-items/
Tests for #![feature(generic_const_items)]
. See Tracking issue for generic const items #113521.
tests/ui/generics/
A broad category of tests on generics, usually used when no more specific subdirectories are fitting.
tests/ui/half-open-range-patterns/
: x..
or ..x
range patterns
Tests on range patterns where one of the bounds is not a direct value.
FIXME: Overlaps with ui/range
. impossible_range.rs
is particularly suspected to be a duplicate test.
tests/ui/hashmap/
Tests for the standard library collection std::collections::HashMap
.
tests/ui/hello_world/
Tests that the basic hello-world program is not somehow broken.
tests/ui/higher-ranked/
Tests for higher-ranked trait bounds.
See:
tests/ui/hygiene/
This seems to have been originally intended for "hygienic macros" - macros which work in all contexts, independent of what surrounds them. However, this category has grown into a mish-mash of many tests that may belong in the other directories.
FIXME: Reorganize this directory properly.
tests/ui/illegal-sized-bound/
This test category revolves around trait objects with Sized
having illegal operations performed on them.
FIXME: There seems to be unrelated testing in this directory, such as tests/ui/illegal-sized-bound/mutability-mismatch-arg.rs
. Investigate.
tests/ui/impl-header-lifetime-elision/
Tests on lifetime elision in impl function signatures. See Lifetime elision | Nomicon.
tests/ui/implied-bounds/
See Implied bounds | Reference.
tests/ui/impl-trait/
Tests for trait impls.
tests/ui/imports/
Tests for module system and imports.
tests/ui/include-macros/
Exercise include!
, include_str!
, and include_bytes!
macros.
tests/ui/incoherent-inherent-impls/
Exercise forbidding inherent impls on a type defined in a different crate.
tests/ui/indexing/
Tests on collection types (arrays, slices, vectors) and various errors encountered when indexing their contents, such as accessing out-of-bounds values.
FIXME: (low-priority) could maybe be a subdirectory of ui/array-slice-vec
tests/ui/inference/
Tests on type inference.
tests/ui/infinite/
Tests for diagnostics on infinitely recursive types without indirection.
tests/ui/inherent-impls-overlap-check/
Checks that repeating the same function names across separate impl
blocks triggers an informative error, but not if the impl
are for different types, such as Bar<u8>
and Bar<u16>
.
NOTE: This should maybe be a subdirectory within another related to duplicate definitions, such as tests/ui/duplicate/
.
tests/ui/inline-const/
These tests revolve around the inline const
block that forces the compiler to const-eval its content.
tests/ui/instrument-coverage/
: -Cinstrument-coverage
command line flag
See Instrument coverage | The rustc book.
tests/ui/instrument-xray/
: -Z instrument-xray
See Tracking issue for -Z instrument-xray
#102921.
tests/ui/interior-mutability/
FIXME: contains a single test, probably better rehomed.
tests/ui/internal/
Tests for internal_unstable
and the attribute header #![feature(allow_internal_unstable)]
, which lets compiler developers mark features as internal to the compiler, and unstable for standard library use.
tests/ui/internal-lints/
Tests for rustc-internal lints.
tests/ui/intrinsics/
Tests for the {std,core}::intrinsics
, internal implementation detail.
tests/ui/invalid/
Various tests related to rejecting invalid inputs.
FIXME: This is rather uninformative, possibly rehome into more meaningful directories.
tests/ui/invalid-compile-flags/
Tests for checking that invalid usage of compiler flags are rejected.
tests/ui/invalid-module-declaration/
FIXME: Consider merging into module/resolve directories.
tests/ui/invalid-self-argument/
: self
as a function argument incorrectly
Tests with erroneous ways of using self
, such as having it not be the first argument, or using it in a non-associated function (no impl
or trait
).
FIXME: Maybe merge with ui/self
.
tests/ui/io-checks/
Contains a single test. The test tries to output a file into an invalid directory with -o
, then checks that the result is an error, not an internal compiler error.
FIXME: Rehome to invalid compiler flags maybe.
tests/ui/issues/
: Tests directly related to GitHub issues
FIXME (#133895): Random collection of regression tests and tests for issues, tests in this directory should be audited and rehomed.
tests/ui/iterators/
These tests revolve around anything to do with iterators, e.g. mismatched types.
FIXME: Check for potential overlap with ui/for-loop-while
.
tests/ui/json/
These tests revolve around the --json
compiler flag. See JSON Output.
tests/ui/keyword/
Tests exercising keywords, such as attempting to use them as identifiers when not contextual keywords.
tests/ui/kindck/
FIXME: kindck
is no longer a thing, these tests probably need to be audited and rehomed.
tests/ui/label/
Exercises block and loop 'label
s.
tests/ui/lang-items/
See Lang items | The Unstable book.
tests/ui/late-bound-lifetimes/
See Early vs Late bound parameters | rustc-dev-guide.
tests/ui/layout/
tests/ui/lazy-type-alias/
Tests for #![feature(lazy_type_alias)]
. See Tracking issue for lazy type aliases #112792
.
tests/ui/lazy-type-alias-impl-trait/
This feature allows use of an impl Trait
in multiple locations while actually using the same concrete type (type Alias = impl Trait;
) everywhere, keeping the original impl Trait
hidden.
FIXME: merge this with tests/ui/type-alias-impl-trait/
?
tests/ui/let-else/
Exercises let-else constructs.
tests/ui/lexer/
Exercises of the lexer.
tests/ui/lifetimes/
Broad directory on lifetimes, including proper specifiers, lifetimes not living long enough, or undeclared lifetime names.
tests/ui/limits/
These tests exercises numerical limits, such as [[u8; 1518599999]; 1518600000]
.
tests/ui/linkage-attr/
Tests for the linkage attribute #[linkage]
of #![feature(linkage)]
.
FIXME: Some of these tests do not use the feature at all, which should be moved under ui/linking
instead.
tests/ui/linking/
Tests on code which fails during the linking stage, or which contain arguments and lines that have been known to cause unjustified errors in the past, such as specifying an unusual #[export_name]
.
See Linkage | Reference.
tests/ui/link-native-libs/
Tests for #[link(name = "", kind = "")]
and -l
command line flag.
See Tracking Issue for linking modifiers for native libraries #81490.
tests/ui/lint/
Tests for the lint infrastructure, lint levels, lint reasons, etc.
See:
tests/ui/liveness/
Tests exercising analysis for unused variables, unreachable statements, functions which are supposed to return a value but do not, as well as values moved elsewhere before they could be used by a function.
FIXME: This seems unrelated to "liveness" as defined in the rustc compiler guide. Is this misleadingly named? https://rustc-dev-guide.rust-lang.org/borrow_check/region_inference/lifetime_parameters.html#liveness-and-universal-regions
tests/ui/loops/
Tests on the loop
construct.
FIXME: Consider merging with ui/for-loop-while
.
tests/ui/lowering/
Tests on AST lowering.
tests/ui/lto/
Exercise Link-Time Optimization (LTO), involving the flags -C lto
or -Z thinlto
.
tests/ui/lub-glb/
: LUB/GLB algorithm update
Tests on changes to inference variable lattice LUB/GLB, see https://github.com/rust-lang/rust/pull/45853.
tests/ui/macro_backtrace/
: -Zmacro-backtrace
Contains a single test, checking the unstable command-line flag to enable detailed macro backtraces.
FIXME: This could be merged with ui/macros
, which already contains other macro backtrace tests.
tests/ui/macros/
Broad category of tests on macros.
tests/ui/malformed/
Broad category of tests on malformed inputs.
FIXME: this is kinda vague, probably best to audit and rehome tests.
tests/ui/marker_trait_attr/
See Tracking issue for allowing overlapping implementations for marker trait #29864.
tests/ui/match/
Broad category of tests on match
constructs.
tests/ui/meta/
: Tests for compiletest itself
These tests check the function of the UI test suite at large and Compiletest in itself.
FIXME: This should absolutely be merged with tests/ui/compiletest-self-test/
.
tests/ui/methods/
A broad category for anything related to methods and method resolution.
tests/ui/mir/
Certain mir-opt regression tests.
tests/ui/mir-dataflow
Tests for MIR dataflow analysis.
See MIR Dataflow | rustc-dev-guide.
tests/ui/mismatched_types/
Exercises on mismatched type diagnostics.
tests/ui/missing/
Something is missing which could be added to fix (e.g. suggestions).
FIXME: this is way too vague, tests should be rehomed.
tests/ui/missing_non_modrs_mod/
This directory is a small tree of mod
dependencies, but the root, foo.rs
, is looking for a file which does not exist. The test checks that the error is reported at the top-level module.
FIXME: Merge with tests/ui/modules/
.
tests/ui/missing-trait-bounds/
Tests for checking missing trait bounds, and their diagnostics.
FIMXE: Maybe a subdirectory of ui/trait-bounds
would be more appropriate.
tests/ui/modules/
Tests on the module system.
FIXME: tests/ui/imports/
should probably be merged with this.
tests/ui/modules_and_files_visibility/
FIXME: Merge with tests/ui/modules/
.
tests/ui/moves
Tests on moves (destructive moves).
tests/ui/mut/
Broad category of tests on mutability, such as the mut
keyword, borrowing a value as both immutable and mutable (and the associated error), or adding mutable references to const
declarations.
tests/ui/namespace/
Contains a single test. It imports a massive amount of very similar types from a crate, then attempts various permutations of their namespace paths, checking for errors or the lackthereof.
FIXME: Move under either tests/ui/modules/
or tests/ui/resolve/
.
tests/ui/never_type/
See Tracking issue for promoting !
to a type (RFC 1216) #35121.
tests/ui/new-range/
See RFC 3550 New Range.
tests/ui/nll/
: Non-lexical lifetimes
Tests for Non-lexical lifetimes. See RFC 2094 NLL.
tests/ui/non_modrs_mods/
Despite the size of the directory, this is a single test, spawning a sprawling mod
dependency tree and checking its successful build.
FIXME: Consider merge with tests/ui/modules/
, keeping the directory structure.
tests/ui/non_modrs_mods_and_inline_mods/
A very similar principle as non_modrs_mods
, but with an added inline mod
statement inside another mod
's code block.
FXIME: Consider merge with tests/ui/modules/
, keeping the directory structure.
tests/ui/no_std/
Tests for where the standard library is disabled through #![no_std]
.
tests/ui/not-panic/
Tests checking various types, such as &RefCell<i32>
, and whether they are not UnwindSafe
as expected.
tests/ui/numbers-arithmetic/
Tests that exercises edge cases, such as specific floats, large or very small numbers, or bit conversion, and check that the arithmetic results are as expected.
tests/ui/numeric/
Tests that checks numeric types and their interactions, such as casting among them with as
or providing the wrong numeric suffix.
tests/ui/object-lifetime/
Tests on lifetimes on objects, such as a lifetime bound not being able to be deduced from context, or checking that lifetimes are inherited properly.
FIXME: Just a more specific subset of ui/lifetimes
.
tests/ui/obsolete-in-place/
Contains a single test. Check that we reject the ancient Rust syntax x <- y
and in(BINDING) {}
construct.
FIXME: Definitely should be rehomed, maybe to tests/ui/deprecation/
.
tests/ui/offset-of/
Exercises the std::mem::offset_of
macro.
tests/ui/on-unimplemented/
Exercises the #[rustc_on_unimplemented]
.
tests/ui/operator-recovery/
FIXME: Probably move under tests/ui/binop/
or tests/ui/parser/
.
tests/ui/or-patterns/
Exercises ||
and |
in patterns.
tests/ui/overloaded/
Exercises operator overloading via std::ops
.
tests/ui/packed/
tests/ui/panic-handler/
tests/ui/panic-runtime/
Exercises #![panic_runtime]
, -C panic
, panic runtimes and panic unwind strategy.
tests/ui/panics/
Broad category of tests about panics in general, often but not necessarily using the panic!
macro.
tests/ui/parallel-rustc/
Efforts towards a Parallel Rustc Front-end. Includes -Zthreads=
.
tests/ui/parser/
Various parser tests
FIXME: Maybe move tests/ui/keywords/
under this?
tests/ui/patchable-function-entry/
See Patchable function entry | The Unstable book.
tests/ui/pattern/
Broad category of tests surrounding patterns. See Patterns | Reference.
FIXME: Some overlap with tests/ui/match/
.
tests/ui/pin-macro/
See std::pin
.
tests/ui/precondition-checks/
Exercises on some unsafe precondition checks.
tests/ui/print-request/
Tests on --print
compiler flag. See print options | The rustc book.
tests/ui/print_type_sizes/
Exercises the -Z print-type-sizes
flag.
tests/ui/privacy/
Exercises on name privacy. E.g. the meaning of pub
, pub(crate)
, etc.
tests/ui/process/
Some standard library process tests which are hard to write within standard library crate tests.
tests/ui/process-termination/
Some standard library process termination tests which are hard to write within standard library crate tests.
tests/ui/proc-macro/
Broad category of tests on proc-macros. See Procedural Macros | Reference.
tests/ui/ptr_ops/
: Using operations on a pointer
Contains only 2 tests, related to a single issue, which was about an error caused by using addition on a pointer to i8
.
FIXME: Probably rehome under some typecheck / binop directory.
tests/ui/pub/
: pub
keyword
A large category about function and type public/private visibility, and its impact when using features across crates. Checks both visibility-related error messages and previously buggy cases.
FIXME: merge with tests/ui/privacy/
.
tests/ui/qualified/
Contains few tests on qualified paths where a type parameter is provided at the end: type A = <S as Tr>::A::f<u8>;
. The tests check if this fails during type checking, not parsing.
FIXME: Should be rehomed to ui/typeck
.
tests/ui/query-system/
Tests on Rust methods and functions which use the query system, such as std::mem::size_of
. These compute information about the current runtime and return it. See Query system | rustc-dev-guide.
tests/ui/range/
Broad category of tests ranges, both in their ..
or ..=
form, as well as the standard library Range
, RangeTo
, RangeFrom
or RangeBounds
types.
FIXME: May have some duplicate tests with ui/new-range
.
tests/ui/raw-ref-op/
: Using operators on &raw
values
Exercises &raw mut <place>
and &raw const <place>
. See RFC 2582 Raw reference MIR operator.
tests/ui/reachable
Reachability tests, primarily unreachable code and coercions into the never type !
from diverging expressions.
FIXME: Check for overlap with ui/liveness
.
tests/ui/recursion/
Broad category of tests exercising recursions (compile test and run time), in functions, macros, type
definitions, and more.
Also exercises the #![recursion_limit = ""]
attribute.
tests/ui/recursion_limit/
: #![recursion_limit = ""]
Sets a recursion limit on recursive code.
FIXME: Should be merged with tests/ui/recursion/
.
tests/ui/regions/
FIXME: Maybe merge with ui/lifetimes
.
tests/ui/repeat-expr/
Exercises [Type; n]
syntax for creating arrays with repeated types across a set size.
FIXME: Maybe make this a subdirectory of ui/array-slice-vec
.
tests/ui/repr/
: #[repr(_)]
Tests on the #[repr(..)]
attribute. See Representations | Reference.
tests/ui/reserved/
Reserved keywords and attribute names.
See e.g. Reserved keywords | Reference.
FIXME: maybe merge under tests/ui/keyword/
.
tests/ui/resolve/
: Name resolution
See Name resolution | rustc-dev-guide.
tests/ui/return/
Exercises the return
keyword, return expressions and statements.
tests/ui/rfcs/
Tests that accompanies an implementation for an RFC.
tests/ui/rmeta/
Exercises .rmeta
crate metadata and the --emit=metadata
cli flag.
tests/ui/runtime/
Tests for runtime environment on which Rust programs are executed. E.g. Unix SIGPIPE
.
tests/ui/rust-{2018,2021,2024}/
Tests that exercise behaviors and features that are specific to editions.
tests/ui/rustc-env
Tests on environmental variables that affect rustc
.
tests/ui/rustdoc
Hybrid tests that exercises rustdoc
, and also some joint rustdoc
/rustc
interactions.
tests/ui/sanitizer/
Exercises sanitizer support. See Sanitizer | The rustc book.
tests/ui/self/
: self
keyword
Tests with erroneous ways of using self
, such as using this.x
syntax as seen in other languages, having it not be the first argument, or using it in a non-associated function (no impl
or trait
). It also contains correct uses of self
which have previously been observed to cause ICEs.
tests/ui/sepcomp/
: Separate Compilation
In this directory, multiple crates are compiled, but some of them have inline
functions, meaning they must be inlined into a different crate despite having been compiled separately.
FIXME: this directory might need some better docs, also this directory might want a better name.
tests/ui/shadowed/
Tests on name shadowing.
tests/ui/shell-argfiles/
: -Z shell-argfiles
command line flag
The -Zshell-argfiles
compiler flag allows argfiles to be parsed using POSIX "shell-style" quoting. When enabled, the compiler will use shlex to parse the arguments from argfiles specified with @shell:<path>
.
Because this feature controls the parsing of input arguments, the -Zshell-argfiles
flag must be present before the argument specifying the shell-style argument file.
FIXME: maybe group this with tests/ui/argfile/
tests/ui/simd/
Some tests exercising SIMD support.
tests/ui/single-use-lifetime/
This is a test directory for the specific error case where a lifetime never gets used beyond a single annotation on, for example, a struct
.
tests/ui/sized/
: Sized
trait, sized types
While many tests here involve the Sized
trait directly, some instead test, for example the slight variations between returning a zero-sized Vec
and a Vec
with one item, where one has no known type and the other does.
tests/ui/span/
An assorted collection of tests that involves specific diagnostic spans.
FIXME: This is a big directory with numerous only-tangentially related tests. Maybe some moving is in order.
tests/ui/specialization
See Tracking issue for specialization (RFC 1210) #31844.
tests/ui/stability-attribute/
Stability attributes used internally by the standard library: #[stable()]
and #[unstable()]
.
tests/ui/stable-mir-print/
Some tests for pretty printing of StableMIR.
tests/ui/stack-protector/
: -Z stack-protector
command line flag
See Tracking Issue for stabilizing stack smashing protection (i.e., -Z stack-protector
) #114903.
tests/ui/static/
Tests on static items.
tests/ui/statics/
FIXME: should probably be merged with tests/ui/static/
.
tests/ui/stats/
Tests for compiler-internal stats; -Z meta-stats
and -Z input-stats
flags.
tests/ui/std/
: Tests which use features from the standard library
A catch-all category about anything that can come from std
.
FIXME: this directory is probably too vague, tests might need to be audited and rehomed.
tests/ui/stdlib-unit-tests/
Some standard library tests which are too inconvenient or annoying to implement as std crate tests.
tests/ui/str/
Exercise str
keyword and string slices.
tests/ui/structs/
Assorted tests surrounding the struct
keyword, struct type definitions and usages.
tests/ui/structs-enums/
Tests on both structs and enums.
FIXME: maybe coalesce {tests/ui/structs/
, tests/ui/structs-enums/
, tests/ui/enums/
} into one tests/ui/adts
directory...
tests/ui/suggestions/
Generic collection of tests for suggestions, when no more specific directories are applicable.
FIXME: Some overlap with tests/ui/did_you_mean/
, that directory should probably be moved under here.
tests/ui/svh/
: Strict Version Hash
Tests on the Strict Version Hash (SVH, also known as the "crate hash").
See Strict Version Hash.
tests/ui/symbol-mangling-version/
: -Csymbol-mangling-version
command line flag
FIXME: Should be merged with ui/symbol-names
.
tests/ui/symbol-names/
: Symbol mangling and related attributes
These tests revolve around #[no_mangle]
attribute, as well as consistently mangled symbol names (checked with the rustc_symbol_name
attribute), which is important to build reproducible binaries.
tests/ui/sync/
: Sync
trait
Exercises Sync
trait and auto-derive thereof.
tests/ui/target-cpu/
: -C target-cpu
command line flag
This command line option instructs rustc to generate code specifically for a particular processor.
FIXME: Contains a single test, maybe put it in a directory about misc codegen options?
tests/ui/target-feature/
: #[target_feature(enable = "relaxed-simd")]
Exercises the #[target_feature(..)]
attribute. See Target feature attribute | Reference.
tests/ui/target_modifiers/
Tests for RFC 3716: Target Modifiers.
See Tracking Issue for target modifiers #136966.
tests/ui/test-attrs/
Exercises the #[test]
attribute.
tests/ui/thir-print/
Pretty print of THIR trees via -Zunpretty=thir-tree
.
tests/ui/thread-local/
Exercises thread local values and #[thread_local]
attribute.
See Tracking issue for thread_local stabilization #29594.
tests/ui/threads-sendsync/
Broad category for parallelism and multi-threaded tests, including attempting to send types across threads which are not thread-safe.
tests/ui/tool-attributes/
: External tool attributes
Exercises tool attributes.
tests/ui/track-diagnostics/
Exercises #[track_caller]
and -Z track-diagnostics
.
tests/ui/trait-bounds/
Collection of tests for trait bounds.
tests/ui/traits/
Broad collection of tests on traits in general.
FIXME: This could be better organized in subdirectories containing tests such as ui/traits/trait-bounds
.
tests/ui/transmutability/
: #![feature(transmutability)]
See Tracking Issue for Transmutability Trait: #[transmutability]
#99571.
See also Project Safe Transmute.
tests/ui/transmute/
Tests surrounding std::mem::transmute
.
tests/ui/treat-err-as-bug/
Exercises compiler development support flag -Z treat-err-as-bug
.
tests/ui/trivial-bounds/
#![feature(trivial_bounds)]
. See RFC 2056 Allow trivial where clause constraints.
tests/ui/try-block/
#![feature(try_blocks)]
. See Tracking issue for ?
operator and try
blocks (RFC 243, question_mark
& try_blocks
features).
tests/ui/try-trait/
#![feature(try_trait_v2)]
. See RFC 3058 Try Trait v2.
tests/ui/tuple/
Tests surrounding the tuple type ()
.
tests/ui/type/
Assorted collection of tests surrounding the concept of a "type".
FIXME: There is very little consistency across tests of this category, and should probably be sent to other subdirectories.
tests/ui/type-alias/
Exercises type aliases.
tests/ui/type-alias-enum-variants/
Tests for type
aliases in the context of enum
variants, such as that applied type arguments of enums are respected independently of being the original type or the type
alias.
tests/ui/type-alias-impl-trait/
#![feature(type_alias_impl_trait)]
. See Type Alias Impl Trait | The Unstable book.
tests/ui/typeck/
General collection of type checking related tests.
tests/ui/type-inference/
General collection of type inference related tests.
tests/ui/typeof/
typeof
keyword, reserved but unimplemented.
tests/ui/ufcs/
See RFC 0132 Unified Function Call Syntax.
tests/ui/unboxed-closures/
#![feature(unboxed_closures)]
, Fn
, FnMut
and FnOnce
traits
See Tracking issue for Fn traits (unboxed_closures
& fn_traits
feature).
tests/ui/underscore-imports/
See Underscore imports | Reference.
FIXME: should become a subdirectory of tests/ui/imports/
.
tests/ui/underscore-lifetime/
: '_
elided lifetime
Exercises anonymous elided lifetimes.
tests/ui/uniform-paths/
In uniform paths, if a submodule and an external dependencies have the same name, to depend on the external dependency, one needs to disambiguate it from the submodule using use ::foo
. Tests revolve around this, for example, check that self::foo
and ::foo
are not considered ambiguously identical by the compiler.
Remark: As they are an important Rust 2018 feature, they also get a big subdirectory in ui/rust-2018/uniform-paths
tests/ui/uninhabited/
: Uninhabited types
tests/ui/union/
See Unions | Reference.
tests/ui/unknown-unstable-lints/
: Attempting to refer to an unstable lint which does not exist
Tests for trying to use non-existent unstable lints.
FIXME: move this under tests/ui/lints/
.
tests/ui/unop/
: Unary operators -
, *
and !
Tests the three unary operators for negating, dereferencing and inverting, across different contexts.
tests/ui/unpretty/
: -Z unpretty
command line flag
The -Z unpretty
flag outputs various representations of a program's tree in a certain way.
tests/ui/unresolved/
Exercises various unresolved errors, ranging from earlier name resolution failures to later method resolution failures.
tests/ui/unsafe/
A broad category of tests about unsafe Rust code.
tests/ui/unsafe-binders/
: #![feature(unsafe_binders)]
See Tracking issue for unsafe binder types #130516.
tests/ui/unsafe-fields/
: struct
s and enum
s with an unsafe
field
See Tracking issue for RFC 3458: Unsafe fields #132922.
tests/ui/unsized/
: Zero-sized types, Sized
trait, object has no known size at compile time
FIXME: between tests/ui/zero-sized/
, tests/ui/sized/
and this directory, might need to reorganize them a bit.
tests/ui/unsized-locals/
: #![feature(unsized_locals, unsized_fn_params)]
See:
- RFC 1909 Unsized rvalues
- de-RFC 3829: Remove unsized_locals
- Tracking issue for RFC #1909: Unsized Rvalues (
unsized_locals
,unsized_fn_params
)
FIXME: Seems to also contain more generic tests that fit in tests/ui/unsized/
.
tests/ui/unused-crate-deps/
Exercises the unused_crate_dependencies
lint.
tests/ui/unwind-abis/
FIXME: Contains a single test, should likely be rehomed to tests/ui/abi/
.
tests/ui/use/
FIXME: merge with ui/imports
.
tests/ui/variance/
: Covariants, invariants and contravariants
See Variance | Reference.
tests/ui/variants/
: enum
variants
Tests on enum
variants.
FIXME: Should be rehomed with tests/ui/enum/
.
tests/ui/version/
FIXME: Contains a single test described as "Check that rustc accepts various version info flags.", should be rehomed.
tests/ui/warnings/
FIXME: Contains a single test on non-explicit paths (::one()
). Should be rehomed probably to tests/ui/resolve/
.
tests/ui/wasm/
These tests target the wasm32
architecture specifically. They are usually regression tests for WASM-specific bugs which were observed in the past.
tests/ui/wf/
: Well-formedness checking
Tests on various well-formedness checks, e.g. Type-checking normal functions.
tests/ui/where-clauses/
Tests on where
clauses. See Where clauses | Reference.
tests/ui/while/
Tests on the while
keyword and the while
construct.
FIXME: merge with ui/for-loop-while
.
tests/ui/windows-subsystem/
: #![windows_subsystem = ""]
See the windows_subsystem
attribute.