#![allow(clippy::ptr_arg)]
#[allow(unused_imports)]
use async_trait::async_trait;
#[allow(unused_imports)]
use serde::{Deserialize, Serialize};
#[allow(unused_imports)]
use std::{borrow::Cow, string::ToString};
#[allow(unused_imports)]
use wasmbus_rpc::{
deserialize, serialize, Context, Message, MessageDispatch, RpcError, RpcResult, SendOpts,
Transport,
};
pub const SMITHY_VERSION: &str = "1.0";
pub type OptMap = std::collections::HashMap<String, String>;
pub type PatternList = Vec<String>;
#[derive(Clone, Debug, Deserialize, Eq, PartialEq, Serialize)]
pub struct TestOptions {
pub options: OptMap,
pub patterns: PatternList,
}
#[derive(Clone, Debug, Default, Deserialize, Eq, PartialEq, Serialize)]
pub struct TestResult {
#[serde(default)]
pub name: String,
#[serde(default)]
pub pass: bool,
#[serde(rename = "snapData")]
#[serde(with = "serde_bytes")]
#[serde(default, skip_serializing_if = "Option::is_none")]
pub snap_data: Option<Vec<u8>>,
}
pub type TestResults = Vec<TestResult>;
#[async_trait]
pub trait Testing {
fn contract_id() -> &'static str {
"wasmcloud:testing"
}
async fn start(&self, ctx: &Context, arg: &TestOptions) -> RpcResult<TestResults>;
}
#[doc(hidden)]
#[async_trait]
pub trait TestingReceiver: MessageDispatch + Testing {
async fn dispatch(&self, ctx: &Context, message: &Message<'_>) -> RpcResult<Message<'_>> {
match message.method {
"Start" => {
let value: TestOptions = deserialize(message.arg.as_ref())
.map_err(|e| RpcError::Deser(format!("message '{}': {}", message.method, e)))?;
let resp = Testing::start(self, ctx, &value).await?;
let buf = Cow::Owned(serialize(&resp)?);
Ok(Message {
method: "Testing.Start",
arg: buf,
})
}
_ => Err(RpcError::MethodNotHandled(format!(
"Testing::{}",
message.method
))),
}
}
}
#[derive(Debug)]
pub struct TestingSender<T: Transport> {
transport: T,
}
impl<T: Transport> TestingSender<T> {
pub fn via(transport: T) -> Self {
Self { transport }
}
}
#[cfg(not(target_arch = "wasm32"))]
impl<'send> TestingSender<wasmbus_rpc::provider::ProviderTransport<'send>> {
pub fn for_actor(ld: &'send wasmbus_rpc::core::LinkDefinition) -> Self {
Self {
transport: wasmbus_rpc::provider::ProviderTransport::new(ld, None),
}
}
}
#[cfg(target_arch = "wasm32")]
impl TestingSender<wasmbus_rpc::actor::prelude::WasmHost> {
pub fn to_actor(actor_id: &str) -> Self {
let transport =
wasmbus_rpc::actor::prelude::WasmHost::to_actor(actor_id.to_string()).unwrap();
Self { transport }
}
}
#[cfg(target_arch = "wasm32")]
impl TestingSender<wasmbus_rpc::actor::prelude::WasmHost> {
pub fn new() -> Self {
let transport =
wasmbus_rpc::actor::prelude::WasmHost::to_provider("wasmcloud:testing", "default")
.unwrap();
Self { transport }
}
pub fn new_with_link(link_name: &str) -> wasmbus_rpc::RpcResult<Self> {
let transport =
wasmbus_rpc::actor::prelude::WasmHost::to_provider("wasmcloud:testing", link_name)?;
Ok(Self { transport })
}
}
#[async_trait]
impl<T: Transport + std::marker::Sync + std::marker::Send> Testing for TestingSender<T> {
#[allow(unused)]
async fn start(&self, ctx: &Context, arg: &TestOptions) -> RpcResult<TestResults> {
let arg = serialize(arg)?;
let resp = self
.transport
.send(
ctx,
Message {
method: "Testing.Start",
arg: Cow::Borrowed(&arg),
},
None,
)
.await?;
let value = deserialize(&resp)
.map_err(|e| RpcError::Deser(format!("response to {}: {}", "Start", e)))?;
Ok(value)
}
}