diff options
| author | Michael Goulet <michael@errs.io> | 2024-04-15 20:13:31 -0400 |
|---|---|---|
| committer | Michael Goulet <michael@errs.io> | 2024-04-25 10:51:54 -0400 |
| commit | 870ed4bfa2be044bafba589b9d53def3f0a8b005 (patch) | |
| tree | 3e29f2605e688793f71ecfc7a65676029b79a0a5 | |
| parent | b2fea557f3ca616ec1b1e119132d3f4205ed2bc2 (diff) | |
| download | rust-870ed4bfa2be044bafba589b9d53def3f0a8b005.tar.gz rust-870ed4bfa2be044bafba589b9d53def3f0a8b005.zip | |
Add test
| -rw-r--r-- | tests/crashes/123461.rs | 5 | ||||
| -rw-r--r-- | tests/ui/transmute/ambiguity-in-closure-arg.rs | 11 | ||||
| -rw-r--r-- | tests/ui/transmute/ambiguity-in-closure-arg.stderr | 9 | ||||
| -rw-r--r-- | tests/ui/wf/closure-wf.rs | 11 | ||||
| -rw-r--r-- | tests/ui/wf/closure-wf.stderr | 20 |
5 files changed, 51 insertions, 5 deletions
diff --git a/tests/crashes/123461.rs b/tests/crashes/123461.rs deleted file mode 100644 index 6dbfb5c8092..00000000000 --- a/tests/crashes/123461.rs +++ /dev/null @@ -1,5 +0,0 @@ -//@ known-bug: #123461 - -fn main() { - let _: [_; unsafe { std::mem::transmute(|o_b: Option<_>| {}) }]; -} diff --git a/tests/ui/transmute/ambiguity-in-closure-arg.rs b/tests/ui/transmute/ambiguity-in-closure-arg.rs new file mode 100644 index 00000000000..4c2d1ce2ad4 --- /dev/null +++ b/tests/ui/transmute/ambiguity-in-closure-arg.rs @@ -0,0 +1,11 @@ +// Minimized test for <https://github.com/rust-lang/rust/issues/123461>. + +struct Unconstrained<T>(T); + +fn main() { + unsafe { std::mem::transmute::<_, ()>(|o_b: Unconstrained<_>| {}) }; + //~^ ERROR type annotations needed + // We unfortunately don't check `Wf(Unconstrained<_>)`, so we won't + // hit an ambiguity error before checking the transmute. That means + // we still may have inference variables in our transmute src. +} diff --git a/tests/ui/transmute/ambiguity-in-closure-arg.stderr b/tests/ui/transmute/ambiguity-in-closure-arg.stderr new file mode 100644 index 00000000000..24a10a6d210 --- /dev/null +++ b/tests/ui/transmute/ambiguity-in-closure-arg.stderr @@ -0,0 +1,9 @@ +error[E0282]: type annotations needed + --> $DIR/ambiguity-in-closure-arg.rs:6:44 + | +LL | unsafe { std::mem::transmute::<_, ()>(|o_b: Unconstrained<_>| {}) }; + | ^^^^^^^^^^^^^^^^^^^^^ cannot infer type + +error: aborting due to 1 previous error + +For more information about this error, try `rustc --explain E0282`. diff --git a/tests/ui/wf/closure-wf.rs b/tests/ui/wf/closure-wf.rs new file mode 100644 index 00000000000..48baeb30ce5 --- /dev/null +++ b/tests/ui/wf/closure-wf.rs @@ -0,0 +1,11 @@ +trait Bound {} +struct NeedsBound<T: Bound>(T); + +// Checks that we enforce that closure args are WF. + +fn constrain_inner<T, F: for<'a> FnOnce(&'a (), NeedsBound<T>)>(_: T, _: F) {} + +fn main() { + constrain_inner(1u32, |&(), _| ()); + //~^ ERROR the trait bound `u32: Bound` is not satisfied +} diff --git a/tests/ui/wf/closure-wf.stderr b/tests/ui/wf/closure-wf.stderr new file mode 100644 index 00000000000..4beef3bb7c5 --- /dev/null +++ b/tests/ui/wf/closure-wf.stderr @@ -0,0 +1,20 @@ +error[E0277]: the trait bound `u32: Bound` is not satisfied + --> $DIR/closure-wf.rs:9:33 + | +LL | constrain_inner(1u32, |&(), _| ()); + | ^ the trait `Bound` is not implemented for `u32` + | +help: this trait has no implementations, consider adding one + --> $DIR/closure-wf.rs:1:1 + | +LL | trait Bound {} + | ^^^^^^^^^^^ +note: required by a bound in `NeedsBound` + --> $DIR/closure-wf.rs:2:22 + | +LL | struct NeedsBound<T: Bound>(T); + | ^^^^^ required by this bound in `NeedsBound` + +error: aborting due to 1 previous error + +For more information about this error, try `rustc --explain E0277`. |
