use std::sync::Arc;
use bytes::Bytes;
use folk_api::Executor;
use folk_core::config::WorkersConfig;
use folk_core::runtime::MockRuntime;
use folk_core::worker_pool::WorkerPool;
#[tokio::test]
async fn execute_round_trips_through_mock_runtime() {
let rt = Arc::new(MockRuntime::echo());
let config = WorkersConfig {
count: 2,
..WorkersConfig::default()
};
let pool = WorkerPool::new(rt, config).unwrap();
tokio::time::sleep(std::time::Duration::from_millis(200)).await;
let payload = rmp_serde::to_vec(&"hello").unwrap();
let response = pool.execute(Bytes::from(payload)).await.unwrap();
let decoded: String = rmp_serde::from_slice(&response).unwrap();
assert_eq!(decoded, "hello");
}