summaryrefslogtreecommitdiffstats
path: root/tests/ui/traits/new-solver
diff options
context:
space:
mode:
Diffstat (limited to 'tests/ui/traits/new-solver')
-rw-r--r--tests/ui/traits/new-solver/alias-bound-preference.rs39
-rw-r--r--tests/ui/traits/new-solver/alias-bound-unsound.rs31
-rw-r--r--tests/ui/traits/new-solver/alias-bound-unsound.stderr57
-rw-r--r--tests/ui/traits/new-solver/alias-eq-in-canonical-response.rs40
-rw-r--r--tests/ui/traits/new-solver/alias-sub.rs34
-rw-r--r--tests/ui/traits/new-solver/alias_eq_cant_be_furthur_normalized.rs29
-rw-r--r--tests/ui/traits/new-solver/alias_eq_dont_use_normalizes_to_if_substs_eq.rs47
-rw-r--r--tests/ui/traits/new-solver/alias_eq_simple.rs22
-rw-r--r--tests/ui/traits/new-solver/alias_eq_substs_eq_not_intercrate.rs17
-rw-r--r--tests/ui/traits/new-solver/alias_eq_substs_eq_not_intercrate.stderr13
-rw-r--r--tests/ui/traits/new-solver/array-default.rs8
-rw-r--r--tests/ui/traits/new-solver/assembly/assemble-normalizing-self-ty-impl-ambiguity.rs27
-rw-r--r--tests/ui/traits/new-solver/assembly/runaway-impl-candidate-selection.rs15
-rw-r--r--tests/ui/traits/new-solver/assembly/runaway-impl-candidate-selection.stderr16
-rw-r--r--tests/ui/traits/new-solver/async.fail.stderr17
-rw-r--r--tests/ui/traits/new-solver/async.rs19
-rw-r--r--tests/ui/traits/new-solver/auto-with-drop_tracking_mir.fail.stderr18
-rw-r--r--tests/ui/traits/new-solver/auto-with-drop_tracking_mir.rs27
-rw-r--r--tests/ui/traits/new-solver/borrowck-error.rs11
-rw-r--r--tests/ui/traits/new-solver/borrowck-error.stderr12
-rw-r--r--tests/ui/traits/new-solver/builtin-fn-must-return-sized.rs17
-rw-r--r--tests/ui/traits/new-solver/builtin-fn-must-return-sized.stderr16
-rw-r--r--tests/ui/traits/new-solver/canonical-int-var-eq-in-response.rs22
-rw-r--r--tests/ui/traits/new-solver/canonical-ty-var-eq-in-response.rs39
-rw-r--r--tests/ui/traits/new-solver/canonicalize-effect-var.rs22
-rw-r--r--tests/ui/traits/new-solver/cast-checks-handling-projections.rs6
-rw-r--r--tests/ui/traits/new-solver/closure-inference-guidance.rs11
-rw-r--r--tests/ui/traits/new-solver/closure-substs-ambiguity.rs7
-rw-r--r--tests/ui/traits/new-solver/coherence/issue-102048.rs44
-rw-r--r--tests/ui/traits/new-solver/coherence/issue-102048.stderr16
-rw-r--r--tests/ui/traits/new-solver/coherence/trait_ref_is_knowable-norm-overflow.rs20
-rw-r--r--tests/ui/traits/new-solver/coherence/trait_ref_is_knowable-norm-overflow.stderr18
-rw-r--r--tests/ui/traits/new-solver/coherence/trait_ref_is_knowable-normalization-1.rs22
-rw-r--r--tests/ui/traits/new-solver/coherence/trait_ref_is_knowable-normalization-2.rs25
-rw-r--r--tests/ui/traits/new-solver/coherence/trait_ref_is_knowable-normalization-3.rs24
-rw-r--r--tests/ui/traits/new-solver/const-param-placeholder.fail.stderr16
-rw-r--r--tests/ui/traits/new-solver/const-param-placeholder.rs21
-rw-r--r--tests/ui/traits/new-solver/coroutine.fail.stderr64
-rw-r--r--tests/ui/traits/new-solver/coroutine.rs32
-rw-r--r--tests/ui/traits/new-solver/cycles/coinduction/fixpoint-exponential-growth.rs31
-rw-r--r--tests/ui/traits/new-solver/cycles/coinduction/fixpoint-exponential-growth.stderr16
-rw-r--r--tests/ui/traits/new-solver/cycles/coinduction/incompleteness-unstable-result.rs69
-rw-r--r--tests/ui/traits/new-solver/cycles/coinduction/incompleteness-unstable-result.stderr16
-rw-r--r--tests/ui/traits/new-solver/cycles/double-cycle-inductive-coinductive.rs37
-rw-r--r--tests/ui/traits/new-solver/cycles/double-cycle-inductive-coinductive.stderr29
-rw-r--r--tests/ui/traits/new-solver/cycles/fixpoint-rerun-all-cycle-heads.rs53
-rw-r--r--tests/ui/traits/new-solver/cycles/fixpoint-rerun-all-cycle-heads.stderr10
-rw-r--r--tests/ui/traits/new-solver/cycles/inductive-cycle-but-err.rs48
-rw-r--r--tests/ui/traits/new-solver/cycles/inductive-cycle-but-err.stderr16
-rw-r--r--tests/ui/traits/new-solver/cycles/inductive-cycle-but-ok.rs44
-rw-r--r--tests/ui/traits/new-solver/cycles/inductive-cycle-discarded-coinductive-constraints.rs36
-rw-r--r--tests/ui/traits/new-solver/cycles/inductive-not-on-stack.rs46
-rw-r--r--tests/ui/traits/new-solver/cycles/inductive-not-on-stack.stderr29
-rw-r--r--tests/ui/traits/new-solver/cycles/leak-check-coinductive-cycle.rs33
-rw-r--r--tests/ui/traits/new-solver/cycles/provisional-result-done.rs33
-rw-r--r--tests/ui/traits/new-solver/deduce-closure-signature-after-normalization.rs10
-rw-r--r--tests/ui/traits/new-solver/deduce-ty-from-object.rs6
-rw-r--r--tests/ui/traits/new-solver/dedup-regions.rs31
-rw-r--r--tests/ui/traits/new-solver/destruct.rs13
-rw-r--r--tests/ui/traits/new-solver/dont-coerce-infer-to-dyn.rs17
-rw-r--r--tests/ui/traits/new-solver/dont-elaborate-for-projections.rs12
-rw-r--r--tests/ui/traits/new-solver/dont-ice-on-assoc-projection.rs19
-rw-r--r--tests/ui/traits/new-solver/dont-ice-on-assoc-projection.stderr21
-rw-r--r--tests/ui/traits/new-solver/dont-loop-fulfill-on-region-constraints.rs32
-rw-r--r--tests/ui/traits/new-solver/dont-normalize-proj-with-error.rs22
-rw-r--r--tests/ui/traits/new-solver/dont-normalize-proj-with-error.stderr9
-rw-r--r--tests/ui/traits/new-solver/dont-remap-tait-substs.rs19
-rw-r--r--tests/ui/traits/new-solver/dont-type_of-tait-in-defining-scope.not_send.stderr16
-rw-r--r--tests/ui/traits/new-solver/dont-type_of-tait-in-defining-scope.rs24
-rw-r--r--tests/ui/traits/new-solver/dyn-any-dont-prefer-impl.rs17
-rw-r--r--tests/ui/traits/new-solver/elaborate-item-bounds.rs12
-rw-r--r--tests/ui/traits/new-solver/equating-projection-cyclically.rs28
-rw-r--r--tests/ui/traits/new-solver/equating-projection-cyclically.stderr9
-rw-r--r--tests/ui/traits/new-solver/escaping-bound-vars-in-writeback-normalization.rs18
-rw-r--r--tests/ui/traits/new-solver/float-canonical.rs8
-rw-r--r--tests/ui/traits/new-solver/fn-trait-closure.rs8
-rw-r--r--tests/ui/traits/new-solver/fn-trait.rs32
-rw-r--r--tests/ui/traits/new-solver/fn-trait.stderr126
-rw-r--r--tests/ui/traits/new-solver/generalize/generalize-proj-new-universe-index-1.rs73
-rw-r--r--tests/ui/traits/new-solver/generalize/generalize-proj-new-universe-index-2.rs75
-rw-r--r--tests/ui/traits/new-solver/generalize/generalize-proj-new-universe-index-2.stderr18
-rw-r--r--tests/ui/traits/new-solver/higher-ranked-dyn-bounds.rs17
-rw-r--r--tests/ui/traits/new-solver/int-var-alias-eq.rs18
-rw-r--r--tests/ui/traits/new-solver/int-var-is-send.rs8
-rw-r--r--tests/ui/traits/new-solver/iter-filter-projection.rs12
-rw-r--r--tests/ui/traits/new-solver/lazy-nested-obligations-1.rs13
-rw-r--r--tests/ui/traits/new-solver/lazy-nested-obligations-2.rs22
-rw-r--r--tests/ui/traits/new-solver/lazy-nested-obligations-3.rs38
-rw-r--r--tests/ui/traits/new-solver/member-constraints-in-root-universe.rs17
-rw-r--r--tests/ui/traits/new-solver/more-object-bound.rs27
-rw-r--r--tests/ui/traits/new-solver/more-object-bound.stderr22
-rw-r--r--tests/ui/traits/new-solver/negative-coherence-bounds.rs40
-rw-r--r--tests/ui/traits/new-solver/negative-coherence-bounds.stderr12
-rw-r--r--tests/ui/traits/new-solver/nested-alias-bound.rs20
-rw-r--r--tests/ui/traits/new-solver/nested-obligations-with-bound-vars-gat.rs43
-rw-r--r--tests/ui/traits/new-solver/normalize-async-closure-in-trait.rs9
-rw-r--r--tests/ui/traits/new-solver/normalize-param-env-1.rs40
-rw-r--r--tests/ui/traits/new-solver/normalize-param-env-2.rs26
-rw-r--r--tests/ui/traits/new-solver/normalize-param-env-3.rs32
-rw-r--r--tests/ui/traits/new-solver/normalize-rcvr-for-inherent.rs25
-rw-r--r--tests/ui/traits/new-solver/normalize-unsize-rhs.rs23
-rw-r--r--tests/ui/traits/new-solver/normalized-const-built-in-op.rs11
-rw-r--r--tests/ui/traits/new-solver/normalizes_to_ignores_unnormalizable_candidate.rs40
-rw-r--r--tests/ui/traits/new-solver/normalizes_to_ignores_unnormalizable_candidate.self_infer.stderr22
-rw-r--r--tests/ui/traits/new-solver/object-soundness-requires-generalization.rs20
-rw-r--r--tests/ui/traits/new-solver/object-unsafety.rs28
-rw-r--r--tests/ui/traits/new-solver/object-unsafety.stderr78
-rw-r--r--tests/ui/traits/new-solver/opportunistic-region-resolve.rs19
-rw-r--r--tests/ui/traits/new-solver/overflow/exponential-trait-goals.rs19
-rw-r--r--tests/ui/traits/new-solver/overflow/exponential-trait-goals.stderr16
-rw-r--r--tests/ui/traits/new-solver/overflow/global-cache.rs23
-rw-r--r--tests/ui/traits/new-solver/overflow/global-cache.stderr16
-rw-r--r--tests/ui/traits/new-solver/overflow/recursion-limit-zero-issue-115351.rs12
-rw-r--r--tests/ui/traits/new-solver/overflow/recursion-limit-zero-issue-115351.stderr27
-rw-r--r--tests/ui/traits/new-solver/overflow/recursive-self-normalization-2.rs20
-rw-r--r--tests/ui/traits/new-solver/overflow/recursive-self-normalization-2.stderr20
-rw-r--r--tests/ui/traits/new-solver/overflow/recursive-self-normalization.rs16
-rw-r--r--tests/ui/traits/new-solver/overflow/recursive-self-normalization.stderr20
-rw-r--r--tests/ui/traits/new-solver/param-candidate-doesnt-shadow-project.rs25
-rw-r--r--tests/ui/traits/new-solver/param-discr-kind.rs8
-rw-r--r--tests/ui/traits/new-solver/pointee.rs21
-rw-r--r--tests/ui/traits/new-solver/pointer-like.rs14
-rw-r--r--tests/ui/traits/new-solver/pointer-like.stderr24
-rw-r--r--tests/ui/traits/new-solver/prefer-candidate-no-constraints.rs22
-rw-r--r--tests/ui/traits/new-solver/prefer-param-env-on-ambiguity.rs10
-rw-r--r--tests/ui/traits/new-solver/projection-discr-kind.rs18
-rw-r--r--tests/ui/traits/new-solver/projection-discr-kind.stderr22
-rw-r--r--tests/ui/traits/new-solver/slice-match-byte-lit.rs11
-rw-r--r--tests/ui/traits/new-solver/specialization-transmute.rs28
-rw-r--r--tests/ui/traits/new-solver/specialization-transmute.stderr28
-rw-r--r--tests/ui/traits/new-solver/specialization-unconstrained.rs22
-rw-r--r--tests/ui/traits/new-solver/specialization-unconstrained.stderr32
-rw-r--r--tests/ui/traits/new-solver/stall-num-var-auto-trait.fallback.stderr17
-rw-r--r--tests/ui/traits/new-solver/stall-num-var-auto-trait.rs25
-rw-r--r--tests/ui/traits/new-solver/structural-resolve-field.rs13
-rw-r--r--tests/ui/traits/new-solver/tait-eq-proj-2.rs23
-rw-r--r--tests/ui/traits/new-solver/tait-eq-proj.rs35
-rw-r--r--tests/ui/traits/new-solver/tait-eq-tait.rs18
-rw-r--r--tests/ui/traits/new-solver/temporary-ambiguity.rs22
-rw-r--r--tests/ui/traits/new-solver/trait-upcast-lhs-needs-normalization.rs20
-rw-r--r--tests/ui/traits/new-solver/try-example.rs28
-rw-r--r--tests/ui/traits/new-solver/two-projection-param-candidates-are-ambiguous.rs30
-rw-r--r--tests/ui/traits/new-solver/two-projection-param-candidates-are-ambiguous.stderr17
-rw-r--r--tests/ui/traits/new-solver/unevaluated-const-impl-trait-ref.fails.stderr18
-rw-r--r--tests/ui/traits/new-solver/unevaluated-const-impl-trait-ref.rs22
-rw-r--r--tests/ui/traits/new-solver/unsafe-auto-trait-impl.rs8
-rw-r--r--tests/ui/traits/new-solver/unsize-although-ambiguous.rs13
-rw-r--r--tests/ui/traits/new-solver/unsize-good.rs25
-rw-r--r--tests/ui/traits/new-solver/upcast-right-substs.rs14
-rw-r--r--tests/ui/traits/new-solver/upcast-wrong-substs.rs13
-rw-r--r--tests/ui/traits/new-solver/upcast-wrong-substs.stderr14
-rw-r--r--tests/ui/traits/new-solver/winnow-specializing-impls.rs22
152 files changed, 0 insertions, 3715 deletions
diff --git a/tests/ui/traits/new-solver/alias-bound-preference.rs b/tests/ui/traits/new-solver/alias-bound-preference.rs
deleted file mode 100644
index e4e0f634e..000000000
--- a/tests/ui/traits/new-solver/alias-bound-preference.rs
+++ /dev/null
@@ -1,39 +0,0 @@
-// revisions: old next
-//[next] compile-flags: -Ztrait-solver=next
-// run-pass
-
-// A test for https://github.com/rust-lang/trait-system-refactor-initiative/issues/45.
-
-trait Trait {
- type Assoc: Into<u32>;
-}
-impl<T: Into<u32>> Trait for T {
- type Assoc = T;
-}
-fn prefer_alias_bound_projection<T: Trait>(x: T::Assoc) {
- // There are two possible types for `x`:
- // - `u32` by using the "alias bound" of `<T as Trait>::Assoc`
- // - `<T as Trait>::Assoc`, i.e. `u16`, by using `impl<T> From<T> for T`
- //
- // We infer the type of `x` to be `u32` here as it is highly likely
- // that this is expected by the user.
- let x = x.into();
- assert_eq!(std::mem::size_of_val(&x), 4);
-}
-
-fn impl_trait() -> impl Into<u32> {
- 0u16
-}
-
-fn main() {
- // There are two possible types for `x`:
- // - `u32` by using the "alias bound" of `impl Into<u32>`
- // - `impl Into<u32>`, i.e. `u16`, by using `impl<T> From<T> for T`
- //
- // We infer the type of `x` to be `u32` here as it is highly likely
- // that this is expected by the user.
- let x = impl_trait().into();
- assert_eq!(std::mem::size_of_val(&x), 4);
-
- prefer_alias_bound_projection::<u16>(1);
-}
diff --git a/tests/ui/traits/new-solver/alias-bound-unsound.rs b/tests/ui/traits/new-solver/alias-bound-unsound.rs
deleted file mode 100644
index 825e874d7..000000000
--- a/tests/ui/traits/new-solver/alias-bound-unsound.rs
+++ /dev/null
@@ -1,31 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-
-// Makes sure that alias bounds are not unsound!
-
-#![feature(trivial_bounds)]
-
-trait Foo {
- type Item: Copy
- where
- <Self as Foo>::Item: Copy;
-
- fn copy_me(x: &Self::Item) -> Self::Item {
- *x
- }
-}
-
-impl Foo for () {
- type Item = String where String: Copy;
- //~^ ERROR overflow evaluating the requirement `<() as Foo>::Item: Copy`
-}
-
-fn main() {
- let x = String::from("hello, world");
- drop(<() as Foo>::copy_me(&x));
- //~^ ERROR overflow evaluating the requirement `<() as Foo>::Item: Sized`
- //~| ERROR overflow evaluating the requirement `<() as Foo>::Item == _`
- //~| ERROR overflow evaluating the requirement `<() as Foo>::Item well-formed`
- //~| ERROR overflow evaluating the requirement `String <: <() as Foo>::Item`
- //~| ERROR overflow evaluating the requirement `&<() as Foo>::Item well-formed`
- println!("{x}");
-}
diff --git a/tests/ui/traits/new-solver/alias-bound-unsound.stderr b/tests/ui/traits/new-solver/alias-bound-unsound.stderr
deleted file mode 100644
index ca4b5c90f..000000000
--- a/tests/ui/traits/new-solver/alias-bound-unsound.stderr
+++ /dev/null
@@ -1,57 +0,0 @@
-error[E0275]: overflow evaluating the requirement `<() as Foo>::Item: Copy`
- --> $DIR/alias-bound-unsound.rs:18:17
- |
-LL | type Item = String where String: Copy;
- | ^^^^^^
- |
- = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`alias_bound_unsound`)
-note: required by a bound in `Foo::Item`
- --> $DIR/alias-bound-unsound.rs:8:16
- |
-LL | type Item: Copy
- | ^^^^ required by this bound in `Foo::Item`
-
-error[E0275]: overflow evaluating the requirement `String <: <() as Foo>::Item`
- --> $DIR/alias-bound-unsound.rs:24:31
- |
-LL | drop(<() as Foo>::copy_me(&x));
- | ^^
- |
- = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`alias_bound_unsound`)
-
-error[E0275]: overflow evaluating the requirement `<() as Foo>::Item == _`
- --> $DIR/alias-bound-unsound.rs:24:10
- |
-LL | drop(<() as Foo>::copy_me(&x));
- | ^^^^^^^^^^^^^^^^^^^^^^^^
- |
- = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`alias_bound_unsound`)
-
-error[E0275]: overflow evaluating the requirement `<() as Foo>::Item: Sized`
- --> $DIR/alias-bound-unsound.rs:24:10
- |
-LL | drop(<() as Foo>::copy_me(&x));
- | ^^^^^^^^^^^^^^^^^^^^
- |
- = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`alias_bound_unsound`)
- = note: the return type of a function must have a statically known size
-
-error[E0275]: overflow evaluating the requirement `&<() as Foo>::Item well-formed`
- --> $DIR/alias-bound-unsound.rs:24:31
- |
-LL | drop(<() as Foo>::copy_me(&x));
- | ^^
- |
- = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`alias_bound_unsound`)
-
-error[E0275]: overflow evaluating the requirement `<() as Foo>::Item well-formed`
- --> $DIR/alias-bound-unsound.rs:24:10
- |
-LL | drop(<() as Foo>::copy_me(&x));
- | ^^^^^^^^^^^^^^^^^^^^^^^^
- |
- = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`alias_bound_unsound`)
-
-error: aborting due to 6 previous errors
-
-For more information about this error, try `rustc --explain E0275`.
diff --git a/tests/ui/traits/new-solver/alias-eq-in-canonical-response.rs b/tests/ui/traits/new-solver/alias-eq-in-canonical-response.rs
deleted file mode 100644
index 4bfb6323a..000000000
--- a/tests/ui/traits/new-solver/alias-eq-in-canonical-response.rs
+++ /dev/null
@@ -1,40 +0,0 @@
-// check-pass
-// compile-flags: -Ztrait-solver=next
-
-trait Foo {
- type Gat<'a>
- where
- Self: 'a;
- fn bar(&self) -> Self::Gat<'_>;
-}
-
-enum Option<T> {
- Some(T),
- None,
-}
-
-impl<T> Option<T> {
- fn as_ref(&self) -> Option<&T> {
- match self {
- Option::Some(t) => Option::Some(t),
- Option::None => Option::None,
- }
- }
-
- fn map<U>(self, f: impl FnOnce(T) -> U) -> Option<U> {
- match self {
- Option::Some(t) => Option::Some(f(t)),
- Option::None => Option::None,
- }
- }
-}
-
-impl<T: Foo + 'static> Foo for Option<T> {
- type Gat<'a> = Option<<T as Foo>::Gat<'a>> where Self: 'a;
-
- fn bar(&self) -> Self::Gat<'_> {
- self.as_ref().map(Foo::bar)
- }
-}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/alias-sub.rs b/tests/ui/traits/new-solver/alias-sub.rs
deleted file mode 100644
index 30c1981a9..000000000
--- a/tests/ui/traits/new-solver/alias-sub.rs
+++ /dev/null
@@ -1,34 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-trait Trait {
- type Assoc: Sized;
-}
-
-impl Trait for &'static str {
- type Assoc = &'static str;
-}
-
-// Wrapper is just here to get around stupid `Sized` obligations in mir typeck
-struct Wrapper<T: ?Sized>(std::marker::PhantomData<T>);
-fn mk<T: Trait>(x: T) -> Wrapper<<T as Trait>::Assoc> { todo!() }
-
-
-trait IsStaticStr {}
-impl IsStaticStr for (&'static str,) {}
-fn define<T: IsStaticStr>(_: T) {}
-
-fn foo<'a, T: Trait>() {
- let y = Default::default();
-
- // `<?0 as Trait>::Assoc <: &'a str`
- // In the old solver, this would *equate* the LHS and RHS.
- let _: Wrapper<&'a str> = mk(y);
-
- // ... then later on, we constrain `?0 = &'static str`
- // but that should not mean that `'a = 'static`, because
- // we should use *sub* above.
- define((y,));
-}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/alias_eq_cant_be_furthur_normalized.rs b/tests/ui/traits/new-solver/alias_eq_cant_be_furthur_normalized.rs
deleted file mode 100644
index dc726ba51..000000000
--- a/tests/ui/traits/new-solver/alias_eq_cant_be_furthur_normalized.rs
+++ /dev/null
@@ -1,29 +0,0 @@
-// check-pass
-// compile-flags: -Ztrait-solver=next
-
-// check that a goal such as `alias-eq(<T as TraitB>::Assoc<bool>, <T as TraitB>::Assoc<?0>)`
-// succeeds with a constraint that `?0 = bool`
-
-// FIXME(deferred_projection_equality): add a test that this is true during coherence
-
-trait TraitA {}
-
-trait TraitB {
- type Assoc<T: ?Sized>;
-}
-
-impl<T: TraitB> TraitA for (T, T::Assoc<bool>) {}
-
-impl TraitB for i32 {
- type Assoc<T: ?Sized> = u32;
-}
-
-fn needs_a<T: TraitA>() {}
-
-fn bar<T: TraitB>() {
- needs_a::<(T, <T as TraitB>::Assoc<_>)>();
-}
-
-fn main() {
- bar::<i32>();
-}
diff --git a/tests/ui/traits/new-solver/alias_eq_dont_use_normalizes_to_if_substs_eq.rs b/tests/ui/traits/new-solver/alias_eq_dont_use_normalizes_to_if_substs_eq.rs
deleted file mode 100644
index 3c7fc7403..000000000
--- a/tests/ui/traits/new-solver/alias_eq_dont_use_normalizes_to_if_substs_eq.rs
+++ /dev/null
@@ -1,47 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-
-// check-pass
-// (should not pass, should be turned into a coherence-only test)
-
-// check that when computing `alias-eq(<() as Foo<u16, T>>::Assoc, <() as Foo<?0, T>>::Assoc)`
-// we do not infer `?0 = u8` via the `for<STOP> (): Foo<u8, STOP>` impl or `?0 = u16` by
-// relating substs as either could be a valid solution.
-
-trait Foo<T, STOP> {
- type Assoc;
-}
-
-impl<STOP> Foo<u8, STOP> for ()
-where
- (): Foo<u16, STOP>,
-{
- type Assoc = <() as Foo<u16, STOP>>::Assoc;
-}
-
-impl Foo<u16, i8> for () {
- type Assoc = u8;
-}
-
-impl Foo<u16, i16> for () {
- type Assoc = u16;
-}
-
-fn output<T, U>() -> <() as Foo<T, U>>::Assoc
-where
- (): Foo<T, U>,
-{
- todo!()
-}
-
-fn incomplete<T>()
-where
- (): Foo<u16, T>,
-{
- // `<() as Foo<u16, STOP>>::Assoc == <() as Foo<_, STOP>>::Assoc`
- let _: <() as Foo<u16, T>>::Assoc = output::<_, T>();
-
- // let _: <() as Foo<u16, T>>::Assoc = output::<u8, T>(); // OK
- // let _: <() as Foo<u16, T>>::Assoc = output::<u16, T>(); // OK
-}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/alias_eq_simple.rs b/tests/ui/traits/new-solver/alias_eq_simple.rs
deleted file mode 100644
index 6792cf3ce..000000000
--- a/tests/ui/traits/new-solver/alias_eq_simple.rs
+++ /dev/null
@@ -1,22 +0,0 @@
-// check-pass
-// compile-flags: -Ztrait-solver=next
-
-// test that the new solver can handle `alias-eq(<i32 as TraitB>::Assoc, u32)`
-
-trait TraitA {}
-
-trait TraitB {
- type Assoc;
-}
-
-impl<T: TraitB> TraitA for (T, T::Assoc) {}
-
-impl TraitB for i32 {
- type Assoc = u32;
-}
-
-fn needs_a<T: TraitA>() {}
-
-fn main() {
- needs_a::<(i32, u32)>();
-}
diff --git a/tests/ui/traits/new-solver/alias_eq_substs_eq_not_intercrate.rs b/tests/ui/traits/new-solver/alias_eq_substs_eq_not_intercrate.rs
deleted file mode 100644
index 204f6e8b0..000000000
--- a/tests/ui/traits/new-solver/alias_eq_substs_eq_not_intercrate.rs
+++ /dev/null
@@ -1,17 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-
-// check that a `alias-eq(<?a as TraitB>::Assoc, <?b as TraitB>::Assoc)` goal fails
-// during coherence. We must not incorrectly constrain `?a` and `?b` to be
-// equal.
-
-trait TraitB {
- type Assoc;
-}
-
-trait Overlaps<T> {}
-
-impl<T: TraitB> Overlaps<Box<T>> for <T as TraitB>::Assoc {}
-impl<U: TraitB> Overlaps<U> for <U as TraitB>::Assoc {}
-//~^ ERROR conflicting implementations of trait
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/alias_eq_substs_eq_not_intercrate.stderr b/tests/ui/traits/new-solver/alias_eq_substs_eq_not_intercrate.stderr
deleted file mode 100644
index 46677a583..000000000
--- a/tests/ui/traits/new-solver/alias_eq_substs_eq_not_intercrate.stderr
+++ /dev/null
@@ -1,13 +0,0 @@
-error[E0119]: conflicting implementations of trait `Overlaps<Box<_>>` for type `<_ as TraitB>::Assoc`
- --> $DIR/alias_eq_substs_eq_not_intercrate.rs:14:1
- |
-LL | impl<T: TraitB> Overlaps<Box<T>> for <T as TraitB>::Assoc {}
- | --------------------------------------------------------- first implementation here
-LL | impl<U: TraitB> Overlaps<U> for <U as TraitB>::Assoc {}
- | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ conflicting implementation for `<_ as TraitB>::Assoc`
- |
- = note: downstream crates may implement trait `TraitB` for type `std::boxed::Box<_>`
-
-error: aborting due to previous error
-
-For more information about this error, try `rustc --explain E0119`.
diff --git a/tests/ui/traits/new-solver/array-default.rs b/tests/ui/traits/new-solver/array-default.rs
deleted file mode 100644
index 5077137b0..000000000
--- a/tests/ui/traits/new-solver/array-default.rs
+++ /dev/null
@@ -1,8 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-fn has_default<const N: usize>() where [(); N]: Default {}
-
-fn main() {
- has_default::<1>();
-}
diff --git a/tests/ui/traits/new-solver/assembly/assemble-normalizing-self-ty-impl-ambiguity.rs b/tests/ui/traits/new-solver/assembly/assemble-normalizing-self-ty-impl-ambiguity.rs
deleted file mode 100644
index 826e8c1e0..000000000
--- a/tests/ui/traits/new-solver/assembly/assemble-normalizing-self-ty-impl-ambiguity.rs
+++ /dev/null
@@ -1,27 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-// Checks that we do not get ambiguity by considering an impl
-// multiple times if we're able to normalize the self type.
-
-trait Trait<'a> {}
-
-impl<'a, T: 'a> Trait<'a> for T {}
-
-fn impls_trait<'a, T: Trait<'a>>() {}
-
-trait Id {
- type Assoc;
-}
-impl<T> Id for T {
- type Assoc = T;
-}
-
-fn call<T>() {
- impls_trait::<<T as Id>::Assoc>();
-}
-
-fn main() {
- call::<()>();
- impls_trait::<<<() as Id>::Assoc as Id>::Assoc>();
-}
diff --git a/tests/ui/traits/new-solver/assembly/runaway-impl-candidate-selection.rs b/tests/ui/traits/new-solver/assembly/runaway-impl-candidate-selection.rs
deleted file mode 100644
index 1dca86d36..000000000
--- a/tests/ui/traits/new-solver/assembly/runaway-impl-candidate-selection.rs
+++ /dev/null
@@ -1,15 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-
-// In the new solver, we are trying to select `<?0 as Iterator>::Item: Debug`,
-// which, naively can be unified with every impl of `Debug` if we're not careful.
-// This test makes sure that we treat projections with inference var substs as
-// placeholders during fast reject.
-
-fn iter<T: Iterator>() -> <T as Iterator>::Item {
- todo!()
-}
-
-fn main() {
- println!("{:?}", iter::<_>());
- //~^ ERROR type annotations needed
-}
diff --git a/tests/ui/traits/new-solver/assembly/runaway-impl-candidate-selection.stderr b/tests/ui/traits/new-solver/assembly/runaway-impl-candidate-selection.stderr
deleted file mode 100644
index 414deb477..000000000
--- a/tests/ui/traits/new-solver/assembly/runaway-impl-candidate-selection.stderr
+++ /dev/null
@@ -1,16 +0,0 @@
-error[E0283]: type annotations needed
- --> $DIR/runaway-impl-candidate-selection.rs:13:22
- |
-LL | println!("{:?}", iter::<_>());
- | ^^^^^^^^^ cannot infer type of the type parameter `T` declared on the function `iter`
- |
- = note: cannot satisfy `_: Iterator`
-note: required by a bound in `iter`
- --> $DIR/runaway-impl-candidate-selection.rs:8:12
- |
-LL | fn iter<T: Iterator>() -> <T as Iterator>::Item {
- | ^^^^^^^^ required by this bound in `iter`
-
-error: aborting due to previous error
-
-For more information about this error, try `rustc --explain E0283`.
diff --git a/tests/ui/traits/new-solver/async.fail.stderr b/tests/ui/traits/new-solver/async.fail.stderr
deleted file mode 100644
index 44097b556..000000000
--- a/tests/ui/traits/new-solver/async.fail.stderr
+++ /dev/null
@@ -1,17 +0,0 @@
-error[E0271]: type mismatch resolving `<{async block@$DIR/async.rs:12:17: 12:25} as Future>::Output == i32`
- --> $DIR/async.rs:12:17
- |
-LL | needs_async(async {});
- | ----------- ^^^^^^^^ types differ
- | |
- | required by a bound introduced by this call
- |
-note: required by a bound in `needs_async`
- --> $DIR/async.rs:8:31
- |
-LL | fn needs_async(_: impl Future<Output = i32>) {}
- | ^^^^^^^^^^^^ required by this bound in `needs_async`
-
-error: aborting due to previous error
-
-For more information about this error, try `rustc --explain E0271`.
diff --git a/tests/ui/traits/new-solver/async.rs b/tests/ui/traits/new-solver/async.rs
deleted file mode 100644
index 155b71eb7..000000000
--- a/tests/ui/traits/new-solver/async.rs
+++ /dev/null
@@ -1,19 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// edition: 2021
-// revisions: pass fail
-//[pass] check-pass
-
-use std::future::Future;
-
-fn needs_async(_: impl Future<Output = i32>) {}
-
-#[cfg(fail)]
-fn main() {
- needs_async(async {});
- //[fail]~^ ERROR type mismatch
-}
-
-#[cfg(pass)]
-fn main() {
- needs_async(async { 1i32 });
-}
diff --git a/tests/ui/traits/new-solver/auto-with-drop_tracking_mir.fail.stderr b/tests/ui/traits/new-solver/auto-with-drop_tracking_mir.fail.stderr
deleted file mode 100644
index 4aefdd6bb..000000000
--- a/tests/ui/traits/new-solver/auto-with-drop_tracking_mir.fail.stderr
+++ /dev/null
@@ -1,18 +0,0 @@
-error[E0277]: `impl Future<Output = ()>` cannot be sent between threads safely
- --> $DIR/auto-with-drop_tracking_mir.rs:25:13
- |
-LL | is_send(foo());
- | ------- ^^^^^ `impl Future<Output = ()>` cannot be sent between threads safely
- | |
- | required by a bound introduced by this call
- |
- = help: the trait `Send` is not implemented for `impl Future<Output = ()>`
-note: required by a bound in `is_send`
- --> $DIR/auto-with-drop_tracking_mir.rs:24:24
- |
-LL | fn is_send(_: impl Send) {}
- | ^^^^ required by this bound in `is_send`
-
-error: aborting due to previous error
-
-For more information about this error, try `rustc --explain E0277`.
diff --git a/tests/ui/traits/new-solver/auto-with-drop_tracking_mir.rs b/tests/ui/traits/new-solver/auto-with-drop_tracking_mir.rs
deleted file mode 100644
index 6b54718e3..000000000
--- a/tests/ui/traits/new-solver/auto-with-drop_tracking_mir.rs
+++ /dev/null
@@ -1,27 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// edition: 2021
-// revisions: pass fail
-//[pass] check-pass
-
-#![feature(negative_impls)]
-
-struct NotSync;
-impl !Sync for NotSync {}
-
-async fn foo() {
- #[cfg(pass)]
- let x = &();
- #[cfg(fail)]
- let x = &NotSync;
- bar().await;
- #[allow(dropping_references)]
- drop(x);
-}
-
-async fn bar() {}
-
-fn main() {
- fn is_send(_: impl Send) {}
- is_send(foo());
- //[fail]~^ ERROR `impl Future<Output = ()>` cannot be sent between threads safely
-}
diff --git a/tests/ui/traits/new-solver/borrowck-error.rs b/tests/ui/traits/new-solver/borrowck-error.rs
deleted file mode 100644
index 4787a2c7e..000000000
--- a/tests/ui/traits/new-solver/borrowck-error.rs
+++ /dev/null
@@ -1,11 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-
-use std::collections::HashMap;
-
-fn foo() -> &'static HashMap<i32, i32>
-{
- &HashMap::new()
- //~^ ERROR cannot return reference to temporary value
-}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/borrowck-error.stderr b/tests/ui/traits/new-solver/borrowck-error.stderr
deleted file mode 100644
index a7d820174..000000000
--- a/tests/ui/traits/new-solver/borrowck-error.stderr
+++ /dev/null
@@ -1,12 +0,0 @@
-error[E0515]: cannot return reference to temporary value
- --> $DIR/borrowck-error.rs:7:5
- |
-LL | &HashMap::new()
- | ^--------------
- | ||
- | |temporary value created here
- | returns a reference to data owned by the current function
-
-error: aborting due to previous error
-
-For more information about this error, try `rustc --explain E0515`.
diff --git a/tests/ui/traits/new-solver/builtin-fn-must-return-sized.rs b/tests/ui/traits/new-solver/builtin-fn-must-return-sized.rs
deleted file mode 100644
index ba473653e..000000000
--- a/tests/ui/traits/new-solver/builtin-fn-must-return-sized.rs
+++ /dev/null
@@ -1,17 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-
-#![feature(fn_traits)]
-#![feature(unboxed_closures)]
-#![feature(tuple_trait)]
-
-use std::ops::Fn;
-use std::marker::Tuple;
-
-fn foo<F: Fn<T>, T: Tuple>(f: Option<F>, t: T) {
- let y = (f.unwrap()).call(t);
-}
-
-fn main() {
- foo::<fn() -> str, _>(None, ());
- //~^ expected a `Fn<_>` closure, found `fn() -> str`
-}
diff --git a/tests/ui/traits/new-solver/builtin-fn-must-return-sized.stderr b/tests/ui/traits/new-solver/builtin-fn-must-return-sized.stderr
deleted file mode 100644
index 4eaa25961..000000000
--- a/tests/ui/traits/new-solver/builtin-fn-must-return-sized.stderr
+++ /dev/null
@@ -1,16 +0,0 @@
-error[E0277]: expected a `Fn<_>` closure, found `fn() -> str`
- --> $DIR/builtin-fn-must-return-sized.rs:15:11
- |
-LL | foo::<fn() -> str, _>(None, ());
- | ^^^^^^^^^^^ expected an `Fn<_>` closure, found `fn() -> str`
- |
- = help: the trait `Fn<_>` is not implemented for `fn() -> str`
-note: required by a bound in `foo`
- --> $DIR/builtin-fn-must-return-sized.rs:10:11
- |
-LL | fn foo<F: Fn<T>, T: Tuple>(f: Option<F>, t: T) {
- | ^^^^^ required by this bound in `foo`
-
-error: aborting due to previous error
-
-For more information about this error, try `rustc --explain E0277`.
diff --git a/tests/ui/traits/new-solver/canonical-int-var-eq-in-response.rs b/tests/ui/traits/new-solver/canonical-int-var-eq-in-response.rs
deleted file mode 100644
index 4b013983a..000000000
--- a/tests/ui/traits/new-solver/canonical-int-var-eq-in-response.rs
+++ /dev/null
@@ -1,22 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-trait Mirror {
- type Assoc;
-}
-
-impl<T> Mirror for T {
- type Assoc = T;
-}
-
-trait Test {}
-impl Test for i64 {}
-impl Test for u64 {}
-
-fn mirror_me<T: Mirror>(t: T, s: <T as Mirror>::Assoc) where <T as Mirror>::Assoc: Test {}
-
-fn main() {
- let mut x = 0;
- mirror_me(x, 1);
- x = 1i64;
-}
diff --git a/tests/ui/traits/new-solver/canonical-ty-var-eq-in-response.rs b/tests/ui/traits/new-solver/canonical-ty-var-eq-in-response.rs
deleted file mode 100644
index d1c6b1077..000000000
--- a/tests/ui/traits/new-solver/canonical-ty-var-eq-in-response.rs
+++ /dev/null
@@ -1,39 +0,0 @@
-// check-pass
-// compile-flags: -Ztrait-solver=next
-
-trait Mirror {
- type Item;
-}
-
-struct Wrapper<T>(T);
-impl<T> Mirror for Wrapper<T> {
- type Item = T;
-}
-
-fn mirror<T>()
-where
- Wrapper<T>: Mirror<Item = i32>,
-{
-}
-
-fn main() {
- mirror::<_ /* ?0 */>();
-
- // Solving `<Wrapper<?0> as Mirror>::Item = i32`
-
- // First, we replace the term with a fresh infer var:
- // `<Wrapper<?0> as Mirror>::Item = ?1`
-
- // We select the impl candidate on line #6, which leads us to learn that
- // `?0 == ?1`.
-
- // That should be reflected in our canonical response, which should have
- // `^0 = ^0, ^1 = ^0`
- // !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
- // !! We used to return a totally unconstrained response here :< !!
- // !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
-
- // Then, during the "equate term" part of the projection solving, we
- // instantiate the response from the unconstrained projection predicate,
- // and equate `?0 == i32`.
-}
diff --git a/tests/ui/traits/new-solver/canonicalize-effect-var.rs b/tests/ui/traits/new-solver/canonicalize-effect-var.rs
deleted file mode 100644
index 35b69ed1a..000000000
--- a/tests/ui/traits/new-solver/canonicalize-effect-var.rs
+++ /dev/null
@@ -1,22 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-#![feature(effects)]
-#![feature(const_trait_impl)]
-
-#[const_trait]
-trait Foo {
- fn foo();
-}
-
-trait Bar {}
-
-impl const Foo for i32 {
- fn foo() {}
-}
-
-impl<T> const Foo for T where T: Bar {
- fn foo() {}
-}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/cast-checks-handling-projections.rs b/tests/ui/traits/new-solver/cast-checks-handling-projections.rs
deleted file mode 100644
index 3b261062f..000000000
--- a/tests/ui/traits/new-solver/cast-checks-handling-projections.rs
+++ /dev/null
@@ -1,6 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-fn main() {
- (0u8 + 0u8) as char;
-}
diff --git a/tests/ui/traits/new-solver/closure-inference-guidance.rs b/tests/ui/traits/new-solver/closure-inference-guidance.rs
deleted file mode 100644
index d2ad0cc03..000000000
--- a/tests/ui/traits/new-solver/closure-inference-guidance.rs
+++ /dev/null
@@ -1,11 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-fn foo(i: isize) -> isize { i + 1 }
-
-fn apply<A, F>(f: F, v: A) -> A where F: FnOnce(A) -> A { f(v) }
-
-pub fn main() {
- let f = |i| foo(i);
- assert_eq!(apply(f, 2), 3);
-}
diff --git a/tests/ui/traits/new-solver/closure-substs-ambiguity.rs b/tests/ui/traits/new-solver/closure-substs-ambiguity.rs
deleted file mode 100644
index 48432f402..000000000
--- a/tests/ui/traits/new-solver/closure-substs-ambiguity.rs
+++ /dev/null
@@ -1,7 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-fn main() {
- let mut x: Vec<_> = vec![];
- x.extend(Some(1i32).into_iter().map(|x| x));
-}
diff --git a/tests/ui/traits/new-solver/coherence/issue-102048.rs b/tests/ui/traits/new-solver/coherence/issue-102048.rs
deleted file mode 100644
index 11636bfeb..000000000
--- a/tests/ui/traits/new-solver/coherence/issue-102048.rs
+++ /dev/null
@@ -1,44 +0,0 @@
-// This must fail coherence.
-//
-// Getting this to pass was fairly difficult, so here's an explanation
-// of what's happening:
-//
-// Normalizing projections currently tries to replace them with inference variables
-// while emitting a nested `Projection` obligation. This cannot be done if the projection
-// has bound variables which is the case here.
-//
-// So the projections stay until after normalization. When unifying two projections we
-// currently treat them as if they are injective, so we **incorrectly** unify their
-// substs. This means that coherence for the two impls ends up unifying `?T` and `?U`
-// as it tries to unify `<?T as WithAssoc1<'a>>::Assoc` with `<?U as WithAssoc1<'a>>::Assoc`.
-//
-// `impl1` therefore has the projection `<?T as WithAssoc2<'a>>::Assoc` and we have the
-// assumption `?T: for<'a> WithAssoc2<'a, Assoc = i32>` in the `param_env`, so we normalize
-// that to `i32`. We then try to unify `i32` from `impl1` with `u32` from `impl2` which fails,
-// causing coherence to consider these two impls distinct.
-
-// compile-flags: -Ztrait-solver=next
-pub trait Trait<T> {}
-
-pub trait WithAssoc1<'a> {
- type Assoc;
-}
-pub trait WithAssoc2<'a> {
- type Assoc;
-}
-
-// impl 1
-impl<T, U> Trait<for<'a> fn(<T as WithAssoc1<'a>>::Assoc, <U as WithAssoc2<'a>>::Assoc)> for (T, U)
-where
- T: for<'a> WithAssoc1<'a> + for<'a> WithAssoc2<'a, Assoc = i32>,
- U: for<'a> WithAssoc2<'a>,
-{
-}
-
-// impl 2
-impl<T, U> Trait<for<'a> fn(<U as WithAssoc1<'a>>::Assoc, u32)> for (T, U) where
- U: for<'a> WithAssoc1<'a> //~^ ERROR conflicting implementations of trait
-{
-}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/coherence/issue-102048.stderr b/tests/ui/traits/new-solver/coherence/issue-102048.stderr
deleted file mode 100644
index 41bf68a1d..000000000
--- a/tests/ui/traits/new-solver/coherence/issue-102048.stderr
+++ /dev/null
@@ -1,16 +0,0 @@
-error[E0119]: conflicting implementations of trait `Trait<for<'a> fn(<_ as WithAssoc1<'a>>::Assoc, <_ as WithAssoc2<'a>>::Assoc)>` for type `(_, _)`
- --> $DIR/issue-102048.rs:39:1
- |
-LL | / impl<T, U> Trait<for<'a> fn(<T as WithAssoc1<'a>>::Assoc, <U as WithAssoc2<'a>>::Assoc)> for (T, U)
-LL | | where
-LL | | T: for<'a> WithAssoc1<'a> + for<'a> WithAssoc2<'a, Assoc = i32>,
-LL | | U: for<'a> WithAssoc2<'a>,
- | |______________________________- first implementation here
-...
-LL | / impl<T, U> Trait<for<'a> fn(<U as WithAssoc1<'a>>::Assoc, u32)> for (T, U) where
-LL | | U: for<'a> WithAssoc1<'a>
- | |_____________________________^ conflicting implementation for `(_, _)`
-
-error: aborting due to previous error
-
-For more information about this error, try `rustc --explain E0119`.
diff --git a/tests/ui/traits/new-solver/coherence/trait_ref_is_knowable-norm-overflow.rs b/tests/ui/traits/new-solver/coherence/trait_ref_is_knowable-norm-overflow.rs
deleted file mode 100644
index b39ae0333..000000000
--- a/tests/ui/traits/new-solver/coherence/trait_ref_is_knowable-norm-overflow.rs
+++ /dev/null
@@ -1,20 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-
-// Coherence should handle overflow while normalizing for
-// `trait_ref_is_knowable` correctly.
-
-trait Overflow {
- type Assoc;
-}
-impl<T> Overflow for T {
- type Assoc = <T as Overflow>::Assoc;
-}
-
-
-trait Trait {}
-impl<T: Copy> Trait for T {}
-struct LocalTy;
-impl Trait for <LocalTy as Overflow>::Assoc {}
-//~^ ERROR conflicting implementations of trait `Trait` for type `<LocalTy as Overflow>::Assoc`
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/coherence/trait_ref_is_knowable-norm-overflow.stderr b/tests/ui/traits/new-solver/coherence/trait_ref_is_knowable-norm-overflow.stderr
deleted file mode 100644
index 73d46c4df..000000000
--- a/tests/ui/traits/new-solver/coherence/trait_ref_is_knowable-norm-overflow.stderr
+++ /dev/null
@@ -1,18 +0,0 @@
-WARN rustc_trait_selection::traits::coherence expected an unknowable trait ref: <<LocalTy as Overflow>::Assoc as std::marker::Sized>
-WARN rustc_trait_selection::traits::coherence expected an unknowable trait ref: <<LocalTy as Overflow>::Assoc as std::marker::Sized>
-WARN rustc_trait_selection::traits::coherence expected an unknowable trait ref: <<LocalTy as Overflow>::Assoc as std::marker::Sized>
-WARN rustc_trait_selection::traits::coherence expected an unknowable trait ref: <<LocalTy as Overflow>::Assoc as std::marker::Sized>
-error[E0119]: conflicting implementations of trait `Trait` for type `<LocalTy as Overflow>::Assoc`
- --> $DIR/trait_ref_is_knowable-norm-overflow.rs:17:1
- |
-LL | impl<T: Copy> Trait for T {}
- | ------------------------- first implementation here
-LL | struct LocalTy;
-LL | impl Trait for <LocalTy as Overflow>::Assoc {}
- | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ conflicting implementation for `<LocalTy as Overflow>::Assoc`
- |
- = note: upstream crates may add a new impl of trait `std::marker::Copy` for type `<LocalTy as Overflow>::Assoc` in future versions
-
-error: aborting due to previous error
-
-For more information about this error, try `rustc --explain E0119`.
diff --git a/tests/ui/traits/new-solver/coherence/trait_ref_is_knowable-normalization-1.rs b/tests/ui/traits/new-solver/coherence/trait_ref_is_knowable-normalization-1.rs
deleted file mode 100644
index c38e3baf5..000000000
--- a/tests/ui/traits/new-solver/coherence/trait_ref_is_knowable-normalization-1.rs
+++ /dev/null
@@ -1,22 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-trait Id {
- type Assoc;
-}
-impl<T> Id for T {
- type Assoc = T;
-}
-
-
-// Coherence should be able to reason that `<LocalTy as Id>::Assoc: Copy`
-// does not hold.
-//
-// See https://github.com/rust-lang/trait-system-refactor-initiative/issues/51
-// for more details.
-trait Trait {}
-impl<T: Copy> Trait for T {}
-struct LocalTy;
-impl Trait for <LocalTy as Id>::Assoc {}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/coherence/trait_ref_is_knowable-normalization-2.rs b/tests/ui/traits/new-solver/coherence/trait_ref_is_knowable-normalization-2.rs
deleted file mode 100644
index 2d53266db..000000000
--- a/tests/ui/traits/new-solver/coherence/trait_ref_is_knowable-normalization-2.rs
+++ /dev/null
@@ -1,25 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-use std::future::{Future, IntoFuture};
-use std::pin::Pin;
-
-// We check that this does not overlap with the following impl from std:
-// impl<P> Future for Pin<P> where P: DerefMut, <P as Deref>::Target: Future { .. }
-// This should fail because we know ` <&mut Value as Deref>::Target: Future` not to hold.
-// For this to work we have to normalize in the `trait_ref_is_knowable` check as we
-// otherwise add an ambiguous candidate here.
-//
-// See https://github.com/rust-lang/trait-system-refactor-initiative/issues/51
-// for more details.
-struct Value;
-impl<'a> IntoFuture for Pin<&'a mut Value> {
- type Output = ();
- type IntoFuture = Pin<Box<dyn Future<Output = ()> + Send>>;
-
- fn into_future(self) -> Self::IntoFuture {
- todo!()
- }
-}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/coherence/trait_ref_is_knowable-normalization-3.rs b/tests/ui/traits/new-solver/coherence/trait_ref_is_knowable-normalization-3.rs
deleted file mode 100644
index 2f27de4e4..000000000
--- a/tests/ui/traits/new-solver/coherence/trait_ref_is_knowable-normalization-3.rs
+++ /dev/null
@@ -1,24 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-trait Id {
- type Assoc;
-}
-impl<T> Id for T {
- type Assoc = T;
-}
-
-
-// Coherence should be able to reason that `(): PartialEq<<T as Id>::Assoc>>`
-// does not hold.
-//
-// See https://github.com/rust-lang/trait-system-refactor-initiative/issues/51
-// for more details.
-trait Trait {}
-impl<T> Trait for T
-where
- (): PartialEq<T> {}
-struct LocalTy;
-impl Trait for <LocalTy as Id>::Assoc {}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/const-param-placeholder.fail.stderr b/tests/ui/traits/new-solver/const-param-placeholder.fail.stderr
deleted file mode 100644
index 4db6e22e5..000000000
--- a/tests/ui/traits/new-solver/const-param-placeholder.fail.stderr
+++ /dev/null
@@ -1,16 +0,0 @@
-error[E0277]: the trait bound `[T; N]: Foo` is not satisfied
- --> $DIR/const-param-placeholder.rs:17:17
- |
-LL | needs_foo::<[T; N]>();
- | ^^^^^^ the trait `Foo` is not implemented for `[T; N]`
- |
- = help: the trait `Foo` is implemented for `[T; 1]`
-note: required by a bound in `needs_foo`
- --> $DIR/const-param-placeholder.rs:8:17
- |
-LL | fn needs_foo<F: Foo>() {}
- | ^^^ required by this bound in `needs_foo`
-
-error: aborting due to previous error
-
-For more information about this error, try `rustc --explain E0277`.
diff --git a/tests/ui/traits/new-solver/const-param-placeholder.rs b/tests/ui/traits/new-solver/const-param-placeholder.rs
deleted file mode 100644
index a83102a4c..000000000
--- a/tests/ui/traits/new-solver/const-param-placeholder.rs
+++ /dev/null
@@ -1,21 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// revisions: pass fail
-//[pass] check-pass
-
-struct Wrapper<T, const N: usize>([T; N]);
-
-trait Foo {}
-fn needs_foo<F: Foo>() {}
-
-#[cfg(fail)]
-impl<T> Foo for [T; 1] {}
-
-#[cfg(pass)]
-impl<T, const N: usize> Foo for [T; N] {}
-
-fn test<T, const N: usize>() {
- needs_foo::<[T; N]>();
- //[fail]~^ ERROR the trait bound `[T; N]: Foo` is not satisfied
-}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/coroutine.fail.stderr b/tests/ui/traits/new-solver/coroutine.fail.stderr
deleted file mode 100644
index 14e67727d..000000000
--- a/tests/ui/traits/new-solver/coroutine.fail.stderr
+++ /dev/null
@@ -1,64 +0,0 @@
-error[E0277]: the trait bound `{coroutine@$DIR/coroutine.rs:18:21: 18:23}: Coroutine<A>` is not satisfied
- --> $DIR/coroutine.rs:18:21
- |
-LL | needs_coroutine(|| {
- | _____---------------_^
- | | |
- | | required by a bound introduced by this call
-LL | |
-LL | |
-LL | |
-LL | | yield ();
-LL | | });
- | |_____^ the trait `Coroutine<A>` is not implemented for `{coroutine@$DIR/coroutine.rs:18:21: 18:23}`
- |
-note: required by a bound in `needs_coroutine`
- --> $DIR/coroutine.rs:14:28
- |
-LL | fn needs_coroutine(_: impl Coroutine<A, Yield = B, Return = C>) {}
- | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ required by this bound in `needs_coroutine`
-
-error[E0271]: type mismatch resolving `<{coroutine@$DIR/coroutine.rs:18:21: 18:23} as Coroutine<A>>::Yield == B`
- --> $DIR/coroutine.rs:18:21
- |
-LL | needs_coroutine(|| {
- | _____---------------_^
- | | |
- | | required by a bound introduced by this call
-LL | |
-LL | |
-LL | |
-LL | | yield ();
-LL | | });
- | |_____^ types differ
- |
-note: required by a bound in `needs_coroutine`
- --> $DIR/coroutine.rs:14:41
- |
-LL | fn needs_coroutine(_: impl Coroutine<A, Yield = B, Return = C>) {}
- | ^^^^^^^^^ required by this bound in `needs_coroutine`
-
-error[E0271]: type mismatch resolving `<{coroutine@$DIR/coroutine.rs:18:21: 18:23} as Coroutine<A>>::Return == C`
- --> $DIR/coroutine.rs:18:21
- |
-LL | needs_coroutine(|| {
- | _____---------------_^
- | | |
- | | required by a bound introduced by this call
-LL | |
-LL | |
-LL | |
-LL | | yield ();
-LL | | });
- | |_____^ types differ
- |
-note: required by a bound in `needs_coroutine`
- --> $DIR/coroutine.rs:14:52
- |
-LL | fn needs_coroutine(_: impl Coroutine<A, Yield = B, Return = C>) {}
- | ^^^^^^^^^^ required by this bound in `needs_coroutine`
-
-error: aborting due to 3 previous errors
-
-Some errors have detailed explanations: E0271, E0277.
-For more information about an error, try `rustc --explain E0271`.
diff --git a/tests/ui/traits/new-solver/coroutine.rs b/tests/ui/traits/new-solver/coroutine.rs
deleted file mode 100644
index af16f70fb..000000000
--- a/tests/ui/traits/new-solver/coroutine.rs
+++ /dev/null
@@ -1,32 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// edition: 2021
-// revisions: pass fail
-//[pass] check-pass
-
-#![feature(coroutine_trait, coroutines)]
-
-use std::ops::Coroutine;
-
-struct A;
-struct B;
-struct C;
-
-fn needs_coroutine(_: impl Coroutine<A, Yield = B, Return = C>) {}
-
-#[cfg(fail)]
-fn main() {
- needs_coroutine(|| {
- //[fail]~^ ERROR Coroutine<A>` is not satisfied
- //[fail]~| ERROR as Coroutine<A>>::Yield == B`
- //[fail]~| ERROR as Coroutine<A>>::Return == C`
- yield ();
- });
-}
-
-#[cfg(pass)]
-fn main() {
- needs_coroutine(|_: A| {
- let _: A = yield B;
- C
- })
-}
diff --git a/tests/ui/traits/new-solver/cycles/coinduction/fixpoint-exponential-growth.rs b/tests/ui/traits/new-solver/cycles/coinduction/fixpoint-exponential-growth.rs
deleted file mode 100644
index 44e763ef9..000000000
--- a/tests/ui/traits/new-solver/cycles/coinduction/fixpoint-exponential-growth.rs
+++ /dev/null
@@ -1,31 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-
-// Proving `W<?0>: Trait` instantiates `?0` with `(W<?1>, W<?2>)` and then
-// proves `W<?1>: Trait` and `W<?2>: Trait`, resulting in a coinductive cycle.
-//
-// Proving coinductive cycles runs until we reach a fixpoint. This fixpoint is
-// never reached here and each step doubles the amount of nested obligations.
-//
-// This previously caused a hang in the trait solver, see
-// https://github.com/rust-lang/trait-system-refactor-initiative/issues/13.
-
-#![feature(rustc_attrs)]
-
-#[rustc_coinductive]
-trait Trait {}
-
-struct W<T>(T);
-
-impl<T, U> Trait for W<(W<T>, W<U>)>
-where
- W<T>: Trait,
- W<U>: Trait,
-{
-}
-
-fn impls<T: Trait>() {}
-
-fn main() {
- impls::<W<_>>();
- //~^ ERROR overflow evaluating the requirement
-}
diff --git a/tests/ui/traits/new-solver/cycles/coinduction/fixpoint-exponential-growth.stderr b/tests/ui/traits/new-solver/cycles/coinduction/fixpoint-exponential-growth.stderr
deleted file mode 100644
index 1ac0e2977..000000000
--- a/tests/ui/traits/new-solver/cycles/coinduction/fixpoint-exponential-growth.stderr
+++ /dev/null
@@ -1,16 +0,0 @@
-error[E0275]: overflow evaluating the requirement `W<_>: Trait`
- --> $DIR/fixpoint-exponential-growth.rs:29:13
- |
-LL | impls::<W<_>>();
- | ^^^^
- |
- = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`fixpoint_exponential_growth`)
-note: required by a bound in `impls`
- --> $DIR/fixpoint-exponential-growth.rs:26:13
- |
-LL | fn impls<T: Trait>() {}
- | ^^^^^ required by this bound in `impls`
-
-error: aborting due to previous error
-
-For more information about this error, try `rustc --explain E0275`.
diff --git a/tests/ui/traits/new-solver/cycles/coinduction/incompleteness-unstable-result.rs b/tests/ui/traits/new-solver/cycles/coinduction/incompleteness-unstable-result.rs
deleted file mode 100644
index 0cd14f05c..000000000
--- a/tests/ui/traits/new-solver/cycles/coinduction/incompleteness-unstable-result.rs
+++ /dev/null
@@ -1,69 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-#![feature(rustc_attrs)]
-
-// This test is incredibly subtle. At its core the goal is to get a coinductive cycle,
-// which, depending on its root goal, either holds or errors. We achieve this by getting
-// incomplete inference via a `ParamEnv` candidate in the `A<T>` impl and required
-// inference from an `Impl` candidate in the `B<T>` impl.
-//
-// To make global cache accesses stronger than the guidance from the where-bounds, we add
-// another coinductive cycle from `A<T>: Trait<U, V, D>` to `A<T>: Trait<U, D, V>` and only
-// constrain `D` directly. This means that any candidates which rely on `V` only make
-// progress in the second iteration, allowing a cache access in the first iteration to take
-// precedence.
-//
-// tl;dr: our caching of coinductive cycles was broken and this is a regression
-// test for that.
-
-#[rustc_coinductive]
-trait Trait<T: ?Sized, V: ?Sized, D: ?Sized> {}
-struct A<T: ?Sized>(*const T);
-struct B<T: ?Sized>(*const T);
-
-trait IncompleteGuidance<T: ?Sized, V: ?Sized> {}
-impl<T: ?Sized, U: ?Sized + 'static> IncompleteGuidance<U, u8> for T {}
-impl<T: ?Sized, U: ?Sized + 'static> IncompleteGuidance<U, i8> for T {}
-impl<T: ?Sized, U: ?Sized + 'static> IncompleteGuidance<U, i16> for T {}
-
-trait ImplGuidance<T: ?Sized, V: ?Sized> {}
-impl<T: ?Sized> ImplGuidance<u32, u8> for T {}
-impl<T: ?Sized> ImplGuidance<i32, i8> for T {}
-
-impl<T: ?Sized, U: ?Sized, V: ?Sized, D: ?Sized> Trait<U, V, D> for A<T>
-where
- T: IncompleteGuidance<U, V>,
- A<T>: Trait<U, D, V>,
- B<T>: Trait<U, V, D>,
- (): ToU8<D>,
-{
-}
-
-trait ToU8<T: ?Sized> {}
-impl ToU8<u8> for () {}
-
-impl<T: ?Sized, U: ?Sized, V: ?Sized, D: ?Sized> Trait<U, V, D> for B<T>
-where
- T: ImplGuidance<U, V>,
- A<T>: Trait<U, V, D>,
-{
-}
-
-fn impls_trait<T: ?Sized + Trait<U, V, D>, U: ?Sized, V: ?Sized, D: ?Sized>() {}
-
-fn with_bound<X>()
-where
- X: IncompleteGuidance<i32, u8>,
- X: IncompleteGuidance<u32, i8>,
- X: IncompleteGuidance<u32, i16>,
-{
- impls_trait::<B<X>, _, _, _>(); // entering the cycle from `B` works
-
- // entering the cycle from `A` fails, but would work if we were to use the cache
- // result of `B<X>`.
- impls_trait::<A<X>, _, _, _>();
- //~^ ERROR the trait bound `A<X>: Trait<_, _, _>` is not satisfied
-}
-
-fn main() {
- with_bound::<u32>();
-}
diff --git a/tests/ui/traits/new-solver/cycles/coinduction/incompleteness-unstable-result.stderr b/tests/ui/traits/new-solver/cycles/coinduction/incompleteness-unstable-result.stderr
deleted file mode 100644
index f1871ff05..000000000
--- a/tests/ui/traits/new-solver/cycles/coinduction/incompleteness-unstable-result.stderr
+++ /dev/null
@@ -1,16 +0,0 @@
-error[E0277]: the trait bound `A<X>: Trait<_, _, _>` is not satisfied
- --> $DIR/incompleteness-unstable-result.rs:63:19
- |
-LL | impls_trait::<A<X>, _, _, _>();
- | ^^^^ the trait `Trait<_, _, _>` is not implemented for `A<X>`
- |
- = help: the trait `Trait<U, V, D>` is implemented for `A<T>`
-note: required by a bound in `impls_trait`
- --> $DIR/incompleteness-unstable-result.rs:51:28
- |
-LL | fn impls_trait<T: ?Sized + Trait<U, V, D>, U: ?Sized, V: ?Sized, D: ?Sized>() {}
- | ^^^^^^^^^^^^^^ required by this bound in `impls_trait`
-
-error: aborting due to previous error
-
-For more information about this error, try `rustc --explain E0277`.
diff --git a/tests/ui/traits/new-solver/cycles/double-cycle-inductive-coinductive.rs b/tests/ui/traits/new-solver/cycles/double-cycle-inductive-coinductive.rs
deleted file mode 100644
index 5617e45ad..000000000
--- a/tests/ui/traits/new-solver/cycles/double-cycle-inductive-coinductive.rs
+++ /dev/null
@@ -1,37 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-#![feature(rustc_attrs)]
-
-// Test that having both an inductive and a coinductive cycle
-// is handled correctly.
-
-#[rustc_coinductive]
-trait Trait {}
-impl<T: Inductive + Coinductive> Trait for T {}
-
-trait Inductive {}
-impl<T: Trait> Inductive for T {}
-#[rustc_coinductive]
-trait Coinductive {}
-impl<T: Trait> Coinductive for T {}
-
-fn impls_trait<T: Trait>() {}
-
-#[rustc_coinductive]
-trait TraitRev {}
-impl<T: CoinductiveRev + InductiveRev> TraitRev for T {}
-
-trait InductiveRev {}
-impl<T: TraitRev> InductiveRev for T {}
-#[rustc_coinductive]
-trait CoinductiveRev {}
-impl<T: TraitRev> CoinductiveRev for T {}
-
-fn impls_trait_rev<T: TraitRev>() {}
-
-fn main() {
- impls_trait::<()>();
- //~^ ERROR overflow evaluating the requirement
-
- impls_trait_rev::<()>();
- //~^ ERROR overflow evaluating the requirement
-}
diff --git a/tests/ui/traits/new-solver/cycles/double-cycle-inductive-coinductive.stderr b/tests/ui/traits/new-solver/cycles/double-cycle-inductive-coinductive.stderr
deleted file mode 100644
index a3404da51..000000000
--- a/tests/ui/traits/new-solver/cycles/double-cycle-inductive-coinductive.stderr
+++ /dev/null
@@ -1,29 +0,0 @@
-error[E0275]: overflow evaluating the requirement `(): Trait`
- --> $DIR/double-cycle-inductive-coinductive.rs:32:19
- |
-LL | impls_trait::<()>();
- | ^^
- |
- = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`double_cycle_inductive_coinductive`)
-note: required by a bound in `impls_trait`
- --> $DIR/double-cycle-inductive-coinductive.rs:17:19
- |
-LL | fn impls_trait<T: Trait>() {}
- | ^^^^^ required by this bound in `impls_trait`
-
-error[E0275]: overflow evaluating the requirement `(): TraitRev`
- --> $DIR/double-cycle-inductive-coinductive.rs:35:23
- |
-LL | impls_trait_rev::<()>();
- | ^^
- |
- = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`double_cycle_inductive_coinductive`)
-note: required by a bound in `impls_trait_rev`
- --> $DIR/double-cycle-inductive-coinductive.rs:29:23
- |
-LL | fn impls_trait_rev<T: TraitRev>() {}
- | ^^^^^^^^ required by this bound in `impls_trait_rev`
-
-error: aborting due to 2 previous errors
-
-For more information about this error, try `rustc --explain E0275`.
diff --git a/tests/ui/traits/new-solver/cycles/fixpoint-rerun-all-cycle-heads.rs b/tests/ui/traits/new-solver/cycles/fixpoint-rerun-all-cycle-heads.rs
deleted file mode 100644
index 279063923..000000000
--- a/tests/ui/traits/new-solver/cycles/fixpoint-rerun-all-cycle-heads.rs
+++ /dev/null
@@ -1,53 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-#![feature(rustc_attrs)]
-
-// Check that we correctly rerun the trait solver for heads of cycles,
-// even if they are not the root.
-
-struct A<T: ?Sized>(*const T);
-struct B<T: ?Sized>(*const T);
-struct C<T: ?Sized>(*const T);
-
-#[rustc_coinductive]
-trait Trait<'a, 'b> {}
-trait NotImplemented {}
-
-impl<'a, 'b, T: ?Sized> Trait<'a, 'b> for A<T> where B<T>: Trait<'a, 'b> {}
-
-// With this the root of `B<T>` is `A<T>`, even if the other impl does
-// not have a cycle with `A<T>`. This candidate never applies because of
-// the `A<T>: NotImplemented` bound.
-impl<'a, 'b, T: ?Sized> Trait<'a, 'b> for B<T>
-where
- A<T>: Trait<'a, 'b>,
- A<T>: NotImplemented,
-{
-}
-
-// This impl directly requires 'b to be equal to 'static.
-//
-// Because of the coinductive cycle through `C<T>` it also requires
-// 'a to be 'static.
-impl<'a, T: ?Sized> Trait<'a, 'static> for B<T>
-where
- C<T>: Trait<'a, 'a>,
-{}
-
-// In the first iteration of `B<T>: Trait<'a, 'b>` we don't add any
-// constraints here, only after setting the provisional result to require
-// `'b == 'static` do we also add that constraint for `'a`.
-impl<'a, 'b, T: ?Sized> Trait<'a, 'b> for C<T>
-where
- B<T>: Trait<'a, 'b>,
-{}
-
-fn impls_trait<'a, 'b, T: Trait<'a, 'b> + ?Sized>() {}
-
-fn check<'a, T: ?Sized>() {
- impls_trait::<'a, 'static, A<T>>();
- //~^ ERROR lifetime may not live long enough
-}
-
-fn main() {
- check::<()>();
-}
diff --git a/tests/ui/traits/new-solver/cycles/fixpoint-rerun-all-cycle-heads.stderr b/tests/ui/traits/new-solver/cycles/fixpoint-rerun-all-cycle-heads.stderr
deleted file mode 100644
index 4cbd08981..000000000
--- a/tests/ui/traits/new-solver/cycles/fixpoint-rerun-all-cycle-heads.stderr
+++ /dev/null
@@ -1,10 +0,0 @@
-error: lifetime may not live long enough
- --> $DIR/fixpoint-rerun-all-cycle-heads.rs:47:5
- |
-LL | fn check<'a, T: ?Sized>() {
- | -- lifetime `'a` defined here
-LL | impls_trait::<'a, 'static, A<T>>();
- | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ requires that `'a` must outlive `'static`
-
-error: aborting due to previous error
-
diff --git a/tests/ui/traits/new-solver/cycles/inductive-cycle-but-err.rs b/tests/ui/traits/new-solver/cycles/inductive-cycle-but-err.rs
deleted file mode 100644
index cda987898..000000000
--- a/tests/ui/traits/new-solver/cycles/inductive-cycle-but-err.rs
+++ /dev/null
@@ -1,48 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-#![feature(trivial_bounds, marker_trait_attr)]
-#![allow(trivial_bounds)]
-// This previously triggered a bug in the provisional cache.
-//
-// This has the proof tree
-// - `MultipleCandidates: Trait` proven via impl-one
-// - `MultipleNested: Trait` via impl
-// - `MultipleCandidates: Trait` (inductive cycle ~> OVERFLOW)
-// - `DoesNotImpl: Trait` (ERR)
-// - `MultipleCandidates: Trait` proven via impl-two
-// - `MultipleNested: Trait` (in provisional cache ~> OVERFLOW)
-//
-// We previously incorrectly treated the `MultipleCandidates: Trait` as
-// overflow because it was in the cache and reached via an inductive cycle.
-// It should be `NoSolution`.
-
-struct MultipleCandidates;
-struct MultipleNested;
-struct DoesNotImpl;
-
-#[marker]
-trait Trait {}
-
-// impl-one
-impl Trait for MultipleCandidates
-where
- MultipleNested: Trait
-{}
-
-// impl-two
-impl Trait for MultipleCandidates
-where
- MultipleNested: Trait,
-{}
-
-impl Trait for MultipleNested
-where
- MultipleCandidates: Trait,
- DoesNotImpl: Trait,
-{}
-
-fn impls_trait<T: Trait>() {}
-
-fn main() {
- impls_trait::<MultipleCandidates>();
- //~^ ERROR the trait bound `MultipleCandidates: Trait` is not satisfied
-}
diff --git a/tests/ui/traits/new-solver/cycles/inductive-cycle-but-err.stderr b/tests/ui/traits/new-solver/cycles/inductive-cycle-but-err.stderr
deleted file mode 100644
index 57227321a..000000000
--- a/tests/ui/traits/new-solver/cycles/inductive-cycle-but-err.stderr
+++ /dev/null
@@ -1,16 +0,0 @@
-error[E0277]: the trait bound `MultipleCandidates: Trait` is not satisfied
- --> $DIR/inductive-cycle-but-err.rs:46:19
- |
-LL | impls_trait::<MultipleCandidates>();
- | ^^^^^^^^^^^^^^^^^^ the trait `Trait` is not implemented for `MultipleCandidates`
- |
- = help: the trait `Trait` is implemented for `MultipleCandidates`
-note: required by a bound in `impls_trait`
- --> $DIR/inductive-cycle-but-err.rs:43:19
- |
-LL | fn impls_trait<T: Trait>() {}
- | ^^^^^ required by this bound in `impls_trait`
-
-error: aborting due to previous error
-
-For more information about this error, try `rustc --explain E0277`.
diff --git a/tests/ui/traits/new-solver/cycles/inductive-cycle-but-ok.rs b/tests/ui/traits/new-solver/cycles/inductive-cycle-but-ok.rs
deleted file mode 100644
index d4851eb69..000000000
--- a/tests/ui/traits/new-solver/cycles/inductive-cycle-but-ok.rs
+++ /dev/null
@@ -1,44 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-#![feature(trivial_bounds, marker_trait_attr)]
-#![allow(trivial_bounds)]
-
-// This previously triggered a bug in the provisional cache.
-//
-// This has the proof tree
-// - `Root: Trait` proven via impl
-// - `MultipleCandidates: Trait`
-// - candidate: overflow-impl
-// - `Root: Trait` (inductive cycle ~> OVERFLOW)
-// - candidate: trivial-impl ~> YES
-// - merge respones ~> YES
-// - `MultipleCandidates: Trait` (in provisional cache ~> OVERFLOW)
-//
-// We previously incorrectly treated the `MultipleCandidates: Trait` as
-// overflow because it was in the cache and reached via an inductive cycle.
-// It should be `YES`.
-
-struct Root;
-struct MultipleCandidates;
-
-#[marker]
-trait Trait {}
-impl Trait for Root
-where
- MultipleCandidates: Trait,
- MultipleCandidates: Trait,
-{}
-
-// overflow-impl
-impl Trait for MultipleCandidates
-where
- Root: Trait,
-{}
-// trivial-impl
-impl Trait for MultipleCandidates {}
-
-fn impls_trait<T: Trait>() {}
-
-fn main() {
- impls_trait::<Root>();
-}
diff --git a/tests/ui/traits/new-solver/cycles/inductive-cycle-discarded-coinductive-constraints.rs b/tests/ui/traits/new-solver/cycles/inductive-cycle-discarded-coinductive-constraints.rs
deleted file mode 100644
index 530e6d0ec..000000000
--- a/tests/ui/traits/new-solver/cycles/inductive-cycle-discarded-coinductive-constraints.rs
+++ /dev/null
@@ -1,36 +0,0 @@
-// check-pass
-// compile-flags: -Ztrait-solver=next
-#![feature(rustc_attrs, marker_trait_attr)]
-#[rustc_coinductive]
-trait Trait {}
-
-impl<T, U> Trait for (T, U)
-where
- (U, T): Trait,
- (T, U): Inductive,
- (): ConstrainToU32<T>,
-{}
-
-trait ConstrainToU32<T> {}
-impl ConstrainToU32<u32> for () {}
-
-// We only prefer the candidate without an inductive cycle
-// once the inductive cycle has the same constraints as the
-// other goal.
-#[marker]
-trait Inductive {}
-impl<T, U> Inductive for (T, U)
-where
- (T, U): Trait,
-{}
-
-impl Inductive for (u32, u32) {}
-
-fn impls_trait<T, U>()
-where
- (T, U): Trait,
-{}
-
-fn main() {
- impls_trait::<_, _>();
-}
diff --git a/tests/ui/traits/new-solver/cycles/inductive-not-on-stack.rs b/tests/ui/traits/new-solver/cycles/inductive-not-on-stack.rs
deleted file mode 100644
index f06b98a79..000000000
--- a/tests/ui/traits/new-solver/cycles/inductive-not-on-stack.rs
+++ /dev/null
@@ -1,46 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-#![feature(rustc_attrs, trivial_bounds)]
-
-// We have to be careful here:
-//
-// We either have the provisional result of `A -> B -> A` on the
-// stack, which is a fully coinductive cycle. Accessing the
-// provisional result for `B` as part of the `A -> C -> B -> A` cycle
-// has to make sure we don't just use the result of `A -> B -> A` as the
-// new cycle is inductive.
-//
-// Alternatively, if we have `A -> C -> A` first, then `A -> B -> A` has
-// a purely inductive stack, so something could also go wrong here.
-
-#[rustc_coinductive]
-trait A {}
-#[rustc_coinductive]
-trait B {}
-trait C {}
-
-impl<T: B + C> A for T {}
-impl<T: A> B for T {}
-impl<T: B> C for T {}
-
-fn impls_a<T: A>() {}
-
-// The same test with reordered where clauses to make sure we're actually testing anything.
-#[rustc_coinductive]
-trait AR {}
-#[rustc_coinductive]
-trait BR {}
-trait CR {}
-
-impl<T: CR + BR> AR for T {}
-impl<T: AR> BR for T {}
-impl<T: BR> CR for T {}
-
-fn impls_ar<T: AR>() {}
-
-fn main() {
- impls_a::<()>();
- //~^ ERROR overflow evaluating the requirement `(): A`
-
- impls_ar::<()>();
- //~^ ERROR overflow evaluating the requirement `(): AR`
-}
diff --git a/tests/ui/traits/new-solver/cycles/inductive-not-on-stack.stderr b/tests/ui/traits/new-solver/cycles/inductive-not-on-stack.stderr
deleted file mode 100644
index 859b3f3f1..000000000
--- a/tests/ui/traits/new-solver/cycles/inductive-not-on-stack.stderr
+++ /dev/null
@@ -1,29 +0,0 @@
-error[E0275]: overflow evaluating the requirement `(): A`
- --> $DIR/inductive-not-on-stack.rs:41:15
- |
-LL | impls_a::<()>();
- | ^^
- |
- = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`inductive_not_on_stack`)
-note: required by a bound in `impls_a`
- --> $DIR/inductive-not-on-stack.rs:25:15
- |
-LL | fn impls_a<T: A>() {}
- | ^ required by this bound in `impls_a`
-
-error[E0275]: overflow evaluating the requirement `(): AR`
- --> $DIR/inductive-not-on-stack.rs:44:16
- |
-LL | impls_ar::<()>();
- | ^^
- |
- = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`inductive_not_on_stack`)
-note: required by a bound in `impls_ar`
- --> $DIR/inductive-not-on-stack.rs:38:16
- |
-LL | fn impls_ar<T: AR>() {}
- | ^^ required by this bound in `impls_ar`
-
-error: aborting due to 2 previous errors
-
-For more information about this error, try `rustc --explain E0275`.
diff --git a/tests/ui/traits/new-solver/cycles/leak-check-coinductive-cycle.rs b/tests/ui/traits/new-solver/cycles/leak-check-coinductive-cycle.rs
deleted file mode 100644
index a6d318726..000000000
--- a/tests/ui/traits/new-solver/cycles/leak-check-coinductive-cycle.rs
+++ /dev/null
@@ -1,33 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-#![feature(rustc_attrs)]
-
-#[rustc_coinductive]
-trait Trait<T> {}
-impl<'a, 'b, T> Trait<T> for (&'a (), &'b ())
-where
- 'b: 'a,
- &'a (): Trait<T>,
-{}
-
-impl Trait<i32> for &'static () {}
-impl<'a> Trait<u32> for &'a ()
-where
- for<'b> (&'a (), &'b ()): Trait<u32>,
-{}
-
-
-fn impls_trait<T: Trait<U>, U>() {}
-
-fn main() {
- // This infers to `impls_trait::<(&'static (), &'static ()), i32>();`
- //
- // In the first attempt we have 2 candidates for `&'a (): Trait<_>`
- // and we get ambiguity. The result is therefore ambiguity with a `'b: 'a`
- // constraint. The next attempt then uses that provisional result when
- // trying to apply `impl<'a> Trait<u32> for &'a ()`. This means we get a
- // `for<'b> 'b: 'a` bound which fails the leak check. Because of this we
- // end up with a single impl for `&'a (): Trait<_>` which infers `_` to `i32`
- // and succeeds.
- impls_trait::<(&(), &()), _>();
-}
diff --git a/tests/ui/traits/new-solver/cycles/provisional-result-done.rs b/tests/ui/traits/new-solver/cycles/provisional-result-done.rs
deleted file mode 100644
index 589d34dd7..000000000
--- a/tests/ui/traits/new-solver/cycles/provisional-result-done.rs
+++ /dev/null
@@ -1,33 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-// This tests checks that we update results in the provisional cache when
-// we pop a goal from the stack.
-#![feature(auto_traits)]
-auto trait Coinductive {}
-struct Foo<T>(T);
-struct Bar<T>(T);
-
-impl<T> Coinductive for Foo<T>
-where
- Bar<T>: Coinductive
-{}
-
-impl<T> Coinductive for Bar<T>
-where
- Foo<T>: Coinductive,
- Bar<T>: ConstrainInfer,
-{}
-
-trait ConstrainInfer {}
-impl ConstrainInfer for Bar<u8> {}
-impl ConstrainInfer for Foo<u16> {}
-
-fn impls<T: Coinductive>() -> T { todo!() }
-
-fn constrain<T: ConstrainInfer>(_: T) {}
-
-fn main() {
- // This should constrain `_` to `u8`.
- impls::<Foo<_>>();
-}
diff --git a/tests/ui/traits/new-solver/deduce-closure-signature-after-normalization.rs b/tests/ui/traits/new-solver/deduce-closure-signature-after-normalization.rs
deleted file mode 100644
index 51f62bc23..000000000
--- a/tests/ui/traits/new-solver/deduce-closure-signature-after-normalization.rs
+++ /dev/null
@@ -1,10 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-trait Foo {
- fn test() -> impl Fn(u32) -> u32 {
- |x| x.count_ones()
- }
-}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/deduce-ty-from-object.rs b/tests/ui/traits/new-solver/deduce-ty-from-object.rs
deleted file mode 100644
index 7398bce7b..000000000
--- a/tests/ui/traits/new-solver/deduce-ty-from-object.rs
+++ /dev/null
@@ -1,6 +0,0 @@
-// check-pass
-// compile-flags: -Ztrait-solver=next
-
-fn main() {
- let x: Box<dyn Iterator<Item = ()>> = Box::new(std::iter::empty());
-}
diff --git a/tests/ui/traits/new-solver/dedup-regions.rs b/tests/ui/traits/new-solver/dedup-regions.rs
deleted file mode 100644
index f376f39a5..000000000
--- a/tests/ui/traits/new-solver/dedup-regions.rs
+++ /dev/null
@@ -1,31 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-struct A(*mut ());
-
-unsafe impl Send for A where A: 'static {}
-
-macro_rules! mk {
- ($name:ident $ty:ty) => {
- struct $name($ty, $ty, $ty, $ty, $ty, $ty, $ty, $ty, $ty, $ty);
- };
-}
-
-mk!(B A);
-mk!(C B);
-mk!(D C);
-mk!(E D);
-mk!(F E);
-mk!(G F);
-mk!(H G);
-mk!(I H);
-mk!(J I);
-mk!(K J);
-mk!(L K);
-mk!(M L);
-
-fn needs_send<T: Send>() {}
-
-fn main() {
- needs_send::<M>();
-}
diff --git a/tests/ui/traits/new-solver/destruct.rs b/tests/ui/traits/new-solver/destruct.rs
deleted file mode 100644
index 30d7777b7..000000000
--- a/tests/ui/traits/new-solver/destruct.rs
+++ /dev/null
@@ -1,13 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-#![feature(const_trait_impl)]
-
-fn foo(_: impl std::marker::Destruct) {}
-
-struct MyAdt;
-
-fn main() {
- foo(1);
- foo(MyAdt);
-}
diff --git a/tests/ui/traits/new-solver/dont-coerce-infer-to-dyn.rs b/tests/ui/traits/new-solver/dont-coerce-infer-to-dyn.rs
deleted file mode 100644
index c2ac80459..000000000
--- a/tests/ui/traits/new-solver/dont-coerce-infer-to-dyn.rs
+++ /dev/null
@@ -1,17 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-use std::fmt::Display;
-use std::rc::Rc;
-
-fn mk<T: ?Sized>(t: Option<&T>) -> Rc<T> {
- todo!()
-}
-
-fn main() {
- let mut x = None;
- let y = mk(x);
- // Don't treat the line below as a unsize coercion `Rc<?0> ~> Rc<dyn Display>`
- let z: Rc<dyn Display> = y;
- x = Some(&1 as &dyn Display);
-}
diff --git a/tests/ui/traits/new-solver/dont-elaborate-for-projections.rs b/tests/ui/traits/new-solver/dont-elaborate-for-projections.rs
deleted file mode 100644
index e60825006..000000000
--- a/tests/ui/traits/new-solver/dont-elaborate-for-projections.rs
+++ /dev/null
@@ -1,12 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-trait Iter<'a, I: 'a>: Iterator<Item = &'a I> {}
-
-fn needs_iter<'a, T: Iter<'a, I> + ?Sized, I: 'a>(_: &T) {}
-
-fn test(x: &dyn Iter<'_, ()>) {
- needs_iter(x);
-}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/dont-ice-on-assoc-projection.rs b/tests/ui/traits/new-solver/dont-ice-on-assoc-projection.rs
deleted file mode 100644
index b9798c79d..000000000
--- a/tests/ui/traits/new-solver/dont-ice-on-assoc-projection.rs
+++ /dev/null
@@ -1,19 +0,0 @@
-// compile-flags: -Ztrait-solver=next-coherence
-
-// Makes sure we don't ICE on associated const projection when the feature gate
-// is not enabled, since we should avoid encountering ICEs on stable if possible.
-
-trait Bar {
- const ASSOC: usize;
-}
-impl Bar for () {
- const ASSOC: usize = 1;
-}
-
-trait Foo {}
-impl Foo for () {}
-impl<T> Foo for T where T: Bar<ASSOC = 0> {}
-//~^ ERROR associated const equality is incomplete
-//~| ERROR conflicting implementations of trait `Foo` for type `()`
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/dont-ice-on-assoc-projection.stderr b/tests/ui/traits/new-solver/dont-ice-on-assoc-projection.stderr
deleted file mode 100644
index 368f5cd0c..000000000
--- a/tests/ui/traits/new-solver/dont-ice-on-assoc-projection.stderr
+++ /dev/null
@@ -1,21 +0,0 @@
-error[E0658]: associated const equality is incomplete
- --> $DIR/dont-ice-on-assoc-projection.rs:15:32
- |
-LL | impl<T> Foo for T where T: Bar<ASSOC = 0> {}
- | ^^^^^^^^^
- |
- = note: see issue #92827 <https://github.com/rust-lang/rust/issues/92827> for more information
- = help: add `#![feature(associated_const_equality)]` to the crate attributes to enable
-
-error[E0119]: conflicting implementations of trait `Foo` for type `()`
- --> $DIR/dont-ice-on-assoc-projection.rs:15:1
- |
-LL | impl Foo for () {}
- | --------------- first implementation here
-LL | impl<T> Foo for T where T: Bar<ASSOC = 0> {}
- | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ conflicting implementation for `()`
-
-error: aborting due to 2 previous errors
-
-Some errors have detailed explanations: E0119, E0658.
-For more information about an error, try `rustc --explain E0119`.
diff --git a/tests/ui/traits/new-solver/dont-loop-fulfill-on-region-constraints.rs b/tests/ui/traits/new-solver/dont-loop-fulfill-on-region-constraints.rs
deleted file mode 100644
index b241e3bf8..000000000
--- a/tests/ui/traits/new-solver/dont-loop-fulfill-on-region-constraints.rs
+++ /dev/null
@@ -1,32 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-trait Eq<'a, 'b, T> {}
-
-trait Ambig {}
-impl Ambig for () {}
-
-impl<'a, T> Eq<'a, 'a, T> for () where T: Ambig {}
-
-fn eq<'a, 'b, T>(t: T)
-where
- (): Eq<'a, 'b, T>,
-{
-}
-
-fn test<'r>() {
- let mut x = Default::default();
-
- // When we evaluate `(): Eq<'r, 'r, ?0>` we uniquify the regions.
- // That leads us to evaluate `(): Eq<'?0, '?1, ?0>`. The response of this
- // will be ambiguous (because `?0: Ambig` is ambig) and also not an "identity"
- // response, since the region constraints will contain `'?0 == '?1` (so
- // `is_changed` will return true). Since it's both ambig and changed,
- // fulfillment will both re-register the goal AND loop again. This hits the
- // overflow limit. This should neither be considered overflow, nor ICE.
- eq::<'r, 'r, _>(x);
-
- x = ();
-}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/dont-normalize-proj-with-error.rs b/tests/ui/traits/new-solver/dont-normalize-proj-with-error.rs
deleted file mode 100644
index 19a6fa990..000000000
--- a/tests/ui/traits/new-solver/dont-normalize-proj-with-error.rs
+++ /dev/null
@@ -1,22 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-
-// Test that we don't incorrectly leak unconstrained inference variables
-// if the projection contained an error. This caused an ICE in writeback.
-
-trait Mirror {
- type Assoc: ?Sized;
-}
-
-struct Wrapper<T: ?Sized>(T);
-impl<T: ?Sized> Mirror for Wrapper<T> {
- type Assoc = T;
-}
-
-fn mirror<W: Mirror>(_: W) -> Box<W::Assoc> { todo!() }
-
-fn type_error() -> TypeError { todo!() }
-//~^ ERROR cannot find type `TypeError` in this scope
-
-fn main() {
- let x = mirror(type_error());
-}
diff --git a/tests/ui/traits/new-solver/dont-normalize-proj-with-error.stderr b/tests/ui/traits/new-solver/dont-normalize-proj-with-error.stderr
deleted file mode 100644
index 5a7459ec1..000000000
--- a/tests/ui/traits/new-solver/dont-normalize-proj-with-error.stderr
+++ /dev/null
@@ -1,9 +0,0 @@
-error[E0412]: cannot find type `TypeError` in this scope
- --> $DIR/dont-normalize-proj-with-error.rs:17:20
- |
-LL | fn type_error() -> TypeError { todo!() }
- | ^^^^^^^^^ not found in this scope
-
-error: aborting due to previous error
-
-For more information about this error, try `rustc --explain E0412`.
diff --git a/tests/ui/traits/new-solver/dont-remap-tait-substs.rs b/tests/ui/traits/new-solver/dont-remap-tait-substs.rs
deleted file mode 100644
index 309bee8aa..000000000
--- a/tests/ui/traits/new-solver/dont-remap-tait-substs.rs
+++ /dev/null
@@ -1,19 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-// Makes sure we don't prepopulate the MIR typeck of `define`
-// with `Foo<T, U> = T`, but instead, `Foo<B, A> = B`, so that
-// the param-env predicates actually apply.
-
-#![feature(type_alias_impl_trait)]
-
-type Foo<T: Send, U> = impl NeedsSend<T>;
-
-trait NeedsSend<T> {}
-impl<T: Send> NeedsSend<T> for T {}
-
-fn define<A, B: Send>(a: A, b: B, _: Foo<B, A>) {
- let y: Option<Foo<B, A>> = Some(b);
-}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/dont-type_of-tait-in-defining-scope.not_send.stderr b/tests/ui/traits/new-solver/dont-type_of-tait-in-defining-scope.not_send.stderr
deleted file mode 100644
index a31bfd958..000000000
--- a/tests/ui/traits/new-solver/dont-type_of-tait-in-defining-scope.not_send.stderr
+++ /dev/null
@@ -1,16 +0,0 @@
-error[E0283]: type annotations needed: cannot satisfy `Foo: Send`
- --> $DIR/dont-type_of-tait-in-defining-scope.rs:16:18
- |
-LL | needs_send::<Foo>();
- | ^^^
- |
- = note: cannot satisfy `Foo: Send`
-note: required by a bound in `needs_send`
- --> $DIR/dont-type_of-tait-in-defining-scope.rs:13:18
- |
-LL | fn needs_send<T: Send>() {}
- | ^^^^ required by this bound in `needs_send`
-
-error: aborting due to previous error
-
-For more information about this error, try `rustc --explain E0283`.
diff --git a/tests/ui/traits/new-solver/dont-type_of-tait-in-defining-scope.rs b/tests/ui/traits/new-solver/dont-type_of-tait-in-defining-scope.rs
deleted file mode 100644
index 08f14d749..000000000
--- a/tests/ui/traits/new-solver/dont-type_of-tait-in-defining-scope.rs
+++ /dev/null
@@ -1,24 +0,0 @@
-// revisions: is_send not_send
-// compile-flags: -Ztrait-solver=next
-//[is_send] check-pass
-
-#![feature(type_alias_impl_trait)]
-
-#[cfg(is_send)]
-type Foo = impl Send;
-
-#[cfg(not_send)]
-type Foo = impl Sized;
-
-fn needs_send<T: Send>() {}
-
-fn test(_: Foo) {
- needs_send::<Foo>();
- //[not_send]~^ ERROR type annotations needed: cannot satisfy `Foo: Send`
-}
-
-fn defines(_: Foo) {
- let _: Foo = ();
-}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/dyn-any-dont-prefer-impl.rs b/tests/ui/traits/new-solver/dyn-any-dont-prefer-impl.rs
deleted file mode 100644
index af35a6195..000000000
--- a/tests/ui/traits/new-solver/dyn-any-dont-prefer-impl.rs
+++ /dev/null
@@ -1,17 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-// Test that selection prefers the builtin trait object impl for `Any`
-// instead of the user defined impl. Both impls apply to the trait
-// object.
-
-use std::any::Any;
-
-fn needs_usize(_: &usize) {}
-
-fn main() {
- let x: &dyn Any = &1usize;
- if let Some(x) = x.downcast_ref::<usize>() {
- needs_usize(x);
- }
-}
diff --git a/tests/ui/traits/new-solver/elaborate-item-bounds.rs b/tests/ui/traits/new-solver/elaborate-item-bounds.rs
deleted file mode 100644
index 076aefcf8..000000000
--- a/tests/ui/traits/new-solver/elaborate-item-bounds.rs
+++ /dev/null
@@ -1,12 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-trait Foo {
- type Bar: Bar;
-}
-
-trait Bar: Baz {}
-
-trait Baz {}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/equating-projection-cyclically.rs b/tests/ui/traits/new-solver/equating-projection-cyclically.rs
deleted file mode 100644
index 2668da1b7..000000000
--- a/tests/ui/traits/new-solver/equating-projection-cyclically.rs
+++ /dev/null
@@ -1,28 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-
-trait Test {
- type Assoc;
-}
-
-fn transform<T: Test>(x: Inv<T>) -> Inv<T::Assoc> {
- todo!()
-}
-
-impl Test for i32 {
- type Assoc = i32;
-}
-
-impl Test for String {
- type Assoc = String;
-}
-
-struct Inv<T>(Option<*mut T>);
-
-fn main() {
- let mut x: Inv<_> = Inv(None);
- // This ends up equating `Inv<?x>` with `Inv<<?x as Test>::Assoc>`
- // which fails the occurs check when generalizing `?x`.
- x = transform(x);
- //~^ ERROR mismatched types
- x = Inv::<i32>(None);
-}
diff --git a/tests/ui/traits/new-solver/equating-projection-cyclically.stderr b/tests/ui/traits/new-solver/equating-projection-cyclically.stderr
deleted file mode 100644
index 6031d4f08..000000000
--- a/tests/ui/traits/new-solver/equating-projection-cyclically.stderr
+++ /dev/null
@@ -1,9 +0,0 @@
-error[E0308]: mismatched types
- --> $DIR/equating-projection-cyclically.rs:25:9
- |
-LL | x = transform(x);
- | ^^^^^^^^^^^^ cyclic type of infinite size
-
-error: aborting due to previous error
-
-For more information about this error, try `rustc --explain E0308`.
diff --git a/tests/ui/traits/new-solver/escaping-bound-vars-in-writeback-normalization.rs b/tests/ui/traits/new-solver/escaping-bound-vars-in-writeback-normalization.rs
deleted file mode 100644
index 29784c32a..000000000
--- a/tests/ui/traits/new-solver/escaping-bound-vars-in-writeback-normalization.rs
+++ /dev/null
@@ -1,18 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-trait Trivial {
- type Assoc;
-}
-
-impl<T: ?Sized> Trivial for T {
- type Assoc = ();
-}
-
-fn main() {
- // During writeback, we call `normalize_erasing_regions`, which will walk past
- // the `for<'a>` binder and try to normalize `<&'a () as Trivial>::Assoc` directly.
- // We need to handle this case in the new deep normalizer similarly to how it
- // is handled in the old solver.
- let x: Option<for<'a> fn(<&'a () as Trivial>::Assoc)> = None;
-}
diff --git a/tests/ui/traits/new-solver/float-canonical.rs b/tests/ui/traits/new-solver/float-canonical.rs
deleted file mode 100644
index b8748cd43..000000000
--- a/tests/ui/traits/new-solver/float-canonical.rs
+++ /dev/null
@@ -1,8 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-fn foo(x: f64) {
- let y = x + 1.0;
-}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/fn-trait-closure.rs b/tests/ui/traits/new-solver/fn-trait-closure.rs
deleted file mode 100644
index bd65737ee..000000000
--- a/tests/ui/traits/new-solver/fn-trait-closure.rs
+++ /dev/null
@@ -1,8 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-fn require_fn(_: impl Fn() -> i32) {}
-
-fn main() {
- require_fn(|| -> i32 { 1i32 });
-}
diff --git a/tests/ui/traits/new-solver/fn-trait.rs b/tests/ui/traits/new-solver/fn-trait.rs
deleted file mode 100644
index 0a19e6265..000000000
--- a/tests/ui/traits/new-solver/fn-trait.rs
+++ /dev/null
@@ -1,32 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-
-fn require_fn(_: impl Fn() -> i32) {}
-
-fn f() -> i32 {
- 1i32
-}
-
-extern "C" fn g() -> i32 {
- 2i32
-}
-
-unsafe fn h() -> i32 {
- 2i32
-}
-
-fn main() {
- require_fn(f);
- require_fn(f as fn() -> i32);
- require_fn(f as unsafe fn() -> i32);
- //~^ ERROR: expected a `Fn()` closure, found `unsafe fn() -> i32`
- //~| ERROR: type mismatch resolving `<unsafe fn() -> i32 as FnOnce<()>>::Output == i32`
- require_fn(g);
- //~^ ERROR: expected a `Fn()` closure, found `extern "C" fn() -> i32 {g}`
- //~| ERROR: type mismatch resolving `<extern "C" fn() -> i32 {g} as FnOnce<()>>::Output == i32`
- require_fn(g as extern "C" fn() -> i32);
- //~^ ERROR: expected a `Fn()` closure, found `extern "C" fn() -> i32`
- //~| ERROR: type mismatch resolving `<extern "C" fn() -> i32 as FnOnce<()>>::Output == i32`
- require_fn(h);
- //~^ ERROR: expected a `Fn()` closure, found `unsafe fn() -> i32 {h}`
- //~| ERROR: type mismatch resolving `<unsafe fn() -> i32 {h} as FnOnce<()>>::Output == i32`
-}
diff --git a/tests/ui/traits/new-solver/fn-trait.stderr b/tests/ui/traits/new-solver/fn-trait.stderr
deleted file mode 100644
index e33487235..000000000
--- a/tests/ui/traits/new-solver/fn-trait.stderr
+++ /dev/null
@@ -1,126 +0,0 @@
-error[E0277]: expected a `Fn()` closure, found `unsafe fn() -> i32`
- --> $DIR/fn-trait.rs:20:16
- |
-LL | require_fn(f as unsafe fn() -> i32);
- | ---------- ^^^^^^^^^^^^^^^^^^^^^^^ call the function in a closure: `|| unsafe { /* code */ }`
- | |
- | required by a bound introduced by this call
- |
- = help: the trait `Fn<()>` is not implemented for `unsafe fn() -> i32`
- = note: unsafe function cannot be called generically without an unsafe block
- = note: wrap the `unsafe fn() -> i32` in a closure with no arguments: `|| { /* code */ }`
-note: required by a bound in `require_fn`
- --> $DIR/fn-trait.rs:3:23
- |
-LL | fn require_fn(_: impl Fn() -> i32) {}
- | ^^^^^^^^^^^ required by this bound in `require_fn`
-
-error[E0271]: type mismatch resolving `<unsafe fn() -> i32 as FnOnce<()>>::Output == i32`
- --> $DIR/fn-trait.rs:20:16
- |
-LL | require_fn(f as unsafe fn() -> i32);
- | ---------- ^^^^^^^^^^^^^^^^^^^^^^^ types differ
- | |
- | required by a bound introduced by this call
- |
-note: required by a bound in `require_fn`
- --> $DIR/fn-trait.rs:3:31
- |
-LL | fn require_fn(_: impl Fn() -> i32) {}
- | ^^^ required by this bound in `require_fn`
-
-error[E0277]: expected a `Fn()` closure, found `extern "C" fn() -> i32 {g}`
- --> $DIR/fn-trait.rs:23:16
- |
-LL | require_fn(g);
- | ---------- ^ expected an `Fn()` closure, found `extern "C" fn() -> i32 {g}`
- | |
- | required by a bound introduced by this call
- |
- = help: the trait `Fn<()>` is not implemented for fn item `extern "C" fn() -> i32 {g}`
- = note: wrap the `extern "C" fn() -> i32 {g}` in a closure with no arguments: `|| { /* code */ }`
-note: required by a bound in `require_fn`
- --> $DIR/fn-trait.rs:3:23
- |
-LL | fn require_fn(_: impl Fn() -> i32) {}
- | ^^^^^^^^^^^ required by this bound in `require_fn`
-
-error[E0271]: type mismatch resolving `<extern "C" fn() -> i32 {g} as FnOnce<()>>::Output == i32`
- --> $DIR/fn-trait.rs:23:16
- |
-LL | require_fn(g);
- | ---------- ^ types differ
- | |
- | required by a bound introduced by this call
- |
-note: required by a bound in `require_fn`
- --> $DIR/fn-trait.rs:3:31
- |
-LL | fn require_fn(_: impl Fn() -> i32) {}
- | ^^^ required by this bound in `require_fn`
-
-error[E0277]: expected a `Fn()` closure, found `extern "C" fn() -> i32`
- --> $DIR/fn-trait.rs:26:16
- |
-LL | require_fn(g as extern "C" fn() -> i32);
- | ---------- ^^^^^^^^^^^^^^^^^^^^^^^^^^^ expected an `Fn()` closure, found `extern "C" fn() -> i32`
- | |
- | required by a bound introduced by this call
- |
- = help: the trait `Fn<()>` is not implemented for `extern "C" fn() -> i32`
- = note: wrap the `extern "C" fn() -> i32` in a closure with no arguments: `|| { /* code */ }`
-note: required by a bound in `require_fn`
- --> $DIR/fn-trait.rs:3:23
- |
-LL | fn require_fn(_: impl Fn() -> i32) {}
- | ^^^^^^^^^^^ required by this bound in `require_fn`
-
-error[E0271]: type mismatch resolving `<extern "C" fn() -> i32 as FnOnce<()>>::Output == i32`
- --> $DIR/fn-trait.rs:26:16
- |
-LL | require_fn(g as extern "C" fn() -> i32);
- | ---------- ^^^^^^^^^^^^^^^^^^^^^^^^^^^ types differ
- | |
- | required by a bound introduced by this call
- |
-note: required by a bound in `require_fn`
- --> $DIR/fn-trait.rs:3:31
- |
-LL | fn require_fn(_: impl Fn() -> i32) {}
- | ^^^ required by this bound in `require_fn`
-
-error[E0277]: expected a `Fn()` closure, found `unsafe fn() -> i32 {h}`
- --> $DIR/fn-trait.rs:29:16
- |
-LL | require_fn(h);
- | ---------- ^ call the function in a closure: `|| unsafe { /* code */ }`
- | |
- | required by a bound introduced by this call
- |
- = help: the trait `Fn<()>` is not implemented for fn item `unsafe fn() -> i32 {h}`
- = note: unsafe function cannot be called generically without an unsafe block
- = note: wrap the `unsafe fn() -> i32 {h}` in a closure with no arguments: `|| { /* code */ }`
-note: required by a bound in `require_fn`
- --> $DIR/fn-trait.rs:3:23
- |
-LL | fn require_fn(_: impl Fn() -> i32) {}
- | ^^^^^^^^^^^ required by this bound in `require_fn`
-
-error[E0271]: type mismatch resolving `<unsafe fn() -> i32 {h} as FnOnce<()>>::Output == i32`
- --> $DIR/fn-trait.rs:29:16
- |
-LL | require_fn(h);
- | ---------- ^ types differ
- | |
- | required by a bound introduced by this call
- |
-note: required by a bound in `require_fn`
- --> $DIR/fn-trait.rs:3:31
- |
-LL | fn require_fn(_: impl Fn() -> i32) {}
- | ^^^ required by this bound in `require_fn`
-
-error: aborting due to 8 previous errors
-
-Some errors have detailed explanations: E0271, E0277.
-For more information about an error, try `rustc --explain E0271`.
diff --git a/tests/ui/traits/new-solver/generalize/generalize-proj-new-universe-index-1.rs b/tests/ui/traits/new-solver/generalize/generalize-proj-new-universe-index-1.rs
deleted file mode 100644
index b0b9b6bbd..000000000
--- a/tests/ui/traits/new-solver/generalize/generalize-proj-new-universe-index-1.rs
+++ /dev/null
@@ -1,73 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-// A minimization of an ambiguity when using typenum. See
-// https://github.com/rust-lang/trait-system-refactor-initiative/issues/55
-// for more details.
-trait Id {
- type Assoc: ?Sized;
-}
-impl<T: ?Sized> Id for T {
- type Assoc = T;
-}
-
-trait WithAssoc<T: ?Sized> {
- type Assoc: ?Sized;
-}
-
-
-struct Leaf;
-struct Wrapper<U: ?Sized>(U);
-
-impl<U: ?Sized> WithAssoc<U> for Leaf {
- type Assoc = U;
-}
-
-impl<Ul: ?Sized, Ur: ?Sized> WithAssoc<Wrapper<Ur>> for Wrapper<Ul>
-where
- Ul: WithAssoc<Ur>,
-{
- type Assoc = <<Ul as WithAssoc<Ur>>::Assoc as Id>::Assoc;
-}
-
-fn bound<T: ?Sized, U: ?Sized, V: ?Sized>()
-where
- T: WithAssoc<U, Assoc = V>,
-{
-}
-
-// normalize self type to `Wrapper<Leaf>`
-// This succeeds, HOWEVER, instantiating the query response previously
-// incremented the universe index counter.
-// equate impl headers:
-// <Wrapper<Leaf> as WithAssoc<<Wrapper<Leaf> as Id>::Assoc>>
-// <Wrapper<?2t> as WithAssoc<Wrapper<?3t>>>
-// ~> AliasRelate(<Wrapper<Leaf> as Id>::Assoc, Equate, Wrapper<?3t>)
-// add where bounds:
-// ~> Leaf: WithAssoc<?3t>
-// equate with assoc type:
-// ?0t
-// <Leaf as WithAssoc<?3t>>::Assoc as Id>::Assoc
-// ~> AliasRelate(
-// <<Leaf as WithAssoc<?3t>>::Assoc as Id>::Assoc,
-// Equate,
-// <<Leaf as WithAssoc<?4t>>::Assoc as Id>::Assoc,
-// )
-//
-// We do not reuse `?3t` during generalization because `?0t` cannot name `?4t` as we created
-// it after incrementing the universe index while normalizing the self type.
-//
-// evaluate_added_goals_and_make_query_response:
-// AliasRelate(<Wrapper<Leaf> as Id>::Assoc, Equate, Wrapper<?3t>)
-// YES, constrains ?3t to Leaf
-// AliasRelate(
-// <<Leaf as WithAssoc<Leaf>>::Assoc as Id>::Assoc,
-// Equate,
-// <<Leaf as WithAssoc<?4t>>::Assoc as Id>::Assoc,
-// )
-//
-// Normalizing <<Leaf as WithAssoc<?4t>>::Assoc as Id>::Assoc then *correctly*
-// results in ambiguity.
-fn main() {
- bound::<<Wrapper<Leaf> as Id>::Assoc, <Wrapper<Leaf> as Id>::Assoc, _>()
-}
diff --git a/tests/ui/traits/new-solver/generalize/generalize-proj-new-universe-index-2.rs b/tests/ui/traits/new-solver/generalize/generalize-proj-new-universe-index-2.rs
deleted file mode 100644
index 94d645a98..000000000
--- a/tests/ui/traits/new-solver/generalize/generalize-proj-new-universe-index-2.rs
+++ /dev/null
@@ -1,75 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// known-bug: trait-system-refactor-initiative#60
-
-// Generalizing a projection containing an inference variable
-// which cannot be named by the `root_vid` can result in ambiguity.
-//
-// Because we do not decrement the universe index when exiting a forall,
-// this can cause unexpected failures.
-//
-// See generalize-proj-new-universe-index-1.rs for more details.
-
-// For this reproduction we need:
-// - an inference variable with a lower universe
-// - enter a binder to increment the current universe
-// - create a new inference variable which is constrained by proving a goal
-// - equate a projection containing the new variable with the first variable
-// - generalization creates yet another inference variable which is then
-// part of an alias-relate, resulting this to fail with ambiguity.
-//
-// Because we need to enter the binder in-between the creation of the first
-// and second inference variable, this is easiest via
-// `assemble_candidates_after_normalizing_self_ty` because eagerly call
-// `try_evaluate_added_goals` there before creating the inference variables
-// for the impl parameters.
-trait Id {
- type Assoc: ?Sized;
-}
-impl<T: ?Sized> Id for T {
- type Assoc = T;
-}
-
-// By adding an higher ranked bound to the impl we currently
-// propagate this bound to the caller, forcing us to create a new
-// universe.
-trait IdHigherRankedBound {
- type Assoc: ?Sized;
-}
-
-impl<T: ?Sized> IdHigherRankedBound for T
-where
- for<'a> T: 'a,
-{
- type Assoc = T;
-}
-
-trait WithAssoc<T: ?Sized> {
- type Assoc: ?Sized;
-}
-
-
-struct Leaf;
-struct Wrapper<U: ?Sized>(U);
-struct Rigid;
-
-impl<U: ?Sized> WithAssoc<U> for Leaf {
- type Assoc = U;
-}
-
-
-impl<Ur: ?Sized> WithAssoc<Wrapper<Ur>> for Rigid
-where
- Leaf: WithAssoc<Ur>,
-{
- type Assoc = <<Leaf as WithAssoc<Ur>>::Assoc as Id>::Assoc;
-}
-
-fn bound<T: ?Sized, U: ?Sized, V: ?Sized>()
-where
- T: WithAssoc<U, Assoc = V>,
-{
-}
-
-fn main() {
- bound::<<Rigid as IdHigherRankedBound>::Assoc, <Wrapper<Leaf> as Id>::Assoc, _>()
-}
diff --git a/tests/ui/traits/new-solver/generalize/generalize-proj-new-universe-index-2.stderr b/tests/ui/traits/new-solver/generalize/generalize-proj-new-universe-index-2.stderr
deleted file mode 100644
index 9aa4f4531..000000000
--- a/tests/ui/traits/new-solver/generalize/generalize-proj-new-universe-index-2.stderr
+++ /dev/null
@@ -1,18 +0,0 @@
-error[E0284]: type annotations needed: cannot satisfy `<<Leaf as WithAssoc<_>>::Assoc as Id>::Assoc == <<Leaf as WithAssoc<_>>::Assoc as Id>::Assoc`
- --> $DIR/generalize-proj-new-universe-index-2.rs:74:5
- |
-LL | bound::<<Rigid as IdHigherRankedBound>::Assoc, <Wrapper<Leaf> as Id>::Assoc, _>()
- | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ cannot satisfy `<<Leaf as WithAssoc<_>>::Assoc as Id>::Assoc == <<Leaf as WithAssoc<_>>::Assoc as Id>::Assoc`
- |
-note: required by a bound in `bound`
- --> $DIR/generalize-proj-new-universe-index-2.rs:69:21
- |
-LL | fn bound<T: ?Sized, U: ?Sized, V: ?Sized>()
- | ----- required by a bound in this function
-LL | where
-LL | T: WithAssoc<U, Assoc = V>,
- | ^^^^^^^^^ required by this bound in `bound`
-
-error: aborting due to previous error
-
-For more information about this error, try `rustc --explain E0284`.
diff --git a/tests/ui/traits/new-solver/higher-ranked-dyn-bounds.rs b/tests/ui/traits/new-solver/higher-ranked-dyn-bounds.rs
deleted file mode 100644
index c886aeeda..000000000
--- a/tests/ui/traits/new-solver/higher-ranked-dyn-bounds.rs
+++ /dev/null
@@ -1,17 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-trait Trait<'a> {
- type Item: for<'b> Trait2<'b>;
-}
-
-trait Trait2<'a> {}
-impl Trait2<'_> for () {}
-
-fn needs_trait(_: Box<impl for<'a> Trait<'a> + ?Sized>) {}
-
-fn foo(x: Box<dyn for<'a> Trait<'a, Item = ()>>) {
- needs_trait(x);
-}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/int-var-alias-eq.rs b/tests/ui/traits/new-solver/int-var-alias-eq.rs
deleted file mode 100644
index 790197e2d..000000000
--- a/tests/ui/traits/new-solver/int-var-alias-eq.rs
+++ /dev/null
@@ -1,18 +0,0 @@
-// check-pass
-// compile-flags: -Ztrait-solver=next
-
-// HIR typeck ends up equating `<?0i as Add>::Output == ?0i`.
-// Want to make sure that we emit an alias-eq goal for this,
-// instead of treating it as a type error and bailing.
-
-fn test() {
- // fallback
- let x = 1 + 2;
-}
-
-fn test2() -> u32 {
- // expectation from return ty
- 1 + 2
-}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/int-var-is-send.rs b/tests/ui/traits/new-solver/int-var-is-send.rs
deleted file mode 100644
index 083aa90e1..000000000
--- a/tests/ui/traits/new-solver/int-var-is-send.rs
+++ /dev/null
@@ -1,8 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-fn needs_send(_: impl Send) {}
-
-fn main() {
- needs_send(1);
-}
diff --git a/tests/ui/traits/new-solver/iter-filter-projection.rs b/tests/ui/traits/new-solver/iter-filter-projection.rs
deleted file mode 100644
index 8fb62323a..000000000
--- a/tests/ui/traits/new-solver/iter-filter-projection.rs
+++ /dev/null
@@ -1,12 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-use std::{iter, slice};
-
-struct Attr;
-
-fn test<'a, T: Iterator<Item = &'a Attr>>() {}
-
-fn main() {
- test::<iter::Filter<slice::Iter<'_, Attr>, fn(&&Attr) -> bool>>();
-}
diff --git a/tests/ui/traits/new-solver/lazy-nested-obligations-1.rs b/tests/ui/traits/new-solver/lazy-nested-obligations-1.rs
deleted file mode 100644
index af00cbb3b..000000000
--- a/tests/ui/traits/new-solver/lazy-nested-obligations-1.rs
+++ /dev/null
@@ -1,13 +0,0 @@
-// check-pass
-// compile-flags: -Ztrait-solver=next
-// Issue 94358
-
-fn foo<C>(_: C)
-where
- for <'a> &'a C: IntoIterator,
- for <'a> <&'a C as IntoIterator>::IntoIter: ExactSizeIterator,
-{}
-
-fn main() {
- foo::<_>(vec![true, false]);
-}
diff --git a/tests/ui/traits/new-solver/lazy-nested-obligations-2.rs b/tests/ui/traits/new-solver/lazy-nested-obligations-2.rs
deleted file mode 100644
index 20f504928..000000000
--- a/tests/ui/traits/new-solver/lazy-nested-obligations-2.rs
+++ /dev/null
@@ -1,22 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-pub trait With {
- type F;
-}
-
-impl With for i32 {
- type F = fn(&str);
-}
-
-fn f(_: &str) {}
-
-fn main() {
- let _: V<i32> = V(f);
- pub struct V<T: With>(<T as With>::F);
-
- pub enum E3<T: With> {
- Var(<T as With>::F),
- }
- let _: E3<i32> = E3::Var(f);
-}
diff --git a/tests/ui/traits/new-solver/lazy-nested-obligations-3.rs b/tests/ui/traits/new-solver/lazy-nested-obligations-3.rs
deleted file mode 100644
index baf399572..000000000
--- a/tests/ui/traits/new-solver/lazy-nested-obligations-3.rs
+++ /dev/null
@@ -1,38 +0,0 @@
-// check-pass
-// compile-flags: -Ztrait-solver=next
-// Issue 96750
-
-use std::marker::PhantomData;
-
-trait AsyncFn<Arg> {
- type Output;
-}
-trait RequestFamily {
- type Type<'a>;
-}
-trait Service {}
-
-struct MyFn;
-impl AsyncFn<String> for MyFn {
- type Output = ();
-}
-
-impl RequestFamily for String {
- type Type<'a> = String;
-}
-
-struct ServiceFromAsyncFn<F, Req>(F, PhantomData<Req>);
-
-impl<F, Req, O> Service for ServiceFromAsyncFn<F, Req>
-where
- Req: RequestFamily,
- F: AsyncFn<Req>,
- F: for<'a> AsyncFn<Req::Type<'a>, Output = O>,
-{
-}
-
-fn assert_service() -> impl Service {
- ServiceFromAsyncFn(MyFn, PhantomData)
-}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/member-constraints-in-root-universe.rs b/tests/ui/traits/new-solver/member-constraints-in-root-universe.rs
deleted file mode 100644
index 97c443058..000000000
--- a/tests/ui/traits/new-solver/member-constraints-in-root-universe.rs
+++ /dev/null
@@ -1,17 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-trait Trait {
- type Ty;
-}
-
-impl Trait for for<'a> fn(&'a u8, &'a u8) {
- type Ty = ();
-}
-
-// argument is necessary to create universes before registering the hidden type.
-fn test<'a>(_: <fn(&u8, &u8) as Trait>::Ty) -> impl Sized {
- "hidden type is `&'?0 str` with '?0 member of ['static,]"
-}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/more-object-bound.rs b/tests/ui/traits/new-solver/more-object-bound.rs
deleted file mode 100644
index bb730b18e..000000000
--- a/tests/ui/traits/new-solver/more-object-bound.rs
+++ /dev/null
@@ -1,27 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// From #80800
-
-trait SuperTrait {
- type A;
- type B;
-}
-
-trait Trait: SuperTrait<A = <Self as SuperTrait>::B> {}
-
-fn transmute<A, B>(x: A) -> B {
- foo::<A, B, dyn Trait<A = A, B = B>>(x)
- //~^ ERROR the trait bound `dyn Trait<A = A, B = B>: Trait` is not satisfied
-}
-
-fn foo<A, B, T: ?Sized>(x: T::A) -> B
-where
- T: Trait<B = B>,
-{
- x
-}
-
-static X: u8 = 0;
-fn main() {
- let x = transmute::<&u8, &[u8; 1_000_000]>(&X);
- println!("{:?}", x[100_000]);
-}
diff --git a/tests/ui/traits/new-solver/more-object-bound.stderr b/tests/ui/traits/new-solver/more-object-bound.stderr
deleted file mode 100644
index 54965dee1..000000000
--- a/tests/ui/traits/new-solver/more-object-bound.stderr
+++ /dev/null
@@ -1,22 +0,0 @@
-error[E0277]: the trait bound `dyn Trait<A = A, B = B>: Trait` is not satisfied
- --> $DIR/more-object-bound.rs:12:5
- |
-LL | foo::<A, B, dyn Trait<A = A, B = B>>(x)
- | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `Trait` is not implemented for `dyn Trait<A = A, B = B>`
- |
-note: required by a bound in `foo`
- --> $DIR/more-object-bound.rs:18:8
- |
-LL | fn foo<A, B, T: ?Sized>(x: T::A) -> B
- | --- required by a bound in this function
-LL | where
-LL | T: Trait<B = B>,
- | ^^^^^^^^^^^^ required by this bound in `foo`
-help: consider introducing a `where` clause, but there might be an alternative better way to express this requirement
- |
-LL | fn transmute<A, B>(x: A) -> B where dyn Trait<A = A, B = B>: Trait {
- | ++++++++++++++++++++++++++++++++++++
-
-error: aborting due to previous error
-
-For more information about this error, try `rustc --explain E0277`.
diff --git a/tests/ui/traits/new-solver/negative-coherence-bounds.rs b/tests/ui/traits/new-solver/negative-coherence-bounds.rs
deleted file mode 100644
index 5436b02c3..000000000
--- a/tests/ui/traits/new-solver/negative-coherence-bounds.rs
+++ /dev/null
@@ -1,40 +0,0 @@
-// check-pass
-
-// This test verifies that negative trait predicate cannot be satisfied from a
-// positive param-env candidate.
-
-// Negative coherence is one of the only places where we actually construct and
-// evaluate negative predicates. Specifically, when verifying whether the first
-// and second impls below overlap, we do not want to consider them disjoint,
-// otherwise the second impl would be missing an associated type `type Item`
-// which is provided by the first impl that it is specializing.
-
-#![feature(specialization)]
-//~^ WARN the feature `specialization` is incomplete
-#![feature(with_negative_coherence)]
-
-trait BoxIter {
- type Item;
-
- fn last(self) -> Option<Self::Item>;
-}
-
-impl<I: Iterator + ?Sized> BoxIter for Box<I> {
- type Item = I::Item;
-
- default fn last(self) -> Option<I::Item> {
- todo!()
- }
-}
-
-// When checking that this impl does/doesn't overlap the one above, we evaluate
-// a negative version of all of the where-clause predicates of the impl below.
-// For `I: !Iterator`, we should make sure that the param-env clause `I: Iterator`
-// from above doesn't satisfy this predicate.
-impl<I: Iterator> BoxIter for Box<I> {
- fn last(self) -> Option<I::Item> {
- (*self).last()
- }
-}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/negative-coherence-bounds.stderr b/tests/ui/traits/new-solver/negative-coherence-bounds.stderr
deleted file mode 100644
index 4127f51f5..000000000
--- a/tests/ui/traits/new-solver/negative-coherence-bounds.stderr
+++ /dev/null
@@ -1,12 +0,0 @@
-warning: the feature `specialization` is incomplete and may not be safe to use and/or cause compiler crashes
- --> $DIR/negative-coherence-bounds.rs:12:12
- |
-LL | #![feature(specialization)]
- | ^^^^^^^^^^^^^^
- |
- = note: see issue #31844 <https://github.com/rust-lang/rust/issues/31844> for more information
- = help: consider using `min_specialization` instead, which is more stable and complete
- = note: `#[warn(incomplete_features)]` on by default
-
-warning: 1 warning emitted
-
diff --git a/tests/ui/traits/new-solver/nested-alias-bound.rs b/tests/ui/traits/new-solver/nested-alias-bound.rs
deleted file mode 100644
index c365902db..000000000
--- a/tests/ui/traits/new-solver/nested-alias-bound.rs
+++ /dev/null
@@ -1,20 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-trait A {
- type A: B;
-}
-
-trait B {
- type B: C;
-}
-
-trait C {}
-
-fn needs_c<T: C>() {}
-
-fn test<T: A>() {
- needs_c::<<T::A as B>::B>();
-}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/nested-obligations-with-bound-vars-gat.rs b/tests/ui/traits/new-solver/nested-obligations-with-bound-vars-gat.rs
deleted file mode 100644
index 92bad9590..000000000
--- a/tests/ui/traits/new-solver/nested-obligations-with-bound-vars-gat.rs
+++ /dev/null
@@ -1,43 +0,0 @@
-// check-pass
-// compile-flags: -Ztrait-solver=next
-// Issue 96230
-
-use std::fmt::Debug;
-
-trait Classic {
- type Assoc;
-}
-
-trait Gat {
- type Assoc<'a>;
-}
-
-struct Foo;
-
-impl Classic for Foo {
- type Assoc = ();
-}
-
-impl Gat for Foo {
- type Assoc<'i> = ();
-}
-
-fn classic_debug<T: Classic>(_: T)
-where
- T::Assoc: Debug,
-{
-}
-
-fn gat_debug<T: Gat>(_: T)
-where
- for<'a> T::Assoc<'a>: Debug,
-{
-}
-
-fn main() {
- classic_debug::<Foo>(Foo); // fine
- classic_debug(Foo); // fine
-
- gat_debug::<Foo>(Foo); // fine
- gat_debug(Foo); // boom
-}
diff --git a/tests/ui/traits/new-solver/normalize-async-closure-in-trait.rs b/tests/ui/traits/new-solver/normalize-async-closure-in-trait.rs
deleted file mode 100644
index cc16cc871..000000000
--- a/tests/ui/traits/new-solver/normalize-async-closure-in-trait.rs
+++ /dev/null
@@ -1,9 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-// edition:2021
-
-trait Foo {
- async fn bar() {}
-}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/normalize-param-env-1.rs b/tests/ui/traits/new-solver/normalize-param-env-1.rs
deleted file mode 100644
index b02a5d623..000000000
--- a/tests/ui/traits/new-solver/normalize-param-env-1.rs
+++ /dev/null
@@ -1,40 +0,0 @@
-// check-pass
-// compile-flags: -Ztrait-solver=next
-// Issue 108933
-
-trait Add<Rhs> {
- type Sum;
-}
-
-impl Add<()> for () {
- type Sum = ();
-}
-
-type Unit = <() as Add<()>>::Sum;
-
-trait Trait<C> {
- type Output;
-}
-
-fn f<T>()
-where
- T: Trait<()>,
- <T as Trait<()>>::Output: Sized,
-{
-}
-
-fn g<T>()
-where
- T: Trait<Unit>,
- <T as Trait<()>>::Output: Sized,
-{
-}
-
-fn h<T>()
-where
- T: Trait<()>,
- <T as Trait<Unit>>::Output: Sized,
-{
-}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/normalize-param-env-2.rs b/tests/ui/traits/new-solver/normalize-param-env-2.rs
deleted file mode 100644
index 7c2cebdd2..000000000
--- a/tests/ui/traits/new-solver/normalize-param-env-2.rs
+++ /dev/null
@@ -1,26 +0,0 @@
-// check-pass
-// compile-flags: -Ztrait-solver=next
-// Issue 92505
-
-trait A<T> {
- type I;
-
- fn f()
- where
- Self::I: A<T>,
- {
- }
-}
-
-impl<T> A<T> for () {
- type I = ();
-
- fn f()
- where
- Self::I: A<T>,
- {
- <() as A<T>>::f();
- }
-}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/normalize-param-env-3.rs b/tests/ui/traits/new-solver/normalize-param-env-3.rs
deleted file mode 100644
index ce2974b2a..000000000
--- a/tests/ui/traits/new-solver/normalize-param-env-3.rs
+++ /dev/null
@@ -1,32 +0,0 @@
-// check-pass
-// compile-flags: -Ztrait-solver=next
-// Issue 100177
-
-trait GenericTrait<T> {}
-
-trait Channel<I>: GenericTrait<Self::T> {
- type T;
-}
-
-trait Sender {
- type Msg;
-
- fn send<C>()
- where
- C: Channel<Self::Msg>;
-}
-
-impl<T> Sender for T {
- type Msg = ();
-
- fn send<C>()
- where
- C: Channel<Self::Msg>,
- {
- }
-}
-
-// This works
-fn foo<I, C>(ch: C) where C: Channel<I> {}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/normalize-rcvr-for-inherent.rs b/tests/ui/traits/new-solver/normalize-rcvr-for-inherent.rs
deleted file mode 100644
index d70534feb..000000000
--- a/tests/ui/traits/new-solver/normalize-rcvr-for-inherent.rs
+++ /dev/null
@@ -1,25 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-// Verify that we can assemble inherent impl candidates on a possibly
-// unnormalized self type.
-
-trait Foo {
- type Assoc;
-}
-impl Foo for i32 {
- type Assoc = Bar;
-}
-
-struct Bar;
-impl Bar {
- fn method(&self) {}
-}
-
-fn build<T: Foo>(_: T) -> T::Assoc {
- todo!()
-}
-
-fn main() {
- build(1i32).method();
-}
diff --git a/tests/ui/traits/new-solver/normalize-unsize-rhs.rs b/tests/ui/traits/new-solver/normalize-unsize-rhs.rs
deleted file mode 100644
index a398ab4f2..000000000
--- a/tests/ui/traits/new-solver/normalize-unsize-rhs.rs
+++ /dev/null
@@ -1,23 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-#![feature(trait_upcasting)]
-
-trait A {}
-trait B: A {}
-
-impl A for usize {}
-impl B for usize {}
-
-trait Mirror {
- type Assoc: ?Sized;
-}
-
-impl<T: ?Sized> Mirror for T {
- type Assoc = T;
-}
-
-fn main() {
- let x = Box::new(1usize) as Box<<dyn B as Mirror>::Assoc>;
- let y = x as Box<<dyn A as Mirror>::Assoc>;
-}
diff --git a/tests/ui/traits/new-solver/normalized-const-built-in-op.rs b/tests/ui/traits/new-solver/normalized-const-built-in-op.rs
deleted file mode 100644
index 2443e5178..000000000
--- a/tests/ui/traits/new-solver/normalized-const-built-in-op.rs
+++ /dev/null
@@ -1,11 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-const fn foo() {
- let mut x = [1, 2, 3];
- // We need to fix up `<<[i32; 3] as Index<usize>>::Output as AddAssign>`
- // to be treated like a built-in operation.
- x[1] += 5;
-}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/normalizes_to_ignores_unnormalizable_candidate.rs b/tests/ui/traits/new-solver/normalizes_to_ignores_unnormalizable_candidate.rs
deleted file mode 100644
index 46343241b..000000000
--- a/tests/ui/traits/new-solver/normalizes_to_ignores_unnormalizable_candidate.rs
+++ /dev/null
@@ -1,40 +0,0 @@
-// [no_self_infer] check-pass
-// compile-flags: -Ztrait-solver=next
-// revisions: self_infer no_self_infer
-
-// checks that the new solver is smart enough to infer `?0 = U` when solving:
-// `normalizes-to(<Vec<?0> as Trait>::Assoc, u8)`
-// with `normalizes-to(<Vec<U> as Trait>::Assoc, u8)` in the paramenv even when
-// there is a separate `Vec<T>: Trait` bound in the paramenv.
-//
-// FIXME(-Ztrait-solver=next)
-// This could also compile for `normalizes-to(<?0 as Trait>::Assoc, u8)` but
-// we currently immediately consider a goal ambiguous if the self type is an
-// inference variable.
-
-trait Trait {
- type Assoc;
-}
-
-fn foo<T: Trait<Assoc = u8>>(x: T) {}
-
-#[cfg(self_infer)]
-fn unconstrained<T>() -> T {
- todo!()
-}
-
-#[cfg(no_self_infer)]
-fn unconstrained<T>() -> Vec<T> {
- todo!()
-}
-
-fn bar<T, U>()
-where
- Vec<T>: Trait,
- Vec<U>: Trait<Assoc = u8>,
-{
- foo(unconstrained())
- //[self_infer]~^ ERROR type annotations needed
-}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/normalizes_to_ignores_unnormalizable_candidate.self_infer.stderr b/tests/ui/traits/new-solver/normalizes_to_ignores_unnormalizable_candidate.self_infer.stderr
deleted file mode 100644
index f482e8cfa..000000000
--- a/tests/ui/traits/new-solver/normalizes_to_ignores_unnormalizable_candidate.self_infer.stderr
+++ /dev/null
@@ -1,22 +0,0 @@
-error[E0283]: type annotations needed
- --> $DIR/normalizes_to_ignores_unnormalizable_candidate.rs:36:5
- |
-LL | foo(unconstrained())
- | ^^^ --------------- type must be known at this point
- | |
- | cannot infer type of the type parameter `T` declared on the function `foo`
- |
- = note: cannot satisfy `_: Trait`
-note: required by a bound in `foo`
- --> $DIR/normalizes_to_ignores_unnormalizable_candidate.rs:19:11
- |
-LL | fn foo<T: Trait<Assoc = u8>>(x: T) {}
- | ^^^^^^^^^^^^^^^^^ required by this bound in `foo`
-help: consider specifying the generic argument
- |
-LL | foo::<T>(unconstrained())
- | +++++
-
-error: aborting due to previous error
-
-For more information about this error, try `rustc --explain E0283`.
diff --git a/tests/ui/traits/new-solver/object-soundness-requires-generalization.rs b/tests/ui/traits/new-solver/object-soundness-requires-generalization.rs
deleted file mode 100644
index d02dada72..000000000
--- a/tests/ui/traits/new-solver/object-soundness-requires-generalization.rs
+++ /dev/null
@@ -1,20 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// ignore-test
-
-trait Trait {
- type Gat<'lt>;
-}
-impl Trait for u8 {
- type Gat<'lt> = u8;
-}
-
-fn test<T: Trait, F: FnOnce(<T as Trait>::Gat<'_>) -> S + ?Sized, S>() {}
-
-fn main() {
- // Proving `dyn FnOnce: FnOnce` requires making sure that all of the supertraits
- // of the trait and associated type bounds hold. We check this in
- // `predicates_for_object_candidate`, and eagerly replace projections using equality
- // which may generalize a type and emit a nested AliasRelate goal. Make sure that
- // we don't ICE in that case, and bubble that goal up to the caller.
- test::<u8, dyn FnOnce(<u8 as Trait>::Gat<'_>) + 'static, _>();
-}
diff --git a/tests/ui/traits/new-solver/object-unsafety.rs b/tests/ui/traits/new-solver/object-unsafety.rs
deleted file mode 100644
index da843c914..000000000
--- a/tests/ui/traits/new-solver/object-unsafety.rs
+++ /dev/null
@@ -1,28 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-
-trait Setup {
- type From: Copy;
-}
-
-fn copy<U: Setup + ?Sized>(from: &U::From) -> U::From {
- *from
-}
-
-pub fn copy_any<T>(t: &T) -> T {
- copy::<dyn Setup<From=T>>(t)
- //~^ ERROR the type `&<dyn Setup<From = T> as Setup>::From` is not well-formed
- //~| ERROR the trait bound `dyn Setup<From = T>: Setup` is not satisfied
- //~| ERROR mismatched types
- //~| ERROR mismatched types
- //~| ERROR the type `<dyn Setup<From = T> as Setup>::From` is not well-formed
- //~| ERROR the size for values of type `<dyn Setup<From = T> as Setup>::From` cannot be known at compilation time
-
- // FIXME(-Ztrait-solver=next): These error messages are horrible and some of them
- // are even simple fallout from previous error.
-}
-
-fn main() {
- let x = String::from("Hello, world");
- let y = copy_any(&x);
- println!("{y}");
-}
diff --git a/tests/ui/traits/new-solver/object-unsafety.stderr b/tests/ui/traits/new-solver/object-unsafety.stderr
deleted file mode 100644
index 914a8f9d4..000000000
--- a/tests/ui/traits/new-solver/object-unsafety.stderr
+++ /dev/null
@@ -1,78 +0,0 @@
-error[E0277]: the trait bound `dyn Setup<From = T>: Setup` is not satisfied
- --> $DIR/object-unsafety.rs:12:12
- |
-LL | copy::<dyn Setup<From=T>>(t)
- | ^^^^^^^^^^^^^^^^^ the trait `Setup` is not implemented for `dyn Setup<From = T>`
- |
-note: required by a bound in `copy`
- --> $DIR/object-unsafety.rs:7:12
- |
-LL | fn copy<U: Setup + ?Sized>(from: &U::From) -> U::From {
- | ^^^^^ required by this bound in `copy`
-help: consider introducing a `where` clause, but there might be an alternative better way to express this requirement
- |
-LL | pub fn copy_any<T>(t: &T) -> T where dyn Setup<From = T>: Setup {
- | ++++++++++++++++++++++++++++++++
-
-error: the type `&<dyn Setup<From = T> as Setup>::From` is not well-formed
- --> $DIR/object-unsafety.rs:12:31
- |
-LL | copy::<dyn Setup<From=T>>(t)
- | ^
-
-error[E0308]: mismatched types
- --> $DIR/object-unsafety.rs:12:31
- |
-LL | copy::<dyn Setup<From=T>>(t)
- | ------------------------- ^ types differ
- | |
- | arguments to this function are incorrect
- |
- = note: expected reference `&<dyn Setup<From = T> as Setup>::From`
- found reference `&T`
-note: function defined here
- --> $DIR/object-unsafety.rs:7:4
- |
-LL | fn copy<U: Setup + ?Sized>(from: &U::From) -> U::From {
- | ^^^^ --------------
-
-error[E0308]: mismatched types
- --> $DIR/object-unsafety.rs:12:5
- |
-LL | pub fn copy_any<T>(t: &T) -> T {
- | - - expected `T` because of return type
- | |
- | expected this type parameter
-LL | copy::<dyn Setup<From=T>>(t)
- | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ types differ
- |
- = note: expected type parameter `T`
- found associated type `<dyn Setup<From = T> as Setup>::From`
- = note: you might be missing a type parameter or trait bound
-
-error: the type `<dyn Setup<From = T> as Setup>::From` is not well-formed
- --> $DIR/object-unsafety.rs:12:5
- |
-LL | copy::<dyn Setup<From=T>>(t)
- | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
-
-error[E0277]: the size for values of type `<dyn Setup<From = T> as Setup>::From` cannot be known at compilation time
- --> $DIR/object-unsafety.rs:12:5
- |
-LL | copy::<dyn Setup<From=T>>(t)
- | ^^^^^^^^^^^^^^^^^^^^^^^^^---
- | |
- | doesn't have a size known at compile-time
- | this returned value is of type `<dyn Setup<From = T> as Setup>::From`
- |
- = help: the trait `Sized` is not implemented for `<dyn Setup<From = T> as Setup>::From`
- = note: the return type of a function must have a statically known size
-help: consider further restricting the associated type
- |
-LL | pub fn copy_any<T>(t: &T) -> T where <dyn Setup<From = T> as Setup>::From: Sized {
- | +++++++++++++++++++++++++++++++++++++++++++++++++
-
-error: aborting due to 6 previous errors
-
-Some errors have detailed explanations: E0277, E0308.
-For more information about an error, try `rustc --explain E0277`.
diff --git a/tests/ui/traits/new-solver/opportunistic-region-resolve.rs b/tests/ui/traits/new-solver/opportunistic-region-resolve.rs
deleted file mode 100644
index 2610789cd..000000000
--- a/tests/ui/traits/new-solver/opportunistic-region-resolve.rs
+++ /dev/null
@@ -1,19 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-#![feature(rustc_attrs)]
-
-#[rustc_coinductive]
-trait Trait {}
-
-#[rustc_coinductive]
-trait Indirect {}
-impl<T: Trait + ?Sized> Indirect for T {}
-
-impl<'a> Trait for &'a () where &'a (): Indirect {}
-
-fn impls_trait<T: Trait>() {}
-
-fn main() {
- impls_trait::<&'static ()>();
-}
diff --git a/tests/ui/traits/new-solver/overflow/exponential-trait-goals.rs b/tests/ui/traits/new-solver/overflow/exponential-trait-goals.rs
deleted file mode 100644
index 3d2e70a63..000000000
--- a/tests/ui/traits/new-solver/overflow/exponential-trait-goals.rs
+++ /dev/null
@@ -1,19 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-
-trait Trait {}
-
-struct W<T>(T);
-
-impl<T, U> Trait for W<(W<T>, W<U>)>
-where
- W<T>: Trait,
- W<U>: Trait,
-{
-}
-
-fn impls<T: Trait>() {}
-
-fn main() {
- impls::<W<_>>();
- //~^ ERROR overflow evaluating the requirement `W<_>: Trait`
-}
diff --git a/tests/ui/traits/new-solver/overflow/exponential-trait-goals.stderr b/tests/ui/traits/new-solver/overflow/exponential-trait-goals.stderr
deleted file mode 100644
index 023efc41a..000000000
--- a/tests/ui/traits/new-solver/overflow/exponential-trait-goals.stderr
+++ /dev/null
@@ -1,16 +0,0 @@
-error[E0275]: overflow evaluating the requirement `W<_>: Trait`
- --> $DIR/exponential-trait-goals.rs:17:13
- |
-LL | impls::<W<_>>();
- | ^^^^
- |
- = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`exponential_trait_goals`)
-note: required by a bound in `impls`
- --> $DIR/exponential-trait-goals.rs:14:13
- |
-LL | fn impls<T: Trait>() {}
- | ^^^^^ required by this bound in `impls`
-
-error: aborting due to previous error
-
-For more information about this error, try `rustc --explain E0275`.
diff --git a/tests/ui/traits/new-solver/overflow/global-cache.rs b/tests/ui/traits/new-solver/overflow/global-cache.rs
deleted file mode 100644
index adc03da04..000000000
--- a/tests/ui/traits/new-solver/overflow/global-cache.rs
+++ /dev/null
@@ -1,23 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-
-// Check that we consider the reached depth of global cache
-// entries when detecting overflow. We would otherwise be unstable
-// wrt to incremental compilation.
-#![recursion_limit = "9"]
-
-trait Trait {}
-
-struct Inc<T>(T);
-
-impl<T: Trait> Trait for Inc<T> {}
-impl Trait for () {}
-
-fn impls_trait<T: Trait>() {}
-
-type Four<T> = Inc<Inc<Inc<Inc<T>>>>;
-
-fn main() {
- impls_trait::<Four<Four<()>>>();
- impls_trait::<Four<Four<Four<Four<()>>>>>();
- //~^ ERROR overflow evaluating the requirement
-}
diff --git a/tests/ui/traits/new-solver/overflow/global-cache.stderr b/tests/ui/traits/new-solver/overflow/global-cache.stderr
deleted file mode 100644
index ebb03d84b..000000000
--- a/tests/ui/traits/new-solver/overflow/global-cache.stderr
+++ /dev/null
@@ -1,16 +0,0 @@
-error[E0275]: overflow evaluating the requirement `Inc<Inc<Inc<Inc<Inc<Inc<Inc<...>>>>>>>: Trait`
- --> $DIR/global-cache.rs:21:19
- |
-LL | impls_trait::<Four<Four<Four<Four<()>>>>>();
- | ^^^^^^^^^^^^^^^^^^^^^^^^^^
- |
- = help: consider increasing the recursion limit by adding a `#![recursion_limit = "18"]` attribute to your crate (`global_cache`)
-note: required by a bound in `impls_trait`
- --> $DIR/global-cache.rs:15:19
- |
-LL | fn impls_trait<T: Trait>() {}
- | ^^^^^ required by this bound in `impls_trait`
-
-error: aborting due to previous error
-
-For more information about this error, try `rustc --explain E0275`.
diff --git a/tests/ui/traits/new-solver/overflow/recursion-limit-zero-issue-115351.rs b/tests/ui/traits/new-solver/overflow/recursion-limit-zero-issue-115351.rs
deleted file mode 100644
index 539c9614e..000000000
--- a/tests/ui/traits/new-solver/overflow/recursion-limit-zero-issue-115351.rs
+++ /dev/null
@@ -1,12 +0,0 @@
-//~ ERROR overflow evaluating the requirement `Self well-formed`
-//~| ERROR overflow evaluating the requirement `Self: Trait`
-
-// This is a non-regression test for issue #115351, where a recursion limit of 0 caused an ICE.
-// compile-flags: -Ztrait-solver=next --crate-type=lib
-// check-fail
-
-#![recursion_limit = "0"]
-trait Trait {}
-impl Trait for u32 {}
-//~^ ERROR overflow evaluating the requirement `u32: Trait`
-//~| ERROR overflow evaluating the requirement `u32 well-formed`
diff --git a/tests/ui/traits/new-solver/overflow/recursion-limit-zero-issue-115351.stderr b/tests/ui/traits/new-solver/overflow/recursion-limit-zero-issue-115351.stderr
deleted file mode 100644
index 16b25d90a..000000000
--- a/tests/ui/traits/new-solver/overflow/recursion-limit-zero-issue-115351.stderr
+++ /dev/null
@@ -1,27 +0,0 @@
-error[E0275]: overflow evaluating the requirement `Self: Trait`
- |
- = help: consider increasing the recursion limit by adding a `#![recursion_limit = "2"]` attribute to your crate (`recursion_limit_zero_issue_115351`)
-
-error[E0275]: overflow evaluating the requirement `Self well-formed`
- |
- = help: consider increasing the recursion limit by adding a `#![recursion_limit = "2"]` attribute to your crate (`recursion_limit_zero_issue_115351`)
-
-error[E0275]: overflow evaluating the requirement `u32: Trait`
- --> $DIR/recursion-limit-zero-issue-115351.rs:10:16
- |
-LL | impl Trait for u32 {}
- | ^^^
- |
- = help: consider increasing the recursion limit by adding a `#![recursion_limit = "2"]` attribute to your crate (`recursion_limit_zero_issue_115351`)
-
-error[E0275]: overflow evaluating the requirement `u32 well-formed`
- --> $DIR/recursion-limit-zero-issue-115351.rs:10:16
- |
-LL | impl Trait for u32 {}
- | ^^^
- |
- = help: consider increasing the recursion limit by adding a `#![recursion_limit = "2"]` attribute to your crate (`recursion_limit_zero_issue_115351`)
-
-error: aborting due to 4 previous errors
-
-For more information about this error, try `rustc --explain E0275`.
diff --git a/tests/ui/traits/new-solver/overflow/recursive-self-normalization-2.rs b/tests/ui/traits/new-solver/overflow/recursive-self-normalization-2.rs
deleted file mode 100644
index d086db475..000000000
--- a/tests/ui/traits/new-solver/overflow/recursive-self-normalization-2.rs
+++ /dev/null
@@ -1,20 +0,0 @@
-//~ ERROR overflow
-// compile-flags: -Ztrait-solver=next
-
-trait Foo1 {
- type Assoc1;
-}
-
-trait Foo2 {
- type Assoc2;
-}
-
-trait Bar {}
-fn needs_bar<S: Bar>() {}
-
-fn test<T: Foo1<Assoc1 = <T as Foo2>::Assoc2> + Foo2<Assoc2 = <T as Foo1>::Assoc1>>() {
- needs_bar::<T::Assoc1>();
- //~^ ERROR overflow evaluating the requirement `<T as Foo1>::Assoc1: Bar`
-}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/overflow/recursive-self-normalization-2.stderr b/tests/ui/traits/new-solver/overflow/recursive-self-normalization-2.stderr
deleted file mode 100644
index 1dc63fae9..000000000
--- a/tests/ui/traits/new-solver/overflow/recursive-self-normalization-2.stderr
+++ /dev/null
@@ -1,20 +0,0 @@
-error[E0275]: overflow evaluating the requirement `<T as Foo1>::Assoc1: Bar`
- --> $DIR/recursive-self-normalization-2.rs:16:17
- |
-LL | needs_bar::<T::Assoc1>();
- | ^^^^^^^^^
- |
- = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`recursive_self_normalization_2`)
-note: required by a bound in `needs_bar`
- --> $DIR/recursive-self-normalization-2.rs:13:17
- |
-LL | fn needs_bar<S: Bar>() {}
- | ^^^ required by this bound in `needs_bar`
-
-error[E0275]: overflow evaluating the requirement `<T as Foo2>::Assoc2`
- |
- = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`recursive_self_normalization_2`)
-
-error: aborting due to 2 previous errors
-
-For more information about this error, try `rustc --explain E0275`.
diff --git a/tests/ui/traits/new-solver/overflow/recursive-self-normalization.rs b/tests/ui/traits/new-solver/overflow/recursive-self-normalization.rs
deleted file mode 100644
index d15df7dea..000000000
--- a/tests/ui/traits/new-solver/overflow/recursive-self-normalization.rs
+++ /dev/null
@@ -1,16 +0,0 @@
-//~ ERROR overflow evaluating the requirement `<T as Foo>::Assoc` [E0275]
-// compile-flags: -Ztrait-solver=next
-
-trait Foo {
- type Assoc;
-}
-
-trait Bar {}
-fn needs_bar<S: Bar>() {}
-
-fn test<T: Foo<Assoc = <T as Foo>::Assoc>>() {
- needs_bar::<T::Assoc>();
- //~^ ERROR overflow evaluating the requirement `<T as Foo>::Assoc: Bar`
-}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/overflow/recursive-self-normalization.stderr b/tests/ui/traits/new-solver/overflow/recursive-self-normalization.stderr
deleted file mode 100644
index afc5bfa54..000000000
--- a/tests/ui/traits/new-solver/overflow/recursive-self-normalization.stderr
+++ /dev/null
@@ -1,20 +0,0 @@
-error[E0275]: overflow evaluating the requirement `<T as Foo>::Assoc: Bar`
- --> $DIR/recursive-self-normalization.rs:12:17
- |
-LL | needs_bar::<T::Assoc>();
- | ^^^^^^^^
- |
- = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`recursive_self_normalization`)
-note: required by a bound in `needs_bar`
- --> $DIR/recursive-self-normalization.rs:9:17
- |
-LL | fn needs_bar<S: Bar>() {}
- | ^^^ required by this bound in `needs_bar`
-
-error[E0275]: overflow evaluating the requirement `<T as Foo>::Assoc`
- |
- = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`recursive_self_normalization`)
-
-error: aborting due to 2 previous errors
-
-For more information about this error, try `rustc --explain E0275`.
diff --git a/tests/ui/traits/new-solver/param-candidate-doesnt-shadow-project.rs b/tests/ui/traits/new-solver/param-candidate-doesnt-shadow-project.rs
deleted file mode 100644
index bdf999ec5..000000000
--- a/tests/ui/traits/new-solver/param-candidate-doesnt-shadow-project.rs
+++ /dev/null
@@ -1,25 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-trait Foo {
- type Assoc;
-}
-
-trait Bar {}
-
-impl<T> Foo for T {
- type Assoc = i32;
-}
-
-impl<T> Bar for T where T: Foo<Assoc = i32> {}
-
-fn require_bar<T: Bar>() {}
-
-fn foo<T: Foo>() {
- // Unlike the classic solver, `<T as Foo>::Assoc = _` will still project
- // down to `i32` even though there's a param-env candidate here, since we
- // don't assemble any param-env projection candidates for `T: Foo` alone.
- require_bar::<T>();
-}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/param-discr-kind.rs b/tests/ui/traits/new-solver/param-discr-kind.rs
deleted file mode 100644
index e319ddea1..000000000
--- a/tests/ui/traits/new-solver/param-discr-kind.rs
+++ /dev/null
@@ -1,8 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-fn foo<T>(x: T) {
- std::mem::discriminant(&x);
-}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/pointee.rs b/tests/ui/traits/new-solver/pointee.rs
deleted file mode 100644
index 93c0542ac..000000000
--- a/tests/ui/traits/new-solver/pointee.rs
+++ /dev/null
@@ -1,21 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-#![feature(ptr_metadata)]
-
-use std::ptr::{DynMetadata, Pointee};
-
-trait Trait<U> {}
-struct MyDst<T: ?Sized>(T);
-
-fn meta_is<T: Pointee<Metadata = U> + ?Sized, U>() {}
-
-fn works<T>() {
- meta_is::<T, ()>();
- meta_is::<[T], usize>();
- meta_is::<str, usize>();
- meta_is::<dyn Trait<T>, DynMetadata<dyn Trait<T>>>();
- meta_is::<MyDst<T>, ()>();
- meta_is::<((((([u8],),),),),), usize>();
-}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/pointer-like.rs b/tests/ui/traits/new-solver/pointer-like.rs
deleted file mode 100644
index 986301769..000000000
--- a/tests/ui/traits/new-solver/pointer-like.rs
+++ /dev/null
@@ -1,14 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-
-#![feature(pointer_like_trait)]
-
-use std::marker::PointerLike;
-
-fn require_(_: impl PointerLike) {}
-
-fn main() {
- require_(1usize);
- require_(1u16);
- //~^ ERROR `u16` needs to have the same ABI as a pointer
- require_(&1i16);
-}
diff --git a/tests/ui/traits/new-solver/pointer-like.stderr b/tests/ui/traits/new-solver/pointer-like.stderr
deleted file mode 100644
index 215a81cc2..000000000
--- a/tests/ui/traits/new-solver/pointer-like.stderr
+++ /dev/null
@@ -1,24 +0,0 @@
-error[E0277]: `u16` needs to have the same ABI as a pointer
- --> $DIR/pointer-like.rs:11:14
- |
-LL | require_(1u16);
- | -------- ^^^^ the trait `PointerLike` is not implemented for `u16`
- | |
- | required by a bound introduced by this call
- |
- = note: the trait bound `u16: PointerLike` is not satisfied
-note: required by a bound in `require_`
- --> $DIR/pointer-like.rs:7:21
- |
-LL | fn require_(_: impl PointerLike) {}
- | ^^^^^^^^^^^ required by this bound in `require_`
-help: consider borrowing here
- |
-LL | require_(&1u16);
- | +
-LL | require_(&mut 1u16);
- | ++++
-
-error: aborting due to previous error
-
-For more information about this error, try `rustc --explain E0277`.
diff --git a/tests/ui/traits/new-solver/prefer-candidate-no-constraints.rs b/tests/ui/traits/new-solver/prefer-candidate-no-constraints.rs
deleted file mode 100644
index 6f8164f3a..000000000
--- a/tests/ui/traits/new-solver/prefer-candidate-no-constraints.rs
+++ /dev/null
@@ -1,22 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-trait Foo {}
-
-impl<T> Foo for T {}
-
-trait Bar {}
-
-struct Wrapper<'a, T>(&'a T);
-
-impl<'a, T> Bar for Wrapper<'a, T> where &'a T: Foo {}
-// We need to satisfy `&'a T: Foo` when checking that this impl is WF
-// that can either be satisfied via the param-env, or via an impl.
-//
-// When satisfied via the param-env, since each lifetime is canonicalized
-// separately, we end up getting extra region constraints.
-//
-// However, when satisfied via the impl, there are no region constraints,
-// and we can short-circuit a response with no external constraints.
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/prefer-param-env-on-ambiguity.rs b/tests/ui/traits/new-solver/prefer-param-env-on-ambiguity.rs
deleted file mode 100644
index 909b33ec3..000000000
--- a/tests/ui/traits/new-solver/prefer-param-env-on-ambiguity.rs
+++ /dev/null
@@ -1,10 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-trait Foo<'a> {}
-trait Bar<'a> {}
-
-impl<'a, T: Bar<'a>> Foo<'a> for T {}
-impl<T> Bar<'static> for T {}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/projection-discr-kind.rs b/tests/ui/traits/new-solver/projection-discr-kind.rs
deleted file mode 100644
index 20296b287..000000000
--- a/tests/ui/traits/new-solver/projection-discr-kind.rs
+++ /dev/null
@@ -1,18 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-
-// Check that `<T::Assoc as DiscriminantKind>::Discriminant` doesn't normalize
-// to itself and cause overflow/ambiguity.
-
-trait Foo {
- type Assoc;
-}
-
-trait Bar {}
-fn needs_bar(_: impl Bar) {}
-
-fn foo<T: Foo>(x: T::Assoc) {
- needs_bar(std::mem::discriminant(&x));
- //~^ ERROR the trait bound `Discriminant<<T as Foo>::Assoc>: Bar` is not satisfied
-}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/projection-discr-kind.stderr b/tests/ui/traits/new-solver/projection-discr-kind.stderr
deleted file mode 100644
index e14953f19..000000000
--- a/tests/ui/traits/new-solver/projection-discr-kind.stderr
+++ /dev/null
@@ -1,22 +0,0 @@
-error[E0277]: the trait bound `Discriminant<<T as Foo>::Assoc>: Bar` is not satisfied
- --> $DIR/projection-discr-kind.rs:14:15
- |
-LL | needs_bar(std::mem::discriminant(&x));
- | --------- ^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `Bar` is not implemented for `Discriminant<<T as Foo>::Assoc>`
- | |
- | required by a bound introduced by this call
- |
-help: this trait has no implementations, consider adding one
- --> $DIR/projection-discr-kind.rs:10:1
- |
-LL | trait Bar {}
- | ^^^^^^^^^
-note: required by a bound in `needs_bar`
- --> $DIR/projection-discr-kind.rs:11:22
- |
-LL | fn needs_bar(_: impl Bar) {}
- | ^^^ required by this bound in `needs_bar`
-
-error: aborting due to previous error
-
-For more information about this error, try `rustc --explain E0277`.
diff --git a/tests/ui/traits/new-solver/slice-match-byte-lit.rs b/tests/ui/traits/new-solver/slice-match-byte-lit.rs
deleted file mode 100644
index 4f8480625..000000000
--- a/tests/ui/traits/new-solver/slice-match-byte-lit.rs
+++ /dev/null
@@ -1,11 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-fn test(s: &[u8]) {
- match &s[0..3] {
- b"uwu" => {}
- _ => {}
- }
-}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/specialization-transmute.rs b/tests/ui/traits/new-solver/specialization-transmute.rs
deleted file mode 100644
index fac7d76f8..000000000
--- a/tests/ui/traits/new-solver/specialization-transmute.rs
+++ /dev/null
@@ -1,28 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-
-#![feature(specialization)]
-//~^ WARN the feature `specialization` is incomplete
-
-trait Default {
- type Id;
-
- fn intu(&self) -> &Self::Id;
-}
-
-impl<T> Default for T {
- default type Id = T; //~ ERROR type annotations needed
- // This will be fixed by #111994
- fn intu(&self) -> &Self::Id { //~ ERROR type annotations needed
- self
- }
-}
-
-fn transmute<T: Default<Id = U>, U: Copy>(t: T) -> U {
- *t.intu()
-}
-
-use std::num::NonZeroU8;
-fn main() {
- let s = transmute::<u8, Option<NonZeroU8>>(0); // this call should then error
- assert_eq!(s, None);
-}
diff --git a/tests/ui/traits/new-solver/specialization-transmute.stderr b/tests/ui/traits/new-solver/specialization-transmute.stderr
deleted file mode 100644
index 18965a465..000000000
--- a/tests/ui/traits/new-solver/specialization-transmute.stderr
+++ /dev/null
@@ -1,28 +0,0 @@
-warning: the feature `specialization` is incomplete and may not be safe to use and/or cause compiler crashes
- --> $DIR/specialization-transmute.rs:3:12
- |
-LL | #![feature(specialization)]
- | ^^^^^^^^^^^^^^
- |
- = note: see issue #31844 <https://github.com/rust-lang/rust/issues/31844> for more information
- = help: consider using `min_specialization` instead, which is more stable and complete
- = note: `#[warn(incomplete_features)]` on by default
-
-error[E0284]: type annotations needed
- --> $DIR/specialization-transmute.rs:15:23
- |
-LL | fn intu(&self) -> &Self::Id {
- | ^^^^^^^^^ cannot infer type
- |
- = note: cannot satisfy `<T as Default>::Id == _`
-
-error[E0282]: type annotations needed
- --> $DIR/specialization-transmute.rs:13:23
- |
-LL | default type Id = T;
- | ^ cannot infer type for associated type `<T as Default>::Id`
-
-error: aborting due to 2 previous errors; 1 warning emitted
-
-Some errors have detailed explanations: E0282, E0284.
-For more information about an error, try `rustc --explain E0282`.
diff --git a/tests/ui/traits/new-solver/specialization-unconstrained.rs b/tests/ui/traits/new-solver/specialization-unconstrained.rs
deleted file mode 100644
index 7fd753109..000000000
--- a/tests/ui/traits/new-solver/specialization-unconstrained.rs
+++ /dev/null
@@ -1,22 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-
-#![feature(specialization)]
-//~^ WARN the feature `specialization` is incomplete
-
-// Do not treat the RHS of a projection-goal as an unconstrained `Certainty::Yes` response
-// if the impl is still further specializable.
-
-trait Default {
- type Id;
-}
-
-impl<T> Default for T {
- default type Id = T; //~ ERROR type annotations needed
-}
-
-fn test<T: Default<Id = U>, U>() {}
-
-fn main() {
- test::<u32, ()>();
- //~^ ERROR cannot satisfy `<u32 as Default>::Id == ()`
-}
diff --git a/tests/ui/traits/new-solver/specialization-unconstrained.stderr b/tests/ui/traits/new-solver/specialization-unconstrained.stderr
deleted file mode 100644
index ed4dafa14..000000000
--- a/tests/ui/traits/new-solver/specialization-unconstrained.stderr
+++ /dev/null
@@ -1,32 +0,0 @@
-warning: the feature `specialization` is incomplete and may not be safe to use and/or cause compiler crashes
- --> $DIR/specialization-unconstrained.rs:3:12
- |
-LL | #![feature(specialization)]
- | ^^^^^^^^^^^^^^
- |
- = note: see issue #31844 <https://github.com/rust-lang/rust/issues/31844> for more information
- = help: consider using `min_specialization` instead, which is more stable and complete
- = note: `#[warn(incomplete_features)]` on by default
-
-error[E0284]: type annotations needed: cannot satisfy `<u32 as Default>::Id == ()`
- --> $DIR/specialization-unconstrained.rs:20:5
- |
-LL | test::<u32, ()>();
- | ^^^^^^^^^^^^^^^ cannot satisfy `<u32 as Default>::Id == ()`
- |
-note: required by a bound in `test`
- --> $DIR/specialization-unconstrained.rs:17:20
- |
-LL | fn test<T: Default<Id = U>, U>() {}
- | ^^^^^^ required by this bound in `test`
-
-error[E0282]: type annotations needed
- --> $DIR/specialization-unconstrained.rs:14:22
- |
-LL | default type Id = T;
- | ^ cannot infer type for associated type `<T as Default>::Id`
-
-error: aborting due to 2 previous errors; 1 warning emitted
-
-Some errors have detailed explanations: E0282, E0284.
-For more information about an error, try `rustc --explain E0282`.
diff --git a/tests/ui/traits/new-solver/stall-num-var-auto-trait.fallback.stderr b/tests/ui/traits/new-solver/stall-num-var-auto-trait.fallback.stderr
deleted file mode 100644
index a3ab7836c..000000000
--- a/tests/ui/traits/new-solver/stall-num-var-auto-trait.fallback.stderr
+++ /dev/null
@@ -1,17 +0,0 @@
-error[E0277]: the trait bound `i32: Foo` is not satisfied
- --> $DIR/stall-num-var-auto-trait.rs:18:15
- |
-LL | needs_foo(x);
- | --------- ^ the trait `Foo` is not implemented for `i32`
- | |
- | required by a bound introduced by this call
- |
-note: required by a bound in `needs_foo`
- --> $DIR/stall-num-var-auto-trait.rs:14:22
- |
-LL | fn needs_foo(x: impl Foo) {}
- | ^^^ required by this bound in `needs_foo`
-
-error: aborting due to previous error
-
-For more information about this error, try `rustc --explain E0277`.
diff --git a/tests/ui/traits/new-solver/stall-num-var-auto-trait.rs b/tests/ui/traits/new-solver/stall-num-var-auto-trait.rs
deleted file mode 100644
index 0539c3a42..000000000
--- a/tests/ui/traits/new-solver/stall-num-var-auto-trait.rs
+++ /dev/null
@@ -1,25 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// revisions: fallback constrain
-//[constrain] check-pass
-
-// Tests that we stall the `{integer}: Foo` obligation until after we
-// constrain the int type (or fallback occurs).
-
-#![feature(negative_impls, auto_traits)]
-
-auto trait Foo {}
-
-impl !Foo for i32 {}
-
-fn needs_foo(x: impl Foo) {}
-
-fn main() {
- let mut x = 0;
- needs_foo(x);
- //[fallback]~^ ERROR the trait bound `i32: Foo` is not satisfied
-
- #[cfg(constrain)]
- {
- x = 1u64;
- }
-}
diff --git a/tests/ui/traits/new-solver/structural-resolve-field.rs b/tests/ui/traits/new-solver/structural-resolve-field.rs
deleted file mode 100644
index 01899c9ad..000000000
--- a/tests/ui/traits/new-solver/structural-resolve-field.rs
+++ /dev/null
@@ -1,13 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-#[derive(Default)]
-struct Foo {
- x: i32,
-}
-
-fn main() {
- let mut xs = <[Foo; 1]>::default();
- xs[0].x = 1;
- (&mut xs[0]).x = 2;
-}
diff --git a/tests/ui/traits/new-solver/tait-eq-proj-2.rs b/tests/ui/traits/new-solver/tait-eq-proj-2.rs
deleted file mode 100644
index 77ea8bc24..000000000
--- a/tests/ui/traits/new-solver/tait-eq-proj-2.rs
+++ /dev/null
@@ -1,23 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-#![feature(type_alias_impl_trait)]
-
-// Similar to tests/ui/traits/new-solver/tait-eq-proj.rs
-// but check the alias-sub relation in the other direction.
-
-type Tait = impl Iterator<Item = impl Sized>;
-
-fn mk<T>() -> T {
- todo!()
-}
-
-fn a(_: Tait) {
- let x: Tait = mk();
- let mut array = mk();
- let mut z = IntoIterator::into_iter(array);
- z = x;
- array = [0i32; 32];
-}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/tait-eq-proj.rs b/tests/ui/traits/new-solver/tait-eq-proj.rs
deleted file mode 100644
index 01ef2ec95..000000000
--- a/tests/ui/traits/new-solver/tait-eq-proj.rs
+++ /dev/null
@@ -1,35 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-#![feature(type_alias_impl_trait)]
-
-type Tait = impl Iterator<Item = impl Sized>;
-
-/*
-
-Consider the goal - AliasRelate(Tait, <[i32; 32] as IntoIterator>::IntoIter)
-which is registered on the line above.
-
-A. SubstRelate - fails (of course).
-
-B. NormalizesToRhs - Tait normalizes-to <[i32; 32] as IntoIterator>::IntoIter
- * infer definition - Tait := <[i32; 32] as IntoIterator>::IntoIter
-
-C. NormalizesToLhs - <[i32; 32] as IntoIterator>::IntoIter normalizes-to Tait
- * Find impl candidate, after substitute - std::array::IntoIter<i32, 32>
- * Equate std::array::IntoIter<i32, 32> and Tait
- * infer definition - Tait := std::array::IntoIter<i32, 32>
-
-B and C are not equal, but they are equivalent modulo normalization.
-
-We get around this by evaluating both the NormalizesToRhs and NormalizesToLhs
-goals together. Essentially:
- A alias-relate B if A normalizes-to B and B normalizes-to A.
-
-*/
-
-fn a(_: Tait) {
- let _: Tait = IntoIterator::into_iter([0i32; 32]);
-}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/tait-eq-tait.rs b/tests/ui/traits/new-solver/tait-eq-tait.rs
deleted file mode 100644
index 70d9dc0ea..000000000
--- a/tests/ui/traits/new-solver/tait-eq-tait.rs
+++ /dev/null
@@ -1,18 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-// Not exactly sure if this is the inference behavior we *want*,
-// but it is a side-effect of the lazy normalization of TAITs.
-
-#![feature(type_alias_impl_trait)]
-
-fn mk<T>() -> T {
- todo!()
-}
-
-fn main() {
- type Tait = impl Sized;
- type Tait2 = impl Sized;
- let x: Tait = 1u32;
- let y: Tait2 = x;
-}
diff --git a/tests/ui/traits/new-solver/temporary-ambiguity.rs b/tests/ui/traits/new-solver/temporary-ambiguity.rs
deleted file mode 100644
index c6c11a1a1..000000000
--- a/tests/ui/traits/new-solver/temporary-ambiguity.rs
+++ /dev/null
@@ -1,22 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-// Checks that we don't explode when we assemble >1 candidate for a goal.
-
-struct Wrapper<T>(T);
-
-trait Foo {}
-
-impl Foo for Wrapper<i32> {}
-
-impl Foo for Wrapper<()> {}
-
-fn needs_foo(_: impl Foo) {}
-
-fn main() {
- let mut x = Default::default();
- let w = Wrapper(x);
- needs_foo(w);
- x = 1;
- let _ = x;
-}
diff --git a/tests/ui/traits/new-solver/trait-upcast-lhs-needs-normalization.rs b/tests/ui/traits/new-solver/trait-upcast-lhs-needs-normalization.rs
deleted file mode 100644
index 43cd773bf..000000000
--- a/tests/ui/traits/new-solver/trait-upcast-lhs-needs-normalization.rs
+++ /dev/null
@@ -1,20 +0,0 @@
-// check-pass
-// compile-flags: -Ztrait-solver=next
-
-#![feature(trait_upcasting)]
-
-pub trait A {}
-pub trait B: A {}
-
-pub trait Mirror {
- type Assoc: ?Sized;
-}
-impl<T: ?Sized> Mirror for T {
- type Assoc = T;
-}
-
-pub fn foo<'a>(x: &'a <dyn B + 'static as Mirror>::Assoc) -> &'a (dyn A + 'static) {
- x
-}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/try-example.rs b/tests/ui/traits/new-solver/try-example.rs
deleted file mode 100644
index e826f3a00..000000000
--- a/tests/ui/traits/new-solver/try-example.rs
+++ /dev/null
@@ -1,28 +0,0 @@
-// check-pass
-// compile-flags: -Ztrait-solver=next
-
-use std::error::Error;
-
-fn main() -> Result<(), Box<dyn Error>> {
- let x: i32 = parse()?;
- Ok(())
-}
-
-trait Parse {}
-
-impl Parse for i32 {}
-
-#[derive(Debug)]
-struct ParseError;
-
-impl std::fmt::Display for ParseError {
- fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
- write!(f, "ParseError")
- }
-}
-
-impl Error for ParseError {}
-
-fn parse<T: Parse>() -> Result<T, ParseError> {
- todo!()
-}
diff --git a/tests/ui/traits/new-solver/two-projection-param-candidates-are-ambiguous.rs b/tests/ui/traits/new-solver/two-projection-param-candidates-are-ambiguous.rs
deleted file mode 100644
index 3c7fc0d81..000000000
--- a/tests/ui/traits/new-solver/two-projection-param-candidates-are-ambiguous.rs
+++ /dev/null
@@ -1,30 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-
-// When we're solving `<T as Foo>::Assoc = i32`, we actually first solve
-// `<T as Foo>::Assoc = ?1t`, then unify `?1t` with `i32`. That goal
-// with the inference variable is ambiguous when there are >1 param-env
-// candidates.
-
-// We don't unify the RHS of a projection goal eagerly when solving, both
-// for caching reasons and partly to make sure that we don't make the new
-// trait solver smarter than it should be.
-
-// This is (as far as I can tell) a forwards-compatible decision, but if you
-// make this test go from fail to pass, be sure you understand the implications!
-
-trait Foo {
- type Assoc;
-}
-
-trait Bar {}
-
-impl<T> Bar for T where T: Foo<Assoc = i32> {}
-
-fn needs_bar<T: Bar>() {}
-
-fn foo<T: Foo<Assoc = i32> + Foo<Assoc = u32>>() {
- needs_bar::<T>();
- //~^ ERROR type annotations needed: cannot satisfy `T: Bar`
-}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/two-projection-param-candidates-are-ambiguous.stderr b/tests/ui/traits/new-solver/two-projection-param-candidates-are-ambiguous.stderr
deleted file mode 100644
index b311ac6b5..000000000
--- a/tests/ui/traits/new-solver/two-projection-param-candidates-are-ambiguous.stderr
+++ /dev/null
@@ -1,17 +0,0 @@
-error[E0283]: type annotations needed: cannot satisfy `T: Bar`
- --> $DIR/two-projection-param-candidates-are-ambiguous.rs:26:17
- |
-LL | needs_bar::<T>();
- | ^
- |
- = note: cannot satisfy `T: Bar`
- = help: the trait `Bar` is implemented for `T`
-note: required by a bound in `needs_bar`
- --> $DIR/two-projection-param-candidates-are-ambiguous.rs:23:17
- |
-LL | fn needs_bar<T: Bar>() {}
- | ^^^ required by this bound in `needs_bar`
-
-error: aborting due to previous error
-
-For more information about this error, try `rustc --explain E0283`.
diff --git a/tests/ui/traits/new-solver/unevaluated-const-impl-trait-ref.fails.stderr b/tests/ui/traits/new-solver/unevaluated-const-impl-trait-ref.fails.stderr
deleted file mode 100644
index 072ac32a5..000000000
--- a/tests/ui/traits/new-solver/unevaluated-const-impl-trait-ref.fails.stderr
+++ /dev/null
@@ -1,18 +0,0 @@
-error[E0277]: the trait bound `(): Trait<1>` is not satisfied
- --> $DIR/unevaluated-const-impl-trait-ref.rs:20:13
- |
-LL | needs::<1>();
- | ^ the trait `Trait<1>` is not implemented for `()`
- |
- = help: the following other types implement trait `Trait<N>`:
- <() as Trait<0>>
- <() as Trait<2>>
-note: required by a bound in `needs`
- --> $DIR/unevaluated-const-impl-trait-ref.rs:10:38
- |
-LL | fn needs<const N: usize>() where (): Trait<N> {}
- | ^^^^^^^^ required by this bound in `needs`
-
-error: aborting due to previous error
-
-For more information about this error, try `rustc --explain E0277`.
diff --git a/tests/ui/traits/new-solver/unevaluated-const-impl-trait-ref.rs b/tests/ui/traits/new-solver/unevaluated-const-impl-trait-ref.rs
deleted file mode 100644
index 26c595bc9..000000000
--- a/tests/ui/traits/new-solver/unevaluated-const-impl-trait-ref.rs
+++ /dev/null
@@ -1,22 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// revisions: works fails
-//[works] check-pass
-
-trait Trait<const N: usize> {}
-
-impl Trait<{ 1 - 1 }> for () {}
-impl Trait<{ 1 + 1 }> for () {}
-
-fn needs<const N: usize>() where (): Trait<N> {}
-
-#[cfg(works)]
-fn main() {
- needs::<0>();
- needs::<2>();
-}
-
-#[cfg(fails)]
-fn main() {
- needs::<1>();
- //[fails]~^ ERROR the trait bound `(): Trait<1>` is not satisfied
-}
diff --git a/tests/ui/traits/new-solver/unsafe-auto-trait-impl.rs b/tests/ui/traits/new-solver/unsafe-auto-trait-impl.rs
deleted file mode 100644
index bcfc747eb..000000000
--- a/tests/ui/traits/new-solver/unsafe-auto-trait-impl.rs
+++ /dev/null
@@ -1,8 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-struct Foo(*mut ());
-
-unsafe impl Sync for Foo {}
-
-fn main() {}
diff --git a/tests/ui/traits/new-solver/unsize-although-ambiguous.rs b/tests/ui/traits/new-solver/unsize-although-ambiguous.rs
deleted file mode 100644
index 431988a5f..000000000
--- a/tests/ui/traits/new-solver/unsize-although-ambiguous.rs
+++ /dev/null
@@ -1,13 +0,0 @@
-// check-pass
-// compile-flags: -Ztrait-solver=next
-
-use std::fmt::Display;
-
-fn box_dyn_display(_: Box<dyn Display>) {}
-
-fn main() {
- // During coercion, we don't necessarily know whether `{integer}` implements
- // `Display`. Before, that would cause us to bail out in the coercion loop when
- // checking `{integer}: Unsize<dyn Display>`.
- box_dyn_display(Box::new(1));
-}
diff --git a/tests/ui/traits/new-solver/unsize-good.rs b/tests/ui/traits/new-solver/unsize-good.rs
deleted file mode 100644
index 87ed9cfd1..000000000
--- a/tests/ui/traits/new-solver/unsize-good.rs
+++ /dev/null
@@ -1,25 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-#![feature(unsized_tuple_coercion)]
-
-trait Foo {}
-
-impl Foo for i32 {}
-
-fn main() {
- // Unsizing via struct
- let _: Box<dyn Foo> = Box::new(1i32);
-
- // Slice unsizing
- let y = [1, 2, 3];
- let _: &[i32] = &y;
-
- // Tuple unsizing
- let hi = (1i32,);
- let _: &(dyn Foo,) = &hi;
-
- // Dropping auto traits
- let a: &(dyn Foo + Send) = &1;
- let _: &dyn Foo = a;
-}
diff --git a/tests/ui/traits/new-solver/upcast-right-substs.rs b/tests/ui/traits/new-solver/upcast-right-substs.rs
deleted file mode 100644
index c19c82acf..000000000
--- a/tests/ui/traits/new-solver/upcast-right-substs.rs
+++ /dev/null
@@ -1,14 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-// check-pass
-
-#![feature(trait_upcasting)]
-
-trait Foo: Bar<i32> + Bar<u32> {}
-
-trait Bar<T> {}
-
-fn main() {
- let x: &dyn Foo = todo!();
- let y: &dyn Bar<i32> = x;
- let z: &dyn Bar<u32> = x;
-}
diff --git a/tests/ui/traits/new-solver/upcast-wrong-substs.rs b/tests/ui/traits/new-solver/upcast-wrong-substs.rs
deleted file mode 100644
index f2d04d932..000000000
--- a/tests/ui/traits/new-solver/upcast-wrong-substs.rs
+++ /dev/null
@@ -1,13 +0,0 @@
-// compile-flags: -Ztrait-solver=next
-
-#![feature(trait_upcasting)]
-
-trait Foo: Bar<i32> + Bar<u32> {}
-
-trait Bar<T> {}
-
-fn main() {
- let x: &dyn Foo = todo!();
- let y: &dyn Bar<usize> = x;
- //~^ ERROR mismatched types
-}
diff --git a/tests/ui/traits/new-solver/upcast-wrong-substs.stderr b/tests/ui/traits/new-solver/upcast-wrong-substs.stderr
deleted file mode 100644
index 8623f395f..000000000
--- a/tests/ui/traits/new-solver/upcast-wrong-substs.stderr
+++ /dev/null
@@ -1,14 +0,0 @@
-error[E0308]: mismatched types
- --> $DIR/upcast-wrong-substs.rs:11:30
- |
-LL | let y: &dyn Bar<usize> = x;
- | --------------- ^ expected trait `Bar`, found trait `Foo`
- | |
- | expected due to this
- |
- = note: expected reference `&dyn Bar<usize>`
- found reference `&dyn Foo`
-
-error: aborting due to previous error
-
-For more information about this error, try `rustc --explain E0308`.
diff --git a/tests/ui/traits/new-solver/winnow-specializing-impls.rs b/tests/ui/traits/new-solver/winnow-specializing-impls.rs
deleted file mode 100644
index 06f64de74..000000000
--- a/tests/ui/traits/new-solver/winnow-specializing-impls.rs
+++ /dev/null
@@ -1,22 +0,0 @@
-// build-pass
-// compile-flags: -Ztrait-solver=next
-
-// Tests that the specializing impl `<() as Foo>` holds during codegen.
-
-#![feature(min_specialization)]
-
-trait Foo {
- fn bar();
-}
-
-impl<T> Foo for T {
- default fn bar() {}
-}
-
-impl Foo for () {
- fn bar() {}
-}
-
-fn main() {
- <() as Foo>::bar();
-}