use crate::server::MemoryMCPServer;
use crate::types::SandboxConfig;
use do_memory_core::SelfLearningMemory;
use serde_json::json;
use std::sync::Arc;
async fn create_test_server() -> MemoryMCPServer {
let memory = Arc::new(SelfLearningMemory::new());
MemoryMCPServer::new(SandboxConfig::default(), memory)
.await
.unwrap()
}
#[tokio::test]
async fn test_server_creation() {
let server = create_test_server().await;
let tools = server.list_tools().await;
assert!(!tools.is_empty());
assert!(
tools.iter().any(|t| t.name == "query_memory"),
"query_memory tool should exist"
);
assert!(
tools.iter().any(|t| t.name == "analyze_patterns"),
"analyze_patterns tool should exist"
);
assert!(
tools.iter().any(|t| t.name == "health_check"),
"health_check tool should exist"
);
}
#[tokio::test]
async fn test_get_tool() {
let server = create_test_server().await;
let tool = server.get_tool("query_memory").await;
assert!(tool.is_some());
let tool = tool.unwrap();
assert_eq!(tool.name, "query_memory");
assert!(!tool.description.is_empty());
}
#[tokio::test]
async fn test_tool_usage_tracking() {
let server = create_test_server().await;
for _ in 0..3 {
let _ = server
.query_memory(
"test".to_string(),
"test".to_string(),
None,
10,
"relevance".to_string(),
None,
)
.await;
}
let usage = server.get_tool_usage().await;
assert_eq!(usage.get("query_memory"), Some(&3));
}
#[tokio::test]
async fn test_add_custom_tool() {
let server = create_test_server().await;
let custom_tool = crate::types::Tool::new(
"custom_tool".to_string(),
"A custom tool".to_string(),
json!({"type": "object"}),
);
let result = server.add_tool(custom_tool).await;
assert!(result.is_ok());
let tool = server.get_tool("custom_tool").await;
assert!(tool.is_some());
}
#[tokio::test]
async fn test_add_duplicate_tool_fails() {
let server = create_test_server().await;
let duplicate_tool = crate::types::Tool::new(
"query_memory".to_string(),
"Duplicate".to_string(),
json!({"type": "object"}),
);
let result = server.add_tool(duplicate_tool).await;
assert!(result.is_err());
}
#[tokio::test]
async fn test_remove_tool() {
let server = create_test_server().await;
let custom_tool = crate::types::Tool::new(
"temp_tool".to_string(),
"Temporary".to_string(),
json!({"type": "object"}),
);
server.add_tool(custom_tool).await.unwrap();
assert!(server.get_tool("temp_tool").await.is_some());
let result = server.remove_tool("temp_tool").await;
assert!(result.is_ok());
assert!(server.get_tool("temp_tool").await.is_none());
}
#[tokio::test]
async fn test_query_memory() {
let server = create_test_server().await;
let result = server
.query_memory(
"test query".to_string(),
"web-api".to_string(),
Some("code_generation".to_string()),
10,
"relevance".to_string(),
None,
)
.await;
assert!(result.is_ok());
let json = result.unwrap();
assert!(json.get("episodes").is_some());
assert!(json.get("patterns").is_some());
}
#[tokio::test]
async fn test_query_memory_negative_returns_empty() {
let server = create_test_server().await;
let result = server
.query_memory(
"tmp_rovodev_negative_test_unique_string".to_string(),
"verification".to_string(),
Some("analysis".to_string()),
10,
"relevance".to_string(),
None,
)
.await
.unwrap();
let episodes = result
.get("episodes")
.and_then(|v| v.as_array())
.expect("episodes should be an array");
assert!(
episodes.is_empty(),
"expected no episodes for unmatched query"
);
}
#[tokio::test]
async fn test_query_memory_with_sort_options() {
let server = create_test_server().await;
for sort in ["relevance", "newest", "oldest", "duration", "success"] {
let result = server
.query_memory(
"test".to_string(),
"test".to_string(),
None,
5,
sort.to_string(),
None,
)
.await;
assert!(result.is_ok(), "Sort option '{}' should be accepted", sort);
}
}
#[tokio::test]
async fn test_analyze_patterns() {
let server = create_test_server().await;
let result = server
.analyze_patterns("code_generation".to_string(), 0.7, 20, None)
.await;
assert!(result.is_ok());
let json = result.unwrap();
assert!(json.get("patterns").is_some());
assert!(json.get("statistics").is_some());
}