2022-10-17 19:30:07 +02:00
|
|
|
use aes_gcm::{Aes256Gcm, KeyInit};
|
|
|
|
|
use multiaddr::Multiaddr;
|
|
|
|
|
use rand::thread_rng;
|
2023-09-27 19:19:59 -04:00
|
|
|
use secp256k1::SecretKey;
|
2023-01-27 11:35:07 +02:00
|
|
|
use serial_test::serial;
|
2022-10-17 19:30:07 +02:00
|
|
|
use std::time::{Duration, SystemTime};
|
2023-01-27 11:35:07 +02:00
|
|
|
use std::{collections::HashSet, str::from_utf8};
|
|
|
|
|
use tokio::sync::mpsc::{self, Sender};
|
|
|
|
|
use tokio::time;
|
2022-11-29 10:28:32 +01:00
|
|
|
use waku_bindings::{
|
2024-02-12 20:13:49 -04:00
|
|
|
waku_new, waku_set_event_callback, Encoding, Event, Key, MessageId, WakuContentTopic,
|
2023-11-07 15:50:35 -04:00
|
|
|
WakuMessage, WakuNodeConfig, WakuNodeHandle, WakuPubSubTopic,
|
2022-10-17 19:30:07 +02:00
|
|
|
};
|
|
|
|
|
|
2023-01-27 11:35:07 +02:00
|
|
|
const ECHO_TIMEOUT: u64 = 10;
|
|
|
|
|
const ECHO_MESSAGE: &str = "Hi from 🦀!";
|
|
|
|
|
|
2022-10-17 19:30:07 +02:00
|
|
|
const NODES: &[&str] = &[
|
|
|
|
|
"/dns4/node-01.ac-cn-hongkong-c.wakuv2.test.statusim.net/tcp/30303/p2p/16Uiu2HAkvWiyFsgRhuJEb9JfjYxEkoHLgnUQmr1N5mKWnYjxYRVm",
|
|
|
|
|
"/dns4/node-01.do-ams3.wakuv2.test.statusim.net/tcp/30303/p2p/16Uiu2HAmPLe7Mzm8TsYUubgCAW1aJoeFScxrLj8ppHFivPo97bUZ",
|
|
|
|
|
"/dns4/node-01.gc-us-central1-a.wakuv2.test.statusim.net/tcp/30303/p2p/16Uiu2HAmJb2e28qLXxT5kZxVUUoJt72EMzNGXB47Rxx5hw3q4YjS"
|
|
|
|
|
];
|
|
|
|
|
|
2023-01-27 11:35:07 +02:00
|
|
|
fn try_publish_relay_messages(
|
2024-02-12 20:13:49 -04:00
|
|
|
node: &WakuNodeHandle,
|
2023-01-27 11:35:07 +02:00
|
|
|
msg: &WakuMessage,
|
|
|
|
|
) -> Result<HashSet<MessageId>, String> {
|
2023-09-27 19:19:59 -04:00
|
|
|
Ok(HashSet::from(
|
|
|
|
|
[node.relay_publish_message(msg, None, None)?],
|
|
|
|
|
))
|
2023-01-27 11:35:07 +02:00
|
|
|
}
|
2022-10-17 19:30:07 +02:00
|
|
|
|
2023-01-27 11:35:07 +02:00
|
|
|
#[derive(Debug)]
|
|
|
|
|
struct Response {
|
|
|
|
|
id: MessageId,
|
|
|
|
|
payload: Vec<u8>,
|
|
|
|
|
}
|
2022-10-17 19:30:07 +02:00
|
|
|
|
2023-01-27 11:35:07 +02:00
|
|
|
fn set_callback(tx: Sender<Response>, sk: SecretKey, ssk: Key<Aes256Gcm>) {
|
|
|
|
|
waku_set_event_callback(move |signal| {
|
|
|
|
|
if let Event::WakuMessage(message) = signal.event() {
|
|
|
|
|
let id = message.message_id();
|
2022-10-17 19:30:07 +02:00
|
|
|
let message = message.waku_message();
|
2023-01-27 11:35:07 +02:00
|
|
|
|
2024-02-12 20:13:49 -04:00
|
|
|
let payload = message.payload().to_vec();
|
2023-01-27 11:35:07 +02:00
|
|
|
|
|
|
|
|
futures::executor::block_on(tx.send(Response {
|
|
|
|
|
id: id.to_string(),
|
|
|
|
|
payload,
|
|
|
|
|
}))
|
|
|
|
|
.expect("send response to the receiver");
|
2022-10-17 19:30:07 +02:00
|
|
|
}
|
|
|
|
|
});
|
2023-01-27 11:35:07 +02:00
|
|
|
}
|
2022-10-17 19:30:07 +02:00
|
|
|
|
2023-01-27 11:35:07 +02:00
|
|
|
async fn test_echo_messages(
|
2024-02-12 20:13:49 -04:00
|
|
|
node: &WakuNodeHandle,
|
2023-01-27 11:35:07 +02:00
|
|
|
content: &'static str,
|
|
|
|
|
content_topic: WakuContentTopic,
|
|
|
|
|
sk: SecretKey,
|
|
|
|
|
ssk: Key<Aes256Gcm>,
|
|
|
|
|
) {
|
2022-10-17 19:30:07 +02:00
|
|
|
let message = WakuMessage::new(
|
|
|
|
|
content,
|
|
|
|
|
content_topic,
|
|
|
|
|
1,
|
|
|
|
|
SystemTime::now()
|
|
|
|
|
.duration_since(SystemTime::UNIX_EPOCH)
|
|
|
|
|
.unwrap()
|
|
|
|
|
.as_millis()
|
|
|
|
|
.try_into()
|
|
|
|
|
.unwrap(),
|
2023-05-10 10:13:50 -04:00
|
|
|
Vec::new(),
|
|
|
|
|
false,
|
2022-10-17 19:30:07 +02:00
|
|
|
);
|
|
|
|
|
|
2023-01-27 11:35:07 +02:00
|
|
|
let (tx, mut rx) = mpsc::channel(1);
|
|
|
|
|
set_callback(tx, sk, ssk);
|
2022-10-17 19:30:07 +02:00
|
|
|
|
2023-09-27 19:19:59 -04:00
|
|
|
let mut ids = try_publish_relay_messages(node, &message).expect("send relay messages");
|
2023-01-27 11:35:07 +02:00
|
|
|
|
|
|
|
|
while let Some(res) = rx.recv().await {
|
|
|
|
|
if ids.take(&res.id).is_some() {
|
|
|
|
|
let msg = from_utf8(&res.payload).expect("should be valid message");
|
|
|
|
|
assert_eq!(content, msg);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if ids.is_empty() {
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#[ignore]
|
|
|
|
|
#[tokio::test]
|
|
|
|
|
#[serial]
|
|
|
|
|
async fn default_echo() -> Result<(), String> {
|
|
|
|
|
let config = WakuNodeConfig {
|
|
|
|
|
..Default::default()
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
let node = waku_new(Some(config))?;
|
2024-02-12 20:13:49 -04:00
|
|
|
|
|
|
|
|
node.start()?;
|
2023-01-27 11:35:07 +02:00
|
|
|
|
|
|
|
|
for node_address in NODES {
|
|
|
|
|
let address: Multiaddr = node_address.parse().unwrap();
|
2024-02-12 20:13:49 -04:00
|
|
|
node.connect(&address, None)?;
|
2023-01-27 11:35:07 +02:00
|
|
|
}
|
|
|
|
|
let sk = SecretKey::new(&mut thread_rng());
|
|
|
|
|
let ssk = Aes256Gcm::generate_key(&mut thread_rng());
|
|
|
|
|
|
|
|
|
|
// subscribe to default channel
|
2023-11-07 15:50:35 -04:00
|
|
|
node.relay_subscribe(&content_filter)?;
|
2024-02-12 20:13:49 -04:00
|
|
|
|
2023-12-08 17:30:30 -04:00
|
|
|
let content_topic = WakuContentTopic::new("toychat", "2", "huilong", Encoding::Proto);
|
2023-01-27 11:35:07 +02:00
|
|
|
|
|
|
|
|
let sleep = time::sleep(Duration::from_secs(ECHO_TIMEOUT));
|
|
|
|
|
tokio::pin!(sleep);
|
|
|
|
|
|
|
|
|
|
// Send and receive messages. Waits until all messages received.
|
|
|
|
|
let got_all = tokio::select! {
|
|
|
|
|
_ = sleep => false,
|
|
|
|
|
_ = test_echo_messages(&node, ECHO_MESSAGE, content_topic, sk, ssk) => true,
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
assert!(got_all);
|
2022-10-17 19:30:07 +02:00
|
|
|
|
2023-03-13 10:51:15 +02:00
|
|
|
node.stop()?;
|
|
|
|
|
Ok(())
|
|
|
|
|
}
|
|
|
|
|
|
2023-01-27 11:35:07 +02:00
|
|
|
#[test]
|
|
|
|
|
#[serial]
|
|
|
|
|
fn node_restart() {
|
|
|
|
|
let config = WakuNodeConfig::default();
|
|
|
|
|
|
|
|
|
|
for _ in 0..3 {
|
|
|
|
|
let node = waku_new(config.clone().into()).expect("default config should be valid");
|
|
|
|
|
|
2024-02-12 20:13:49 -04:00
|
|
|
node.start().expect("node should start with valid config");
|
|
|
|
|
|
2023-01-27 11:35:07 +02:00
|
|
|
node.stop().expect("node should stop");
|
|
|
|
|
}
|
|
|
|
|
}
|