intrepid_core/extract/
message_json.rsuse crate::{Context, Frame};
use super::{Extractor, Message, MessageFrameError};
#[derive(Debug, Clone, PartialEq, Eq)]
pub struct MessageJson<T>(pub T);
impl<T, State> Extractor<State> for MessageJson<T>
where
T: serde::de::DeserializeOwned,
{
type Error = MessageFrameError;
fn extract(frame: Frame, context: &Context<State>) -> Result<Self, Self::Error>
where
Self: Sized,
{
let Message(message_frame) = Message::extract(frame, context)?;
let contents: T = serde_json::from_slice(&message_frame.data)
.map_err(MessageFrameError::MalformedJsonData)?;
Ok(Self(contents))
}
}
#[test]
fn message_json() -> crate::Result<()> {
let json = serde_json::to_vec(&vec![1, 2, 3]).expect("Couldn't make a byte vec");
let frame = Frame::message("/test", json, ());
let context = Context::<()>::default();
let MessageJson(message_data) =
MessageJson::<Vec<usize>>::extract_from_frame_and_state(frame, &context)?;
assert_eq!(message_data, vec![1, 2, 3]);
Ok(())
}
#[test]
fn wrong_frame_failure() -> crate::Result<()> {
use crate::{Error, ExtractorError};
let context = Context::<()>::default();
let result =
MessageJson::<Vec<usize>>::extract_from_frame_and_state(Frame::default(), &context);
assert!(matches!(
result.unwrap_err(),
Error::ExtractorError(ExtractorError::MessageFrameError(
MessageFrameError::WrongFrame(_)
))
),);
Ok(())
}
#[test]
fn extraction_failed_error() -> crate::Result<()> {
use crate::{Error, ExtractorError};
let frame = Frame::message("/test", vec![1, 2, 3], ());
let context = Context::<()>::default();
let result = MessageJson::<Vec<usize>>::extract_from_frame_and_state(frame, &context);
assert!(matches!(
result.unwrap_err(),
Error::ExtractorError(ExtractorError::MessageFrameError(
MessageFrameError::MalformedJsonData(_)
))
),);
Ok(())
}