Vendor dependencies
Let's see how I like this workflow.
This commit is contained in:
parent
34d1830413
commit
9c435dc440
7500 changed files with 1665121 additions and 99 deletions
228
vendor/tokio/tests/task_blocking.rs
vendored
Normal file
228
vendor/tokio/tests/task_blocking.rs
vendored
Normal file
|
|
@ -0,0 +1,228 @@
|
|||
#![warn(rust_2018_idioms)]
|
||||
#![cfg(all(feature = "full", not(tokio_wasi)))] // Wasi doesn't support threads
|
||||
|
||||
use tokio::{runtime, task};
|
||||
use tokio_test::assert_ok;
|
||||
|
||||
use std::thread;
|
||||
use std::time::Duration;
|
||||
|
||||
mod support {
|
||||
pub(crate) mod mpsc_stream;
|
||||
}
|
||||
|
||||
#[tokio::test]
|
||||
async fn basic_blocking() {
|
||||
// Run a few times
|
||||
for _ in 0..100 {
|
||||
let out = assert_ok!(
|
||||
tokio::spawn(async {
|
||||
assert_ok!(
|
||||
task::spawn_blocking(|| {
|
||||
thread::sleep(Duration::from_millis(5));
|
||||
"hello"
|
||||
})
|
||||
.await
|
||||
)
|
||||
})
|
||||
.await
|
||||
);
|
||||
|
||||
assert_eq!(out, "hello");
|
||||
}
|
||||
}
|
||||
|
||||
#[tokio::test(flavor = "multi_thread")]
|
||||
async fn block_in_blocking() {
|
||||
// Run a few times
|
||||
for _ in 0..100 {
|
||||
let out = assert_ok!(
|
||||
tokio::spawn(async {
|
||||
assert_ok!(
|
||||
task::spawn_blocking(|| {
|
||||
task::block_in_place(|| {
|
||||
thread::sleep(Duration::from_millis(5));
|
||||
});
|
||||
"hello"
|
||||
})
|
||||
.await
|
||||
)
|
||||
})
|
||||
.await
|
||||
);
|
||||
|
||||
assert_eq!(out, "hello");
|
||||
}
|
||||
}
|
||||
|
||||
#[tokio::test(flavor = "multi_thread")]
|
||||
async fn block_in_block() {
|
||||
// Run a few times
|
||||
for _ in 0..100 {
|
||||
let out = assert_ok!(
|
||||
tokio::spawn(async {
|
||||
task::block_in_place(|| {
|
||||
task::block_in_place(|| {
|
||||
thread::sleep(Duration::from_millis(5));
|
||||
});
|
||||
"hello"
|
||||
})
|
||||
})
|
||||
.await
|
||||
);
|
||||
|
||||
assert_eq!(out, "hello");
|
||||
}
|
||||
}
|
||||
|
||||
#[tokio::test(flavor = "current_thread")]
|
||||
#[should_panic]
|
||||
async fn no_block_in_current_thread_scheduler() {
|
||||
task::block_in_place(|| {});
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn yes_block_in_threaded_block_on() {
|
||||
let rt = runtime::Runtime::new().unwrap();
|
||||
rt.block_on(async {
|
||||
task::block_in_place(|| {});
|
||||
});
|
||||
}
|
||||
|
||||
#[test]
|
||||
#[should_panic]
|
||||
fn no_block_in_current_thread_block_on() {
|
||||
let rt = runtime::Builder::new_current_thread().build().unwrap();
|
||||
rt.block_on(async {
|
||||
task::block_in_place(|| {});
|
||||
});
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn can_enter_current_thread_rt_from_within_block_in_place() {
|
||||
let outer = tokio::runtime::Runtime::new().unwrap();
|
||||
|
||||
outer.block_on(async {
|
||||
tokio::task::block_in_place(|| {
|
||||
let inner = tokio::runtime::Builder::new_current_thread()
|
||||
.build()
|
||||
.unwrap();
|
||||
|
||||
inner.block_on(async {})
|
||||
})
|
||||
});
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn useful_panic_message_when_dropping_rt_in_rt() {
|
||||
use std::panic::{catch_unwind, AssertUnwindSafe};
|
||||
|
||||
let outer = tokio::runtime::Runtime::new().unwrap();
|
||||
|
||||
let result = catch_unwind(AssertUnwindSafe(|| {
|
||||
outer.block_on(async {
|
||||
let _ = tokio::runtime::Builder::new_current_thread()
|
||||
.build()
|
||||
.unwrap();
|
||||
});
|
||||
}));
|
||||
|
||||
assert!(result.is_err());
|
||||
let err = result.unwrap_err();
|
||||
let err: &'static str = err.downcast_ref::<&'static str>().unwrap();
|
||||
|
||||
assert!(
|
||||
err.contains("Cannot drop a runtime"),
|
||||
"Wrong panic message: {:?}",
|
||||
err
|
||||
);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn can_shutdown_with_zero_timeout_in_runtime() {
|
||||
let outer = tokio::runtime::Runtime::new().unwrap();
|
||||
|
||||
outer.block_on(async {
|
||||
let rt = tokio::runtime::Builder::new_current_thread()
|
||||
.build()
|
||||
.unwrap();
|
||||
rt.shutdown_timeout(Duration::from_nanos(0));
|
||||
});
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn can_shutdown_now_in_runtime() {
|
||||
let outer = tokio::runtime::Runtime::new().unwrap();
|
||||
|
||||
outer.block_on(async {
|
||||
let rt = tokio::runtime::Builder::new_current_thread()
|
||||
.build()
|
||||
.unwrap();
|
||||
rt.shutdown_background();
|
||||
});
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn coop_disabled_in_block_in_place() {
|
||||
let outer = tokio::runtime::Builder::new_multi_thread()
|
||||
.enable_time()
|
||||
.build()
|
||||
.unwrap();
|
||||
|
||||
let (tx, rx) = support::mpsc_stream::unbounded_channel_stream();
|
||||
|
||||
for i in 0..200 {
|
||||
tx.send(i).unwrap();
|
||||
}
|
||||
drop(tx);
|
||||
|
||||
outer.block_on(async move {
|
||||
let jh = tokio::spawn(async move {
|
||||
tokio::task::block_in_place(move || {
|
||||
futures::executor::block_on(async move {
|
||||
use tokio_stream::StreamExt;
|
||||
assert_eq!(rx.fold(0, |n, _| n + 1).await, 200);
|
||||
})
|
||||
})
|
||||
});
|
||||
|
||||
tokio::time::timeout(Duration::from_secs(1), jh)
|
||||
.await
|
||||
.expect("timed out (probably hanging)")
|
||||
.unwrap()
|
||||
});
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn coop_disabled_in_block_in_place_in_block_on() {
|
||||
let (done_tx, done_rx) = std::sync::mpsc::channel();
|
||||
let done = done_tx.clone();
|
||||
thread::spawn(move || {
|
||||
let outer = tokio::runtime::Runtime::new().unwrap();
|
||||
|
||||
let (tx, rx) = support::mpsc_stream::unbounded_channel_stream();
|
||||
|
||||
for i in 0..200 {
|
||||
tx.send(i).unwrap();
|
||||
}
|
||||
drop(tx);
|
||||
|
||||
outer.block_on(async move {
|
||||
tokio::task::block_in_place(move || {
|
||||
futures::executor::block_on(async move {
|
||||
use tokio_stream::StreamExt;
|
||||
assert_eq!(rx.fold(0, |n, _| n + 1).await, 200);
|
||||
})
|
||||
})
|
||||
});
|
||||
|
||||
let _ = done.send(Ok(()));
|
||||
});
|
||||
|
||||
thread::spawn(move || {
|
||||
thread::sleep(Duration::from_secs(1));
|
||||
let _ = done_tx.send(Err("timed out (probably hanging)"));
|
||||
});
|
||||
|
||||
done_rx.recv().unwrap().unwrap();
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue