Module tokio_test::task

source ·
Expand description

Futures task based helpers to easily test futures and manually written futures.

The Spawn type is used as a mock task harness that allows you to poll futures without needing to setup pinning or context. Any future can be polled but if the future requires the tokio async context you will need to ensure that you poll the Spawn within a tokio context, this means that as long as you are inside the runtime it will work and you can poll it via Spawn.

Spawn also supports [Stream] to call poll_next without pinning or context.

In addition to circumventing the need for pinning and context, Spawn also tracks the amount of times the future/task was woken. This can be useful to track if some leaf future notified the root task correctly.

§Example

use tokio_test::task;

let fut = async {};

let mut task = task::spawn(fut);

assert!(task.poll().is_ready(), "Task was not ready!");

Structs§

  • Future spawned on a mock task that can be used to poll the future or stream without needing pinning or context types.

Functions§

  • Spawn a future into a Spawn which wraps the future in a mocked executor.