mod testing;
use serde::Serialize;
use serde_json::json;
pub use testing::*;
use wasmbus_rpc::error::RpcResult;
impl Default for TestOptions {
fn default() -> TestOptions {
TestOptions {
patterns: vec![".*".to_string()],
options: std::collections::HashMap::default(),
}
}
}
pub type NamedResult<'name, T> = (&'name str, RpcResult<T>);
impl<'name, T: Serialize> From<NamedResult<'name, T>> for TestResult {
fn from(name_res: NamedResult<'name, T>) -> TestResult {
match name_res.1 {
Ok(res) => {
let data = match serde_json::to_vec(&res) {
Ok(v) => serde_json::to_vec(&json!({ "data": v })).unwrap_or_default(),
Err(_) => b"".to_vec(),
};
TestResult {
name: name_res.0.to_string(),
passed: true,
snap_data: Some(data),
}
}
Err(e) => {
let data = serde_json::to_vec(&json!(
{
"error": e.to_string(),
}
))
.ok();
TestResult {
name: name_res.0.to_string(),
passed: false,
snap_data: data,
}
}
}
}
}
#[test]
fn cbor_enc_dec() {
let x = SampleUnion::One("hello".to_string());
let bytes = rmp_serde::to_vec(&x).expect("serialize");
let y = rmp_serde::from_slice::<SampleUnion>(&bytes).expect("deser");
assert_eq!(x, y);
let x = SampleUnion::Two(TestResult {
name: "hello".to_string(),
passed: false,
snap_data: None,
});
let bytes = rmp_serde::to_vec(&x).expect("serialize");
let y = rmp_serde::from_slice::<SampleUnion>(&bytes).expect("deser");
assert_eq!(x, y);
}