diff options
| author | Michael Goulet <michael@errs.io> | 2024-02-02 17:51:16 +0000 |
|---|---|---|
| committer | Michael Goulet <michael@errs.io> | 2024-02-09 00:13:52 +0000 |
| commit | 7a63d3f16a44ade84f7fd99a7257ff753eb1da1d (patch) | |
| tree | b1365014ebb8c20734ef99a4315f31a5f4d1c56a | |
| parent | 548929dc5e7558880108065e088b56a4a7e11205 (diff) | |
| download | rust-7a63d3f16a44ade84f7fd99a7257ff753eb1da1d.tar.gz rust-7a63d3f16a44ade84f7fd99a7257ff753eb1da1d.zip | |
Add tests for untested capabilities
| -rw-r--r-- | tests/ui/associated-type-bounds/higher-ranked.rs | 17 | ||||
| -rw-r--r-- | tests/ui/associated-type-bounds/nested-bounds-dont-eliminate-alias-bounds.rs | 37 |
2 files changed, 54 insertions, 0 deletions
diff --git a/tests/ui/associated-type-bounds/higher-ranked.rs b/tests/ui/associated-type-bounds/higher-ranked.rs new file mode 100644 index 00000000000..2bd5f316811 --- /dev/null +++ b/tests/ui/associated-type-bounds/higher-ranked.rs @@ -0,0 +1,17 @@ +// check-pass + +#![feature(associated_type_bounds)] + +trait A<'a> { + type Assoc: ?Sized; +} + +impl<'a> A<'a> for () { + type Assoc = &'a (); +} + +fn hello() -> impl for<'a> A<'a, Assoc: Sized> { + () +} + +fn main() {} diff --git a/tests/ui/associated-type-bounds/nested-bounds-dont-eliminate-alias-bounds.rs b/tests/ui/associated-type-bounds/nested-bounds-dont-eliminate-alias-bounds.rs new file mode 100644 index 00000000000..05e4e323d87 --- /dev/null +++ b/tests/ui/associated-type-bounds/nested-bounds-dont-eliminate-alias-bounds.rs @@ -0,0 +1,37 @@ +// check-pass + +#![feature(associated_type_bounds)] + +trait Trait1 { + type Assoc1: Bar; + + fn assoc(self) -> Self::Assoc1; +} + +impl Trait1 for () { + type Assoc1 = (); + fn assoc(self) {} +} + +trait Foo {} +impl Foo for () {} +trait Bar {} +impl Bar for () {} + +fn hello() -> impl Trait1<Assoc1: Foo> { + () +} + +fn world() { + // Tests that `Assoc1: Foo` bound in the RPIT doesn't disqualify + // the `Assoc1: Bar` bound in the item, as a nested RPIT desugaring + // would do. + + fn is_foo(_: impl Foo) {} + is_foo(hello().assoc()); + + fn is_bar(_: impl Bar) {} + is_bar(hello().assoc()); +} + +fn main() {} |
