pub struct MockSleepRuntime<R: Runtime> { /* private fields */ }
Expand description

A deprecated wrapper Runtime that overrides SleepProvider for the underlying runtime.

§Deprecated

The MockSleepProvider used here has some limitations. See its documentation for more information. Use MockRuntime for new tests.

Implementations§

source§

impl<R: Runtime> MockSleepRuntime<R>

source

pub fn new(runtime: R) -> Self

Create a new runtime that wraps runtime, but overrides its view of time with a MockSleepProvider.

source

pub fn inner(&self) -> &R

Return a reference to the underlying runtime.

source

pub fn mock_sleep(&self) -> &MockSleepProvider

Return a reference to the MockSleepProvider

source

pub async fn advance(&self, dur: Duration)

source

pub fn jump_to(&self, new_wallclock: SystemTime)

source

pub fn wait_for<F: Future>(&self, fut: F) -> WaitFor<F>

Run a future under mock time, advancing time forward where necessary until it completes. Users of this function should read the whole of this documentation before using!

NOTE Instead of using this, consider MockRuntime, which will fully isolate the test case (albeit at the cost of demanding manual management of the simulated time).

The returned future will run fut, expecting it to create Sleeping futures (as returned by MockSleepProvider::sleep() and similar functions). When all such created futures have been polled (indicating the future is waiting on them), time will be advanced in order that the first (or only) of said futures returns Ready. This process then repeats until fut returns Ready itself (as in, the returned wrapper future will wait for all created Sleeping futures to be polled, and advance time again).

Note: The above described algorithm interacts poorly with futures that spawn asynchronous background tasks, or otherwise expect work to complete in the background before time is advanced. These futures will need to make use of the SleepProvider::block_advance (and similar) APIs in order to prevent time advancing while said tasks complete; see the documentation for those APIs for more detail.

§Panics

Panics if another WaitFor future is already running. (If two ran simultaneously, they would both try and advance the same mock time clock, which would be bad.)

Trait Implementations§

source§

impl<R: Runtime> BlockOn for MockSleepRuntime<R>

source§

fn block_on<F: Future>(&self, future: F) -> F::Output

Run future until it is ready, and return its output.
source§

impl<R: Clone + Runtime> Clone for MockSleepRuntime<R>

source§

fn clone(&self) -> MockSleepRuntime<R>

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl<R: Debug + Runtime> Debug for MockSleepRuntime<R>

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<R: Runtime> SleepProvider for MockSleepRuntime<R>

§

type SleepFuture = <MockSleepProvider as SleepProvider>::SleepFuture

A future returned by SleepProvider::sleep()
source§

fn sleep(&self, dur: Duration) -> Self::SleepFuture

Return a future that will be ready after duration has elapsed.
source§

fn now(&self) -> Instant

Return the SleepProvider’s view of the current instant. Read more
source§

fn wallclock(&self) -> SystemTime

Return the SleepProvider’s view of the current wall-clock time. Read more
source§

fn block_advance<T: Into<String>>(&self, reason: T)

Signify that a test running under mock time shouldn’t advance time yet, with a given unique reason string. This is useful for making sure (mock) time doesn’t advance while things that might require some (real-world) time to complete do so, such as spawning a task on another thread. Read more
source§

fn release_advance<T: Into<String>>(&self, reason: T)

Signify that the reason to withhold time advancing provided in a call to block_advance no longer exists, and it’s fine to move time forward if nothing else is blocking advances. Read more
source§

fn allow_one_advance(&self, dur: Duration)

Allow a test running under mock time to advance time by the provided duration, even if the above block_advance API has been used. Read more
source§

impl<R: Runtime> Spawn for MockSleepRuntime<R>

source§

fn spawn_obj(&self, future: FutureObj<'static, ()>) -> Result<(), SpawnError>

Spawns a future that will be run to completion. Read more
§

fn status(&self) -> Result<(), SpawnError>

Determines whether the executor is able to spawn new tasks. Read more
source§

impl<R: Runtime> TcpProvider for MockSleepRuntime<R>

§

type TcpStream = <R as TcpProvider>::TcpStream

The type for the TCP connections returned by Self::connect().
§

type TcpListener = <R as TcpProvider>::TcpListener

The type for the TCP listeners returned by Self::listen().
source§

fn connect<'life0, 'life1, 'async_trait>( &'life0 self, addr: &'life1 SocketAddr ) -> Pin<Box<dyn Future<Output = IoResult<Self::TcpStream>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Launch a TCP connection to a given socket address. Read more
source§

fn listen<'life0, 'life1, 'async_trait>( &'life0 self, addr: &'life1 SocketAddr ) -> Pin<Box<dyn Future<Output = IoResult<Self::TcpListener>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Open a TCP listener on a given socket address.
source§

impl<R: Runtime> TlsProvider<<R as TcpProvider>::TcpStream> for MockSleepRuntime<R>

§

type Connector = <R as TlsProvider<<R as TcpProvider>::TcpStream>>::Connector

The Connector object that this provider can return.
§

type TlsStream = <R as TlsProvider<<R as TcpProvider>::TcpStream>>::TlsStream

The type of the stream returned by that connector.
source§

fn tls_connector(&self) -> Self::Connector

Return a TLS connector for use with this runtime.
source§

impl<R: Runtime> UdpProvider for MockSleepRuntime<R>

§

type UdpSocket = <R as UdpProvider>::UdpSocket

The type of Udp Socket returned by Self::bind()
source§

fn bind<'life0, 'life1, 'async_trait>( &'life0 self, addr: &'life1 SocketAddr ) -> Pin<Box<dyn Future<Output = IoResult<Self::UdpSocket>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Bind a local port to send and receive packets from

Auto Trait Implementations§

§

impl<R> RefUnwindSafe for MockSleepRuntime<R>
where R: RefUnwindSafe,

§

impl<R> Send for MockSleepRuntime<R>

§

impl<R> Sync for MockSleepRuntime<R>

§

impl<R> Unpin for MockSleepRuntime<R>
where R: Unpin,

§

impl<R> UnwindSafe for MockSleepRuntime<R>
where R: UnwindSafe,

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T> Instrument for T

source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> SleepProviderExt for T
where T: SleepProvider,

source§

fn timeout<F>( &self, duration: Duration, future: F ) -> Timeout<F, Self::SleepFuture>
where F: Future,

Wrap a Future with a timeout. Read more
source§

fn sleep_until_wallclock( &self, when: SystemTime ) -> SleepUntilWallclock<'_, Self>

Pause until the wall-clock is at when or later, trying to recover from clock jumps. Read more
§

impl<Sp> SpawnExt for Sp
where Sp: Spawn + ?Sized,

§

fn spawn<Fut>(&self, future: Fut) -> Result<(), SpawnError>
where Fut: Future<Output = ()> + Send + 'static,

Available on crate feature alloc only.
Spawns a task that polls the given future with output () to completion. Read more
§

fn spawn_with_handle<Fut>( &self, future: Fut ) -> Result<RemoteHandle<<Fut as Future>::Output>, SpawnError>
where Fut: Future + Send + 'static, <Fut as Future>::Output: Send,

Available on crate features channel and std only.
Spawns a task that polls the given future to completion and returns a future that resolves to the spawned future’s output. Read more
source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
source§

impl<T> WithSubscriber for T

source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

impl<T> Runtime for T
where T: Sync + Send + Spawn + BlockOn + Clone + SleepProvider + TcpProvider + TlsProvider<<T as TcpProvider>::TcpStream> + UdpProvider + Debug + 'static,