update failing ui tests
This commit is contained in:
parent
5f56956b3c
commit
4ceca09586
@ -1,18 +1,25 @@
|
|||||||
error[E0277]: `Sender<i32>` cannot be shared between threads safely
|
error[E0277]: `*mut ()` cannot be shared between threads safely
|
||||||
--> $DIR/issue-70935-complex-spans.rs:13:45
|
--> $DIR/issue-70935-complex-spans.rs:18:23
|
||||||
|
|
|
|
||||||
LL | fn foo(tx: std::sync::mpsc::Sender<i32>) -> impl Future + Send {
|
LL | fn foo(x: NotSync) -> impl Future + Send {
|
||||||
| ^^^^^^^^^^^^^^^^^^ `Sender<i32>` cannot be shared between threads safely
|
| ^^^^^^^^^^^^^^^^^^ `*mut ()` cannot be shared between threads safely
|
||||||
|
|
|
|
||||||
= help: the trait `Sync` is not implemented for `Sender<i32>`
|
= help: within `NotSync`, the trait `Sync` is not implemented for `*mut ()`
|
||||||
= note: required for `&Sender<i32>` to implement `Send`
|
note: required because it appears within the type `PhantomData<*mut ()>`
|
||||||
|
--> $SRC_DIR/core/src/marker.rs:LL:COL
|
||||||
|
note: required because it appears within the type `NotSync`
|
||||||
|
--> $DIR/issue-70935-complex-spans.rs:12:8
|
||||||
|
|
|
||||||
|
LL | struct NotSync(PhantomData<*mut ()>);
|
||||||
|
| ^^^^^^^
|
||||||
|
= note: required for `&NotSync` to implement `Send`
|
||||||
note: required because it's used within this closure
|
note: required because it's used within this closure
|
||||||
--> $DIR/issue-70935-complex-spans.rs:17:13
|
--> $DIR/issue-70935-complex-spans.rs:22:13
|
||||||
|
|
|
|
||||||
LL | baz(|| async{
|
LL | baz(|| async {
|
||||||
| ^^
|
| ^^
|
||||||
note: required because it's used within this `async fn` body
|
note: required because it's used within this `async fn` body
|
||||||
--> $DIR/issue-70935-complex-spans.rs:10:67
|
--> $DIR/issue-70935-complex-spans.rs:15:67
|
||||||
|
|
|
|
||||||
LL | async fn baz<T>(_c: impl FnMut() -> T) where T: Future<Output=()> {
|
LL | async fn baz<T>(_c: impl FnMut() -> T) where T: Future<Output=()> {
|
||||||
| ___________________________________________________________________^
|
| ___________________________________________________________________^
|
||||||
@ -20,11 +27,11 @@ LL | | }
|
|||||||
| |_^
|
| |_^
|
||||||
= note: required because it captures the following types: `ResumeTy`, `impl Future<Output = ()>`, `()`
|
= note: required because it captures the following types: `ResumeTy`, `impl Future<Output = ()>`, `()`
|
||||||
note: required because it's used within this `async` block
|
note: required because it's used within this `async` block
|
||||||
--> $DIR/issue-70935-complex-spans.rs:16:5
|
--> $DIR/issue-70935-complex-spans.rs:21:5
|
||||||
|
|
|
|
||||||
LL | / async move {
|
LL | / async move {
|
||||||
LL | | baz(|| async{
|
LL | | baz(|| async {
|
||||||
LL | | foo(tx.clone());
|
LL | | foo(x.clone());
|
||||||
LL | | }).await;
|
LL | | }).await;
|
||||||
LL | | }
|
LL | | }
|
||||||
| |_____^
|
| |_____^
|
||||||
|
@ -1,18 +1,25 @@
|
|||||||
error[E0277]: `Sender<i32>` cannot be shared between threads safely
|
error[E0277]: `*mut ()` cannot be shared between threads safely
|
||||||
--> $DIR/issue-70935-complex-spans.rs:13:45
|
--> $DIR/issue-70935-complex-spans.rs:18:23
|
||||||
|
|
|
|
||||||
LL | fn foo(tx: std::sync::mpsc::Sender<i32>) -> impl Future + Send {
|
LL | fn foo(x: NotSync) -> impl Future + Send {
|
||||||
| ^^^^^^^^^^^^^^^^^^ `Sender<i32>` cannot be shared between threads safely
|
| ^^^^^^^^^^^^^^^^^^ `*mut ()` cannot be shared between threads safely
|
||||||
|
|
|
|
||||||
= help: the trait `Sync` is not implemented for `Sender<i32>`
|
= help: within `NotSync`, the trait `Sync` is not implemented for `*mut ()`
|
||||||
= note: required for `&Sender<i32>` to implement `Send`
|
note: required because it appears within the type `PhantomData<*mut ()>`
|
||||||
|
--> $SRC_DIR/core/src/marker.rs:LL:COL
|
||||||
|
note: required because it appears within the type `NotSync`
|
||||||
|
--> $DIR/issue-70935-complex-spans.rs:12:8
|
||||||
|
|
|
||||||
|
LL | struct NotSync(PhantomData<*mut ()>);
|
||||||
|
| ^^^^^^^
|
||||||
|
= note: required for `&NotSync` to implement `Send`
|
||||||
note: required because it's used within this closure
|
note: required because it's used within this closure
|
||||||
--> $DIR/issue-70935-complex-spans.rs:17:13
|
--> $DIR/issue-70935-complex-spans.rs:22:13
|
||||||
|
|
|
|
||||||
LL | baz(|| async{
|
LL | baz(|| async {
|
||||||
| ^^
|
| ^^
|
||||||
note: required because it's used within this `async fn` body
|
note: required because it's used within this `async fn` body
|
||||||
--> $DIR/issue-70935-complex-spans.rs:10:67
|
--> $DIR/issue-70935-complex-spans.rs:15:67
|
||||||
|
|
|
|
||||||
LL | async fn baz<T>(_c: impl FnMut() -> T) where T: Future<Output=()> {
|
LL | async fn baz<T>(_c: impl FnMut() -> T) where T: Future<Output=()> {
|
||||||
| ___________________________________________________________________^
|
| ___________________________________________________________________^
|
||||||
@ -20,11 +27,11 @@ LL | | }
|
|||||||
| |_^
|
| |_^
|
||||||
= note: required because it captures the following types: `impl Future<Output = ()>`
|
= note: required because it captures the following types: `impl Future<Output = ()>`
|
||||||
note: required because it's used within this `async` block
|
note: required because it's used within this `async` block
|
||||||
--> $DIR/issue-70935-complex-spans.rs:16:5
|
--> $DIR/issue-70935-complex-spans.rs:21:5
|
||||||
|
|
|
|
||||||
LL | / async move {
|
LL | / async move {
|
||||||
LL | | baz(|| async{
|
LL | | baz(|| async {
|
||||||
LL | | foo(tx.clone());
|
LL | | foo(x.clone());
|
||||||
LL | | }).await;
|
LL | | }).await;
|
||||||
LL | | }
|
LL | | }
|
||||||
| |_____^
|
| |_____^
|
||||||
|
@ -1,21 +1,21 @@
|
|||||||
error: future cannot be sent between threads safely
|
error: future cannot be sent between threads safely
|
||||||
--> $DIR/issue-70935-complex-spans.rs:13:45
|
--> $DIR/issue-70935-complex-spans.rs:18:23
|
||||||
|
|
|
|
||||||
LL | fn foo(tx: std::sync::mpsc::Sender<i32>) -> impl Future + Send {
|
LL | fn foo(x: NotSync) -> impl Future + Send {
|
||||||
| ^^^^^^^^^^^^^^^^^^ future created by async block is not `Send`
|
| ^^^^^^^^^^^^^^^^^^ future created by async block is not `Send`
|
||||||
|
|
|
|
||||||
= help: the trait `Sync` is not implemented for `Sender<i32>`
|
= help: within `NotSync`, the trait `Sync` is not implemented for `*mut ()`
|
||||||
note: future is not `Send` as this value is used across an await
|
note: future is not `Send` as this value is used across an await
|
||||||
--> $DIR/issue-70935-complex-spans.rs:19:12
|
--> $DIR/issue-70935-complex-spans.rs:24:12
|
||||||
|
|
|
|
||||||
LL | baz(|| async{
|
LL | baz(|| async {
|
||||||
| _____________-
|
| _____________-
|
||||||
LL | | foo(tx.clone());
|
LL | | foo(x.clone());
|
||||||
LL | | }).await;
|
LL | | }).await;
|
||||||
| | - ^^^^^- the value is later dropped here
|
| | - ^^^^^- the value is later dropped here
|
||||||
| | | |
|
| | | |
|
||||||
| |_________| await occurs here, with the value maybe used later
|
| |_________| await occurs here, with the value maybe used later
|
||||||
| has type `[closure@$DIR/issue-70935-complex-spans.rs:17:13: 17:15]` which is not `Send`
|
| has type `[closure@$DIR/issue-70935-complex-spans.rs:22:13: 22:15]` which is not `Send`
|
||||||
|
|
||||||
error: aborting due to previous error
|
error: aborting due to previous error
|
||||||
|
|
||||||
|
@ -6,16 +6,21 @@
|
|||||||
// with newlines which lead complex diagnostics.
|
// with newlines which lead complex diagnostics.
|
||||||
|
|
||||||
use std::future::Future;
|
use std::future::Future;
|
||||||
|
use std::marker::PhantomData;
|
||||||
|
|
||||||
|
#[derive(Clone)]
|
||||||
|
struct NotSync(PhantomData<*mut ()>);
|
||||||
|
unsafe impl Send for NotSync {}
|
||||||
|
|
||||||
async fn baz<T>(_c: impl FnMut() -> T) where T: Future<Output=()> {
|
async fn baz<T>(_c: impl FnMut() -> T) where T: Future<Output=()> {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn foo(tx: std::sync::mpsc::Sender<i32>) -> impl Future + Send {
|
fn foo(x: NotSync) -> impl Future + Send {
|
||||||
//[no_drop_tracking]~^ ERROR future cannot be sent between threads safely
|
//[no_drop_tracking]~^ ERROR future cannot be sent between threads safely
|
||||||
//[drop_tracking,drop_tracking_mir]~^^ ERROR `Sender<i32>` cannot be shared between threads
|
//[drop_tracking,drop_tracking_mir]~^^ ERROR `*mut ()` cannot be shared between threads
|
||||||
async move {
|
async move {
|
||||||
baz(|| async{
|
baz(|| async {
|
||||||
foo(tx.clone());
|
foo(x.clone());
|
||||||
}).await;
|
}).await;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -24,6 +29,6 @@ fn bar(_s: impl Future + Send) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
fn main() {
|
fn main() {
|
||||||
let (tx, _rx) = std::sync::mpsc::channel();
|
let x = NotSync(PhantomData);
|
||||||
bar(foo(tx));
|
bar(foo(x));
|
||||||
}
|
}
|
||||||
|
@ -13,10 +13,4 @@ fn bar() {
|
|||||||
t.join().unwrap();
|
t.join().unwrap();
|
||||||
}
|
}
|
||||||
|
|
||||||
fn foo() {
|
|
||||||
let (tx, _rx) = channel();
|
|
||||||
thread::spawn(|| tx.send(()).unwrap());
|
|
||||||
//~^ ERROR `Sender<()>` cannot be shared between threads safely
|
|
||||||
}
|
|
||||||
|
|
||||||
fn main() {}
|
fn main() {}
|
||||||
|
@ -20,24 +20,6 @@ LL | let t = thread::spawn(|| {
|
|||||||
note: required by a bound in `spawn`
|
note: required by a bound in `spawn`
|
||||||
--> $SRC_DIR/std/src/thread/mod.rs:LL:COL
|
--> $SRC_DIR/std/src/thread/mod.rs:LL:COL
|
||||||
|
|
||||||
error[E0277]: `Sender<()>` cannot be shared between threads safely
|
error: aborting due to previous error
|
||||||
--> $DIR/closure-move-sync.rs:18:19
|
|
||||||
|
|
|
||||||
LL | thread::spawn(|| tx.send(()).unwrap());
|
|
||||||
| ------------- ^^^^^^^^^^^^^^^^^^^^^^^ `Sender<()>` cannot be shared between threads safely
|
|
||||||
| |
|
|
||||||
| required by a bound introduced by this call
|
|
||||||
|
|
|
||||||
= help: the trait `Sync` is not implemented for `Sender<()>`
|
|
||||||
= note: required for `&Sender<()>` to implement `Send`
|
|
||||||
note: required because it's used within this closure
|
|
||||||
--> $DIR/closure-move-sync.rs:18:19
|
|
||||||
|
|
|
||||||
LL | thread::spawn(|| tx.send(()).unwrap());
|
|
||||||
| ^^
|
|
||||||
note: required by a bound in `spawn`
|
|
||||||
--> $SRC_DIR/std/src/thread/mod.rs:LL:COL
|
|
||||||
|
|
||||||
error: aborting due to 2 previous errors
|
|
||||||
|
|
||||||
For more information about this error, try `rustc --explain E0277`.
|
For more information about this error, try `rustc --explain E0277`.
|
||||||
|
@ -17,6 +17,4 @@ fn main() {
|
|||||||
|
|
||||||
test::<Receiver<i32>>();
|
test::<Receiver<i32>>();
|
||||||
//~^ ERROR `std::sync::mpsc::Receiver<i32>` cannot be shared between threads safely [E0277]
|
//~^ ERROR `std::sync::mpsc::Receiver<i32>` cannot be shared between threads safely [E0277]
|
||||||
test::<Sender<i32>>();
|
|
||||||
//~^ ERROR `Sender<i32>` cannot be shared between threads safely [E0277]
|
|
||||||
}
|
}
|
||||||
|
@ -65,19 +65,6 @@ note: required by a bound in `test`
|
|||||||
LL | fn test<T: Sync>() {}
|
LL | fn test<T: Sync>() {}
|
||||||
| ^^^^ required by this bound in `test`
|
| ^^^^ required by this bound in `test`
|
||||||
|
|
||||||
error[E0277]: `Sender<i32>` cannot be shared between threads safely
|
error: aborting due to 5 previous errors
|
||||||
--> $DIR/not-sync.rs:20:12
|
|
||||||
|
|
|
||||||
LL | test::<Sender<i32>>();
|
|
||||||
| ^^^^^^^^^^^ `Sender<i32>` cannot be shared between threads safely
|
|
||||||
|
|
|
||||||
= help: the trait `Sync` is not implemented for `Sender<i32>`
|
|
||||||
note: required by a bound in `test`
|
|
||||||
--> $DIR/not-sync.rs:5:12
|
|
||||||
|
|
|
||||||
LL | fn test<T: Sync>() {}
|
|
||||||
| ^^^^ required by this bound in `test`
|
|
||||||
|
|
||||||
error: aborting due to 6 previous errors
|
|
||||||
|
|
||||||
For more information about this error, try `rustc --explain E0277`.
|
For more information about this error, try `rustc --explain E0277`.
|
||||||
|
Loading…
x
Reference in New Issue
Block a user