about summary refs log tree commit diff
path: root/tests/ui/impl-trait/method-resolution3.rs
diff options
context:
space:
mode:
authorOli Scherer <git-spam-no-reply9815368754983@oli-obk.de>2024-04-15 11:20:33 +0000
committerOli Scherer <git-spam-no-reply9815368754983@oli-obk.de>2024-06-13 10:41:52 +0000
commitc75f7283bf52c6e2ec6a178f2b7717a4daddacf4 (patch)
tree05d2c77ddb1ba67d34880c15d0a271b7af1cb9dc /tests/ui/impl-trait/method-resolution3.rs
parentb28221e74f5f05d0f7a6212f99c9d5af868c0ed3 (diff)
downloadrust-c75f7283bf52c6e2ec6a178f2b7717a4daddacf4.tar.gz
rust-c75f7283bf52c6e2ec6a178f2b7717a4daddacf4.zip
Add some tests
Diffstat (limited to 'tests/ui/impl-trait/method-resolution3.rs')
-rw-r--r--tests/ui/impl-trait/method-resolution3.rs29
1 files changed, 29 insertions, 0 deletions
diff --git a/tests/ui/impl-trait/method-resolution3.rs b/tests/ui/impl-trait/method-resolution3.rs
new file mode 100644
index 00000000000..8474e2da7db
--- /dev/null
+++ b/tests/ui/impl-trait/method-resolution3.rs
@@ -0,0 +1,29 @@
+//! Check that we consider `Bar<impl Sized>` to successfully unify
+//! with both `Bar<u32>` and `Bar<i32>` (in isolation), so we bail
+//! out with ambiguity.
+
+//@ revisions: current next
+//@[next] compile-flags: -Znext-solver
+
+struct Bar<T>(T);
+
+impl Bar<u32> {
+    fn bar(self) {}
+}
+
+impl Bar<i32> {
+    fn bar(self) {}
+}
+
+fn foo(x: bool) -> Bar<impl Sized> {
+    //[current]~^ ERROR: cycle
+    if x {
+        let x = foo(false);
+        x.bar();
+        //[current]~^ ERROR: no method named `bar`
+        //[next]~^^ ERROR: multiple applicable items in scope
+    }
+    todo!()
+}
+
+fn main() {}