2024-06-19 23:25:45 +02:00
|
|
|
/*
|
2024-06-19 23:27:10 +02:00
|
|
|
Eagle - A library for easy communication in full-stack Rust applications
|
2024-06-19 23:25:45 +02:00
|
|
|
Copyright (c) 2024 KodiCraft
|
|
|
|
|
|
|
|
This program is free software: you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU Affero General Public License as
|
|
|
|
published by the Free Software Foundation, either version 3 of the
|
|
|
|
License, or (at your option) any later version.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU Affero General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU Affero General Public License
|
|
|
|
along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
use eagle::Protocol;
|
2024-06-21 11:28:46 +02:00
|
|
|
use tokio::sync::mpsc::{self, Receiver, Sender};
|
2024-06-19 23:25:45 +02:00
|
|
|
|
|
|
|
#[derive(Protocol)]
|
|
|
|
enum TestProtocol {
|
|
|
|
Addition((i32, i32), i32),
|
|
|
|
SomeKindOfQuestion(String, i32),
|
2024-06-20 14:59:32 +02:00
|
|
|
ThisRespondsWithAString(i32, String),
|
|
|
|
Void((), ()),
|
2024-06-19 23:25:45 +02:00
|
|
|
}
|
|
|
|
|
2024-06-21 11:28:46 +02:00
|
|
|
#[tokio::test]
|
|
|
|
async fn main() {
|
|
|
|
let (qtx, qrx) = mpsc::channel(16);
|
|
|
|
let (atx, arx) = mpsc::channel(16);
|
2024-06-21 11:51:33 +02:00
|
|
|
let client = TestProtocolClient::new(qtx, arx);
|
2024-06-21 11:28:46 +02:00
|
|
|
let server = tokio::spawn(server_loop(qrx, atx));
|
|
|
|
let result = client.addition(2, 5).await.unwrap();
|
|
|
|
assert_eq!(result, 7);
|
|
|
|
let result = client
|
|
|
|
.some_kind_of_question("Hello, world!".to_string())
|
|
|
|
.await
|
|
|
|
.unwrap();
|
|
|
|
assert_eq!(result, "Hello, world!".len() as i32);
|
|
|
|
let result = client.this_responds_with_a_string(42).await.unwrap();
|
|
|
|
assert_eq!(result, "The number is 42");
|
|
|
|
client.void().await.unwrap();
|
|
|
|
server.abort();
|
|
|
|
}
|
2024-06-20 14:59:32 +02:00
|
|
|
|
2024-06-21 11:28:46 +02:00
|
|
|
async fn server_loop(
|
|
|
|
mut qrx: Receiver<(u64, __TestProtocolQuestion)>,
|
|
|
|
atx: Sender<(u64, __TestProtocolAnswer)>,
|
|
|
|
) {
|
|
|
|
loop {
|
|
|
|
if let Some((nonce, q)) = qrx.recv().await {
|
|
|
|
match q {
|
|
|
|
__TestProtocolQuestion::addition((a, b)) => {
|
|
|
|
atx.send((nonce, __TestProtocolAnswer::addition(a + b)))
|
|
|
|
.await
|
|
|
|
.unwrap();
|
|
|
|
}
|
|
|
|
__TestProtocolQuestion::some_kind_of_question(s) => {
|
|
|
|
atx.send((
|
|
|
|
nonce,
|
|
|
|
__TestProtocolAnswer::some_kind_of_question(s.len() as i32),
|
|
|
|
))
|
|
|
|
.await
|
|
|
|
.unwrap();
|
|
|
|
}
|
|
|
|
__TestProtocolQuestion::this_responds_with_a_string(i) => {
|
|
|
|
atx.send((
|
|
|
|
nonce,
|
|
|
|
__TestProtocolAnswer::this_responds_with_a_string(format!(
|
|
|
|
"The number is {}",
|
|
|
|
i
|
|
|
|
)),
|
|
|
|
))
|
|
|
|
.await
|
|
|
|
.unwrap();
|
|
|
|
}
|
|
|
|
__TestProtocolQuestion::void(()) => {
|
|
|
|
println!("Received void question");
|
|
|
|
atx.send((nonce, __TestProtocolAnswer::void(())))
|
|
|
|
.await
|
|
|
|
.unwrap();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2024-06-20 14:59:32 +02:00
|
|
|
}
|
2024-06-19 23:25:45 +02:00
|
|
|
}
|
2024-06-21 11:51:33 +02:00
|
|
|
|
|
|
|
#[tokio::test]
|
|
|
|
async fn heavy_async() {
|
|
|
|
let (qtx, qrx) = mpsc::channel(16);
|
|
|
|
let (atx, arx) = mpsc::channel(16);
|
|
|
|
let client = TestProtocolClient::new(qtx, arx);
|
|
|
|
let server = tokio::spawn(server_loop(qrx, atx));
|
|
|
|
let mut tasks = Vec::new();
|
|
|
|
for i in 0..100 {
|
|
|
|
let client = client.clone();
|
|
|
|
tasks.push(tokio::spawn(async move {
|
|
|
|
let result = client.addition(i, i).await.unwrap();
|
|
|
|
assert_eq!(result, i + i);
|
|
|
|
}));
|
|
|
|
}
|
|
|
|
for task in tasks {
|
|
|
|
task.await.unwrap();
|
|
|
|
}
|
|
|
|
server.abort();
|
|
|
|
}
|