pub struct SenderAndReceiverMock<P, T>where
P: PoolItem,
T: RequestWithResponse<P>,{ /* private fields */ }Expand description
This structure enables the mocking of a crate::ThreadPool
It has two constructors. One takes a vec of responses that are to be returned when send_and_receive is called, the other defines the requests that are expected to be received as well as an array of responses that are to be returned.
The implementation of send_and_receive asserts that the requests are as expected if requests are provided. If no requests are provided any requests passed in are ignored and the defined set of responses are returned
Implementations§
source§impl<P, T> SenderAndReceiverMock<P, T>where
P: PoolItem,
T: RequestWithResponse<P>,
impl<P, T> SenderAndReceiverMock<P, T>where
P: PoolItem,
T: RequestWithResponse<P>,
pub fn new_with_expected_requests( expected_requests: Vec<T>, returned_responses: Vec<T::Response> ) -> Self
pub fn new(returned_responses: Vec<T::Response>) -> Self
sourcepub fn was_called(&self) -> bool
pub fn was_called(&self) -> bool
Verify that the mock send_and_receive was called at least once
sourcepub fn is_complete(&self) -> bool
pub fn is_complete(&self) -> bool
Verify that all of the responses have been returned
sourcepub fn assert_is_complete(&self)
pub fn assert_is_complete(&self)
Assert that all of the responses have been returned; provides
Trait Implementations§
source§impl<P, T> Debug for SenderAndReceiverMock<P, T>
impl<P, T> Debug for SenderAndReceiverMock<P, T>
source§impl<P, T> Default for SenderAndReceiverMock<P, T>
impl<P, T> Default for SenderAndReceiverMock<P, T>
source§fn default() -> SenderAndReceiverMock<P, T>
fn default() -> SenderAndReceiverMock<P, T>
Returns the “default value” for a type. Read more
source§impl<P, T1> SenderAndReceiver<P> for SenderAndReceiverMock<P, T1>
impl<P, T1> SenderAndReceiver<P> for SenderAndReceiverMock<P, T1>
source§fn send_and_receive<'a, T>(
&'a self,
requests: impl Iterator<Item = T> + 'a
) -> Result<Box<dyn Iterator<Item = T::Response> + 'a>, SendError<SenderCouplet<P>>>where
T: RequestWithResponse<P> + 'a,
fn send_and_receive<'a, T>(
&'a self,
requests: impl Iterator<Item = T> + 'a
) -> Result<Box<dyn Iterator<Item = T::Response> + 'a>, SendError<SenderCouplet<P>>>where
T: RequestWithResponse<P> + 'a,
This function sends a request to a worker thread and receives a response back Read more
source§fn send_and_receive_one<'a, T>(
&'a self,
request: T
) -> Result<T::Response, SendError<SenderCouplet<P>>>where
T: RequestWithResponse<P> + IdTargeted + 'a,
fn send_and_receive_one<'a, T>(
&'a self,
request: T
) -> Result<T::Response, SendError<SenderCouplet<P>>>where
T: RequestWithResponse<P> + IdTargeted + 'a,
a default convenience function for dealing with the case when there is specifically
only one message to send and (therefore) only one response to receive
Auto Trait Implementations§
impl<P, T> !Freeze for SenderAndReceiverMock<P, T>
impl<P, T> RefUnwindSafe for SenderAndReceiverMock<P, T>
impl<P, T> Send for SenderAndReceiverMock<P, T>
impl<P, T> Sync for SenderAndReceiverMock<P, T>
impl<P, T> Unpin for SenderAndReceiverMock<P, T>
impl<P, T> UnwindSafe for SenderAndReceiverMock<P, T>
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more