veecle_os_test/lib.rs
1//! Utilities for testing actors.
2//!
3//! [`veecle_os_test::execute!`](crate::execute) can be used in place of [`veecle_os::runtime::execute!`](veecle_os_runtime::execute!)
4//! to write tests for actors.
5//!
6//! [`veecle_os_test::block_on_future`](block_on_future) can be used to block the current thread until the future resolves.
7//!
8//! The following example shows how to implement a test:
9//!
10//! ```
11//! use core::convert::Infallible;
12//!
13//! #[derive(Debug, Default, veecle_os_runtime::Storable)]
14//! pub struct Number(usize);
15//!
16//! #[derive(Debug, Default, veecle_os_runtime::Storable)]
17//! pub struct Total(usize);
18//! #
19//! # use veecle_os_runtime::{InitializedReader, Reader, Writer};
20//!
21//! // `total_actor` reads numbers from a `Number` reader, keeps a running
22//! // total, and writes running totals to a `Total` writer.
23//! #[veecle_os_runtime::actor]
24//! async fn total_actor(
25//! mut total: Writer<'_, Total>,
26//! mut numbers: InitializedReader<'_, Number>,
27//! ) -> Infallible {
28//! let mut sum: usize = 0;
29//! loop {
30//! numbers.wait_for_update().await.read(|value| {
31//! sum += value.0;
32//! });
33//!
34//! total.write(Total(sum)).await;
35//! }
36//! }
37//!
38//! // This test writes 1 and 2 to the `Number` slot and verifies that
39//! // `total_actor` writes 1 and 3 as the running totals.
40//!
41//! veecle_os_test::block_on_future(
42//! veecle_os_test::execute! {
43//! store: [Total, Number],
44//! actors: [TotalActor],
45//! validation: async |mut total_reader: Reader<'a, Total>, mut numbers_writer: Writer<'a, Number>| {
46//! numbers_writer.write(Number(0)).await;
47//! let mut total_reader = total_reader.wait_init().await;
48//! total_reader.wait_for_update().await.read(|value| {
49//! assert_eq!(value.0, 0);
50//! });
51//! numbers_writer.write(Number(1)).await;
52//! total_reader.wait_for_update().await.read(|value| {
53//! assert_eq!(value.0, 1);
54//! });
55//! numbers_writer.write(Number(2)).await;
56//! total_reader.wait_for_update().await.read(|value| {
57//! assert_eq!(value.0, 3);
58//! });
59//! }
60//! }
61//! );
62//! ```
63
64#![forbid(unsafe_code)]
65
66#[doc(hidden)]
67mod execute;
68
69/// Reexport of [`futures::executor::block_on`] for convenience.
70pub use futures::executor::block_on as block_on_future;
71
72/// Internal exports for `macro_rules!` purposes.
73#[doc(hidden)]
74pub mod __exports {
75 pub use ::veecle_os_runtime;
76 pub use futures;
77}