use schemars::JsonSchema;
use serde::{Deserialize, Serialize};
#[derive(Debug, Clone, PartialEq, Eq, Serialize, Deserialize, JsonSchema)]
pub struct ElicitToolOutput<T> {
pub value: T,
}
impl<T> ElicitToolOutput<T> {
pub fn new(value: T) -> Self {
Self { value }
}
pub fn into_inner(self) -> T {
self.value
}
}
impl<T> From<T> for ElicitToolOutput<T> {
fn from(value: T) -> Self {
Self::new(value)
}
}
impl<T> AsRef<T> for ElicitToolOutput<T> {
fn as_ref(&self) -> &T {
&self.value
}
}
impl<T> AsMut<T> for ElicitToolOutput<T> {
fn as_mut(&mut self) -> &mut T {
&mut self.value
}
}
#[cfg(test)]
mod tests {
use super::*;
#[derive(Debug, Clone, PartialEq, Eq, Serialize, Deserialize, JsonSchema)]
enum TestEnum {
A,
B,
C,
}
#[test]
fn test_wrapper_construction() {
let wrapped = ElicitToolOutput::new(TestEnum::A);
assert_eq!(wrapped.value, TestEnum::A);
}
#[test]
fn test_wrapper_into_inner() {
let wrapped = ElicitToolOutput::new(42);
assert_eq!(wrapped.into_inner(), 42);
}
#[test]
fn test_wrapper_from() {
let wrapped: ElicitToolOutput<i32> = 42.into();
assert_eq!(wrapped.value, 42);
}
#[test]
fn test_wrapper_as_ref() {
let wrapped = ElicitToolOutput::new(TestEnum::B);
assert_eq!(wrapped.as_ref(), &TestEnum::B);
}
#[test]
fn test_wrapper_serialization() {
let wrapped = ElicitToolOutput::new(TestEnum::C);
let json = serde_json::to_value(&wrapped).expect("Serialize");
assert!(json.is_object());
assert!(json.get("value").is_some());
}
#[test]
fn test_wrapper_schema_is_object() {
use schemars::schema_for;
let schema = schema_for!(ElicitToolOutput<TestEnum>);
assert!(
schema.as_object().is_some(),
"Wrapper schema must be object type"
);
let obj = schema.as_object().unwrap();
assert!(obj.get("properties").is_some());
}
}