use rust_mcp_sdk::schema::ContentBlock;
use std::sync::Arc;
#[allow(clippy::too_many_arguments)]
pub async fn run_test_command(
tool: &str,
crate_name: Option<&str>,
item_path: Option<&str>,
query: Option<&str>,
sort: Option<&str>,
version: Option<&str>,
limit: u32,
format: &str,
) -> Result<(), Box<dyn std::error::Error>> {
tracing::info!("Testing tool: {}", tool);
let cache_config = crate::cache::CacheConfig::default();
let cache = crate::cache::create_cache(&cache_config)?;
let cache_arc: Arc<dyn crate::cache::Cache> = Arc::from(cache);
let doc_service = Arc::new(crate::tools::docs::DocService::new(cache_arc)?);
let registry = crate::tools::create_default_registry(&doc_service);
match tool {
"lookup_crate" => {
execute_lookup_crate(crate_name, version, format, ®istry).await?;
}
"search_crates" => {
execute_search_crates(query, sort, limit, format, ®istry).await?;
}
"lookup_item" => {
execute_lookup_item(crate_name, item_path, version, format, ®istry).await?;
}
"health_check" => {
execute_health_check(®istry).await?;
}
_ => {
return Err(format!("Unknown tool: {tool}").into());
}
}
println!("Tool test completed");
Ok(())
}
async fn execute_lookup_crate(
crate_name: Option<&str>,
version: Option<&str>,
format: &str,
registry: &crate::tools::ToolRegistry,
) -> Result<(), Box<dyn std::error::Error>> {
if let Some(name) = crate_name {
println!("Testing crate lookup: {name} (version: {version:?})");
println!("Output format: {format}");
let mut arguments = serde_json::json!({
"crate_name": name,
"format": format
});
if let Some(v) = version {
arguments["version"] = serde_json::Value::String(v.to_string());
}
match registry.execute_tool("lookup_crate", arguments).await {
Ok(result) => print_tool_result(&result),
Err(e) => eprintln!("Tool execution failed: {e}"),
}
} else {
return Err("lookup_crate requires --crate-name parameter".into());
}
Ok(())
}
async fn execute_search_crates(
query: Option<&str>,
sort: Option<&str>,
limit: u32,
format: &str,
registry: &crate::tools::ToolRegistry,
) -> Result<(), Box<dyn std::error::Error>> {
if let Some(q) = query {
println!("Testing crate search: {q} (limit: {limit})");
println!("Sort order: {}", sort.unwrap_or("relevance"));
println!("Output format: {format}");
let mut arguments = serde_json::json!({
"query": q,
"limit": limit,
"format": format
});
if let Some(sort) = sort {
arguments["sort"] = serde_json::Value::String(sort.to_string());
}
match registry.execute_tool("search_crates", arguments).await {
Ok(result) => print_tool_result(&result),
Err(e) => eprintln!("Tool execution failed: {e}"),
}
} else {
return Err("search_crates requires --query parameter".into());
}
Ok(())
}
async fn execute_lookup_item(
crate_name: Option<&str>,
item_path: Option<&str>,
version: Option<&str>,
format: &str,
registry: &crate::tools::ToolRegistry,
) -> Result<(), Box<dyn std::error::Error>> {
if let (Some(name), Some(path)) = (crate_name, item_path) {
println!("Testing item lookup: {name}::{path} (version: {version:?})");
println!("Output format: {format}");
let mut arguments = serde_json::json!({
"crate_name": name,
"item_path": path,
"format": format
});
if let Some(v) = version {
arguments["version"] = serde_json::Value::String(v.to_string());
}
match registry.execute_tool("lookup_item", arguments).await {
Ok(result) => print_tool_result(&result),
Err(e) => eprintln!("Tool execution failed: {e}"),
}
} else {
return Err("lookup_item requires --crate-name and --item-path parameters".into());
}
Ok(())
}
async fn execute_health_check(
registry: &crate::tools::ToolRegistry,
) -> Result<(), Box<dyn std::error::Error>> {
println!("Testing health check");
let arguments = serde_json::json!({
"check_type": "all",
"verbose": true
});
match registry.execute_tool("health_check", arguments).await {
Ok(result) => print_tool_result(&result),
Err(e) => eprintln!("Tool execution failed: {e}"),
}
Ok(())
}
fn print_tool_result(result: &rust_mcp_sdk::schema::CallToolResult) {
println!("Tool executed successfully:");
if let Some(content) = result.content.first() {
match content {
ContentBlock::TextContent(text_content) => {
println!("{}", text_content.text);
}
other => {
println!("Non-text content: {other:?}");
}
}
}
}