2023-02-11 13:05:37 +00:00
|
|
|
use crate::{
|
2023-03-02 14:18:06 +00:00
|
|
|
instance::{listen, new_instance, Webserver},
|
2023-02-19 12:26:01 +00:00
|
|
|
objects::post::DbPost,
|
2023-02-11 13:05:37 +00:00
|
|
|
utils::generate_object_id,
|
|
|
|
};
|
|
|
|
use error::Error;
|
2023-03-02 14:18:06 +00:00
|
|
|
use std::{env::args, str::FromStr};
|
2023-02-19 12:26:01 +00:00
|
|
|
use tracing::log::{info, LevelFilter};
|
2022-06-02 11:17:12 +00:00
|
|
|
|
|
|
|
mod activities;
|
2023-02-11 13:05:37 +00:00
|
|
|
#[cfg(feature = "actix-web")]
|
|
|
|
mod actix_web;
|
|
|
|
#[cfg(feature = "axum")]
|
|
|
|
mod axum;
|
2022-06-02 11:17:12 +00:00
|
|
|
mod error;
|
|
|
|
mod instance;
|
|
|
|
mod objects;
|
2022-11-26 16:12:08 +00:00
|
|
|
mod utils;
|
2022-06-02 11:17:12 +00:00
|
|
|
|
2023-06-20 09:54:14 +00:00
|
|
|
#[tokio::main]
|
2022-06-02 11:17:12 +00:00
|
|
|
async fn main() -> Result<(), Error> {
|
|
|
|
env_logger::builder()
|
2023-02-19 12:26:01 +00:00
|
|
|
.filter_level(LevelFilter::Warn)
|
2023-03-07 22:01:36 +00:00
|
|
|
.filter_module("activitypub_federation", LevelFilter::Info)
|
2023-02-19 12:26:01 +00:00
|
|
|
.filter_module("local_federation", LevelFilter::Info)
|
|
|
|
.format_timestamp(None)
|
2022-06-02 11:17:12 +00:00
|
|
|
.init();
|
|
|
|
|
2023-03-02 14:18:06 +00:00
|
|
|
info!("Start with parameter `axum` or `actix-web` to select the webserver");
|
|
|
|
let webserver = args()
|
|
|
|
.nth(1)
|
|
|
|
.map(|arg| Webserver::from_str(&arg).unwrap())
|
|
|
|
.unwrap_or(Webserver::Axum);
|
|
|
|
|
2023-06-20 09:54:14 +00:00
|
|
|
let alpha = new_instance("localhost:8001", "alpha".to_string()).await?;
|
|
|
|
let beta = new_instance("localhost:8002", "beta".to_string()).await?;
|
2023-03-02 14:18:06 +00:00
|
|
|
listen(&alpha, &webserver)?;
|
|
|
|
listen(&beta, &webserver)?;
|
2023-02-19 12:26:01 +00:00
|
|
|
info!("Local instances started");
|
2022-06-02 11:17:12 +00:00
|
|
|
|
2023-03-01 23:19:10 +00:00
|
|
|
info!("Alpha user follows beta user via webfinger");
|
2022-06-02 11:17:12 +00:00
|
|
|
alpha
|
|
|
|
.local_user()
|
2023-03-01 23:19:10 +00:00
|
|
|
.follow("beta@localhost:8002", &alpha.to_request_data())
|
2022-06-02 11:17:12 +00:00
|
|
|
.await?;
|
|
|
|
assert_eq!(
|
|
|
|
beta.local_user().followers(),
|
|
|
|
&vec![alpha.local_user().ap_id.inner().clone()]
|
|
|
|
);
|
2023-02-19 12:26:01 +00:00
|
|
|
info!("Follow was successful");
|
2022-06-02 11:17:12 +00:00
|
|
|
|
2023-02-19 12:26:01 +00:00
|
|
|
info!("Beta sends a post to its followers");
|
|
|
|
let sent_post = DbPost::new("Hello world!".to_string(), beta.local_user().ap_id)?;
|
2023-02-11 12:32:35 +00:00
|
|
|
beta.local_user()
|
|
|
|
.post(sent_post.clone(), &beta.to_request_data())
|
|
|
|
.await?;
|
2022-06-02 11:17:12 +00:00
|
|
|
let received_post = alpha.posts.lock().unwrap().first().cloned().unwrap();
|
2023-02-19 12:26:01 +00:00
|
|
|
info!("Alpha received post: {}", received_post.text);
|
2022-06-02 11:17:12 +00:00
|
|
|
|
|
|
|
// assert that alpha received the post
|
|
|
|
assert_eq!(received_post.text, sent_post.text);
|
|
|
|
assert_eq!(received_post.ap_id.inner(), sent_post.ap_id.inner());
|
|
|
|
assert_eq!(received_post.creator.inner(), sent_post.creator.inner());
|
2023-02-19 12:26:01 +00:00
|
|
|
info!("Test completed");
|
2022-06-02 11:17:12 +00:00
|
|
|
Ok(())
|
|
|
|
}
|