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/abiThese 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/allocatorThese tests exercise #![feature(allocator_api)] and the #[global_allocator] attribute.
See Allocator traits and std::heap #32838.
tests/ui/alloc-errorThese tests exercise alloc error handling.
See https://doc.rust-lang.org/std/alloc/fn.handle_alloc_error.html.
tests/ui/annotate-snippetThese 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-paramsThese 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 argumentsThese 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 vectorsExercises 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 suggestionsCalling 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! macroThese 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 ConstantsThese 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 TypesThese 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 ItemsTests 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 BoundsThese 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 TypesTests 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/AwaitTests for the async/await related features. E.g. async functions, await expressions, and their interaction with other language features.
tests/ui/attributes: Compiler AttributesTests 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 TraitsThere 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 DifferentiationThe #[autodiff] macro supports automatic differentiation.
See Tracking Issue for autodiff #124509.
tests/ui/autoref-autoderef: Automatic Referencing/DereferencingTests 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/: BacktracesRuntime panics and error handling generate backtraces to assist in debugging and diagnostics.
tests/ui/bench/: Benchmarks and performanceThis 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 BindingTests 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 operatorsTests 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 identifierTests exercising name resolution.
FIXME: Probably move to tests/ui/resolve/.
tests/ui/block-result/: Block results and returningTests 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 variableMeta tests for stability mechanisms surrounding RUSTC_BOOTSTRAP, which is coordinated between rustc and the build system, bootstrap.
tests/ui/borrowck/: Borrow CheckingTests for borrow checking. E.g. lifetime analysis, borrowing rules, and diagnostics.
tests/ui/box/: Box BehaviorTests 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 MapsTests 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 TestsTests 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 CastingTests 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 AttributeTests 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 ChecksTests 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 contextTests for closure type inference with respect to surrounding scopes, mostly quality of diagnostics.
tests/ui/closure-expected-type/: Closure type inferenceTests 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 TestsAny 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 ABIsTests 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 GenerationTests that exercise code generation. E.g. codegen flags (starting with -C on the command line), LLVM IR output, optimizations (and the various opt-levels), and target-specific code generation (such as tests specific to x86_64).
tests/ui/codemap_tests/: Source MappingTests that exercise source code mapping.
tests/ui/coercion/: Type CoercionTests 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 CoherenceTests 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 ResolutionTests 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::CommandThis 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 comparisonsSome 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” testsMeta test suite of the test harness compiletest itself.
tests/ui/conditional-compilation/: Conditional CompilationTests 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 AmbiguityIf 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 GenericsTests 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:
feature(generic_const_exprs) #76560tests/ui/const_prop/: Constant PropagationTests 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 PointersTests exercise const raw pointers. E.g. pointer arithmetic, casting and dereferencing, always with a const.
See:
tests/ui/consts/: General Constant EvaluationAnything 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 featureTests exercising #![feature(contracts)].
See Tracking Issue for Contracts #128044.
tests/ui/coroutine/: Coroutines feature and gen blocksTests for #![feature(coroutines)] and gen blocks, it belongs here.
See:
tests/ui/coverage-attr/: #[coverage] attributeTests for #![feature(coverage_attribute)]. See Tracking issue for function attribute #[coverage].
tests/ui/crate-loading/: Crate LoadingTests 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 InteractionTests 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 FunctionTests for FFI with C varargs (va_list).
tests/ui/cycle-trait/: Trait Cycle DetectionTests 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 ReachabilityTests 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-graphThese 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 AttributeTests 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 MessagesTests for quality of diagnostics involving suppression of cascading errors in some cases to avoid overwhelming the user.
tests/ui/derives/: Derive MacroTests for built-in derive macros (Debug, Clone, etc.) when used in conjunction with built-in #[derive(..)] attributes.
tests/ui/deriving/: Derive MacroFIXME: Coalesce with tests/ui/derives.
tests/ui/dest-prop/ Destination PropagationFIXME: 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 namespace.
tests/ui/diagnostics-infraThis directory contains tests and infrastructure related to the diagnostics system, including support for translatable diagnostics
tests/ui/diagnostic-width/: --diagnostic-widthEverything to do with --diagnostic-width.
tests/ui/did_you_mean/Tests for miscellaneous suggestions.
tests/ui/directory_ownership/: Declaring mod inside a blockExercises 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 deconstructionExercises diagnostics for disallowed struct destructuring.
tests/ui/dollar-crate/: $crate used with the use keywordThere 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 orderNot 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 CheckingMostly about checking the validity of Drop implementations.
See:
tests/ui/dst/: Dynamically Sized TypesTests for dynamically-sized types (DSTs). See Dynamically Sized Types | Reference.
tests/ui/duplicate/: Duplicate SymbolsTests 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 TypesFIXME: should be coalesced with tests/ui/dst.
tests/ui/dyn-compatibility/: Dyn-compatibilityTests for dyn-compatibility of traits.
See:
Previously known as “object safety”.
tests/ui/dyn-drop/: dyn DropFIXME: Contains a single test, used only to check the dyn_drop lint (which is normally warn level).
tests/ui/dyn-keyword/: dyn and Dynamic DispatchThe 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 peculiaritiesThese 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 functionTests exercising the main entry-point.
tests/ui/enum/General-purpose tests on enums. 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 codesTests 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 EXXXXAccompanies 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/: ExpressionsA 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 flagTests 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 keywordTests 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 patternsTests 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/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 flagSee Instrument coverage | The rustc book.
tests/ui/instrument-xray/: -Z instrument-xraySee 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 incorrectlyTests 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 issuesFIXME (#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 'labels.
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 updateTests on changes to inference variable lattice LUB/GLB, see https://github.com/rust-lang/rust/pull/45853.
tests/ui/macro_backtrace/: -Zmacro-backtraceContains 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 itselfThese 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-dataflowTests 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/movesTests 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 lifetimesTests 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 pointerContains 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 keywordA 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 valuesExercises &raw mut <place> and &raw const <place>. See RFC 2582 Raw reference MIR operator.
tests/ui/reachableReachability 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 resolutionSee 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-envTests on environmental variables that affect rustc.
tests/ui/rustdocHybrid 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 keywordTests 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/self-profile/: self-profilingTests related to the self-profiler (-Zself-profile) functionality of rustc.
tests/ui/sepcomp/: Separate CompilationIn 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 flagThe -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 typesWhile 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/specializationSee Tracking issue for specialization (RFC 1210) #31844.
tests/ui/stability-attribute/Stability attributes used internally by the standard library: #[stable()] and #[unstable()].
tests/ui/rustc_public-ir-print/Some tests for pretty printing of rustc_public's IR.
tests/ui/stack-protector/: -Z stack-protector command line flagSee 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 libraryA 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 HashTests 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 flagFIXME: Should be merged with ui/symbol-names.
tests/ui/symbol-names/: Symbol mangling and related attributesThese 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 traitExercises Sync trait and auto-derive thereof.
tests/ui/target-cpu/: -C target-cpu command line flagThis 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 attributesExercises 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 lifetimeExercises 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 typestests/ui/union/See Unions | Reference.
tests/ui/unknown-unstable-lints/: Attempting to refer to an unstable lint which does not existTests 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 flagThe -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/: structs and enums with an unsafe fieldSee Tracking issue for RFC 3458: Unsafe fields #132922.
tests/ui/unsized/: Zero-sized types, Sized trait, object has no known size at compile timeFIXME: 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:
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 contravariantsSee Variance | Reference.
tests/ui/variants/: enum variantsTests 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 checkingTests 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.
tests/ui/zero-sized/: Zero-sized types