crux_core::testing

Struct AppTester

Source
pub struct AppTester<App>
where App: App,
{ /* private fields */ }
Expand description

AppTester is a simplified execution environment for Crux apps for use in tests.

Create an instance of AppTester with your App and an Effect type using AppTester::default.

for example:

let app = AppTester::<ExampleApp, ExampleEffect>::default();

Implementations§

Source§

impl<App> AppTester<App>
where App: App,

Source

pub fn new(app: App) -> Self
where App::Capabilities: WithContext<App::Event, App::Effect>,

Create an AppTester instance for an existing app instance. This can be used if your App has a constructor other than Default, for example when used as a child app and expecting configuration from the parent

Source

pub fn update( &self, event: App::Event, model: &mut App::Model, ) -> Update<App::Effect, App::Event>

Run the app’s update function with an event and a model state

You can use the resulting Update to inspect the effects which were requested and potential further events dispatched by capabilities.

Source

pub fn resolve<Op: Operation>( &self, request: &mut Request<Op>, value: Op::Output, ) -> Result<Update<App::Effect, App::Event>>

Resolve an effect request from previous update with an operation output.

This potentially runs the app’s update function if the effect is completed, and produce another Update.

Source

pub fn resolve_to_event_then_update<Op: Operation>( &self, request: &mut Request<Op>, value: Op::Output, model: &mut App::Model, ) -> Update<App::Effect, App::Event>

Resolve an effect request from previous update, then run the resulting event

This helper is useful for the common case where one expects the effect to resolve to exactly one event, which should then be run by the app.

Source

pub fn view(&self, model: &App::Model) -> App::ViewModel

Run the app’s view function with a model state

Trait Implementations§

Source§

impl<App> AsRef<<App as App>::Capabilities> for AppTester<App>
where App: App,

Source§

fn as_ref(&self) -> &App::Capabilities

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl<App> Default for AppTester<App>
where App: App, App::Capabilities: WithContext<App::Event, App::Effect>,

Source§

fn default() -> Self

Returns the “default value” for a type. Read more

Auto Trait Implementations§

§

impl<App> Freeze for AppTester<App>
where App: Freeze, <App as App>::Capabilities: Freeze,

§

impl<App> !RefUnwindSafe for AppTester<App>

§

impl<App> Send for AppTester<App>
where App: Send, <App as App>::Capabilities: Send,

§

impl<App> Sync for AppTester<App>
where App: Sync, <App as App>::Capabilities: Sync,

§

impl<App> Unpin for AppTester<App>
where App: Unpin, <App as App>::Capabilities: Unpin,

§

impl<App> !UnwindSafe for AppTester<App>

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, 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, U> TryFrom<U> for T
where U: Into<T>,

Source§

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>,

Source§

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.