mirror of
https://github.com/Nutomic/ibis.git
synced 2024-11-29 10:01:10 +00:00
test setup function
This commit is contained in:
parent
f84c4f47f2
commit
12754a53bf
2 changed files with 68 additions and 72 deletions
|
@ -6,12 +6,22 @@ use reqwest::Client;
|
||||||
use serde::de::Deserialize;
|
use serde::de::Deserialize;
|
||||||
use serde::ser::Serialize;
|
use serde::ser::Serialize;
|
||||||
use std::sync::Once;
|
use std::sync::Once;
|
||||||
|
use tokio::task::JoinHandle;
|
||||||
use tracing::log::LevelFilter;
|
use tracing::log::LevelFilter;
|
||||||
use url::Url;
|
use url::Url;
|
||||||
|
use fediwiki::start;
|
||||||
|
|
||||||
pub static CLIENT: Lazy<Client> = Lazy::new(Client::new);
|
pub static CLIENT: Lazy<Client> = Lazy::new(Client::new);
|
||||||
|
|
||||||
pub fn setup() {
|
pub struct TestData {
|
||||||
|
pub hostname_alpha: &'static str,
|
||||||
|
pub hostname_beta:&'static str,
|
||||||
|
handle_alpha: JoinHandle<()>,
|
||||||
|
handle_beta: JoinHandle<()>,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl TestData {
|
||||||
|
pub fn start() -> Self {
|
||||||
static INIT: Once = Once::new();
|
static INIT: Once = Once::new();
|
||||||
INIT.call_once(|| {
|
INIT.call_once(|| {
|
||||||
env_logger::builder()
|
env_logger::builder()
|
||||||
|
@ -20,6 +30,28 @@ pub fn setup() {
|
||||||
.filter_module("fediwiki", LevelFilter::Info)
|
.filter_module("fediwiki", LevelFilter::Info)
|
||||||
.init();
|
.init();
|
||||||
});
|
});
|
||||||
|
|
||||||
|
let hostname_alpha = "localhost:8131";
|
||||||
|
let hostname_beta = "localhost:8132";
|
||||||
|
let handle_alpha = tokio::task::spawn(async {
|
||||||
|
start(hostname_alpha).await.unwrap();
|
||||||
|
});
|
||||||
|
let handle_beta = tokio::task::spawn(async {
|
||||||
|
start(hostname_beta).await.unwrap();
|
||||||
|
});
|
||||||
|
Self {
|
||||||
|
hostname_alpha,
|
||||||
|
hostname_beta,
|
||||||
|
handle_alpha,
|
||||||
|
handle_beta,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn stop(self) -> MyResult<()>{
|
||||||
|
self.handle_alpha.abort();
|
||||||
|
self.handle_beta.abort();
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub async fn get<T>(hostname: &str, endpoint: &str) -> MyResult<T>
|
pub async fn get<T>(hostname: &str, endpoint: &str) -> MyResult<T>
|
||||||
|
|
|
@ -2,31 +2,26 @@ extern crate fediwiki;
|
||||||
|
|
||||||
mod common;
|
mod common;
|
||||||
|
|
||||||
use crate::common::{follow_instance, get_query, patch, post, setup};
|
use crate::common::{follow_instance, get_query, patch, post, TestData};
|
||||||
use common::get;
|
use common::get;
|
||||||
use fediwiki::api::{CreateArticle, EditArticle, GetArticle, ResolveObject};
|
use fediwiki::api::{CreateArticle, EditArticle, GetArticle, ResolveObject};
|
||||||
use fediwiki::error::MyResult;
|
use fediwiki::error::MyResult;
|
||||||
use fediwiki::federation::objects::article::DbArticle;
|
use fediwiki::federation::objects::article::DbArticle;
|
||||||
use fediwiki::federation::objects::instance::DbInstance;
|
use fediwiki::federation::objects::instance::DbInstance;
|
||||||
use fediwiki::start;
|
|
||||||
use serial_test::serial;
|
use serial_test::serial;
|
||||||
use url::Url;
|
use url::Url;
|
||||||
|
|
||||||
#[tokio::test]
|
#[tokio::test]
|
||||||
#[serial]
|
#[serial]
|
||||||
async fn test_create_and_read_article() -> MyResult<()> {
|
async fn test_create_and_read_article() -> MyResult<()> {
|
||||||
setup();
|
let data = TestData::start();
|
||||||
let hostname = "localhost:8131";
|
|
||||||
let handle = tokio::task::spawn(async {
|
|
||||||
start(hostname).await.unwrap();
|
|
||||||
});
|
|
||||||
|
|
||||||
// error on nonexistent article
|
// error on nonexistent article
|
||||||
let get_article = GetArticle {
|
let get_article = GetArticle {
|
||||||
title: "Manu_Chao".to_string(),
|
title: "Manu_Chao".to_string(),
|
||||||
};
|
};
|
||||||
let not_found =
|
let not_found =
|
||||||
get_query::<DbArticle, _>(hostname, &"article".to_string(), Some(get_article.clone()))
|
get_query::<DbArticle, _>(data.hostname_alpha, &"article".to_string(), Some(get_article.clone()))
|
||||||
.await;
|
.await;
|
||||||
assert!(not_found.is_err());
|
assert!(not_found.is_err());
|
||||||
|
|
||||||
|
@ -35,73 +30,54 @@ async fn test_create_and_read_article() -> MyResult<()> {
|
||||||
title: get_article.title.to_string(),
|
title: get_article.title.to_string(),
|
||||||
text: "Lorem ipsum".to_string(),
|
text: "Lorem ipsum".to_string(),
|
||||||
};
|
};
|
||||||
let create_res: DbArticle = post(hostname, "article", &create_article).await?;
|
let create_res: DbArticle = post(data.hostname_alpha, "article", &create_article).await?;
|
||||||
assert_eq!(create_article.title, create_res.title);
|
assert_eq!(create_article.title, create_res.title);
|
||||||
assert!(create_res.local);
|
assert!(create_res.local);
|
||||||
|
|
||||||
// now article can be read
|
// now article can be read
|
||||||
let get_res: DbArticle =
|
let get_res: DbArticle =
|
||||||
get_query(hostname, &"article".to_string(), Some(get_article.clone())).await?;
|
get_query(data.hostname_alpha, &"article".to_string(), Some(get_article.clone())).await?;
|
||||||
assert_eq!(create_article.title, get_res.title);
|
assert_eq!(create_article.title, get_res.title);
|
||||||
assert_eq!(create_article.text, get_res.text);
|
assert_eq!(create_article.text, get_res.text);
|
||||||
assert!(get_res.local);
|
assert!(get_res.local);
|
||||||
|
|
||||||
handle.abort();
|
data.stop()
|
||||||
Ok(())
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[tokio::test]
|
#[tokio::test]
|
||||||
#[serial]
|
#[serial]
|
||||||
async fn test_follow_instance() -> MyResult<()> {
|
async fn test_follow_instance() -> MyResult<()> {
|
||||||
setup();
|
let data = TestData::start();
|
||||||
let hostname_alpha = "localhost:8131";
|
|
||||||
let hostname_beta = "localhost:8132";
|
|
||||||
let handle_alpha = tokio::task::spawn(async {
|
|
||||||
start(hostname_alpha).await.unwrap();
|
|
||||||
});
|
|
||||||
let handle_beta = tokio::task::spawn(async {
|
|
||||||
start(hostname_beta).await.unwrap();
|
|
||||||
});
|
|
||||||
|
|
||||||
// check initial state
|
// check initial state
|
||||||
let alpha_instance: DbInstance = get(hostname_alpha, "instance").await?;
|
let alpha_instance: DbInstance = get(data.hostname_alpha, "instance").await?;
|
||||||
assert_eq!(0, alpha_instance.follows.len());
|
assert_eq!(0, alpha_instance.follows.len());
|
||||||
let beta_instance: DbInstance = get(hostname_beta, "instance").await?;
|
let beta_instance: DbInstance = get(data.hostname_beta, "instance").await?;
|
||||||
assert_eq!(0, beta_instance.followers.len());
|
assert_eq!(0, beta_instance.followers.len());
|
||||||
|
|
||||||
common::follow_instance(hostname_alpha, &hostname_beta).await?;
|
follow_instance(data.hostname_alpha, &data.hostname_beta).await?;
|
||||||
|
|
||||||
// check that follow was federated
|
// check that follow was federated
|
||||||
let beta_instance: DbInstance = get(hostname_beta, "instance").await?;
|
let beta_instance: DbInstance = get(data.hostname_beta, "instance").await?;
|
||||||
assert_eq!(1, beta_instance.followers.len());
|
assert_eq!(1, beta_instance.followers.len());
|
||||||
|
|
||||||
let alpha_instance: DbInstance = get(hostname_alpha, "instance").await?;
|
let alpha_instance: DbInstance = get(data.hostname_alpha, "instance").await?;
|
||||||
assert_eq!(1, alpha_instance.follows.len());
|
assert_eq!(1, alpha_instance.follows.len());
|
||||||
|
|
||||||
handle_alpha.abort();
|
data.stop()
|
||||||
handle_beta.abort();
|
|
||||||
Ok(())
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[tokio::test]
|
#[tokio::test]
|
||||||
#[serial]
|
#[serial]
|
||||||
async fn test_synchronize_articles() -> MyResult<()> {
|
async fn test_synchronize_articles() -> MyResult<()> {
|
||||||
setup();
|
let data = TestData::start();
|
||||||
let hostname_alpha = "localhost:8131";
|
|
||||||
let hostname_beta = "localhost:8132";
|
|
||||||
let handle_alpha = tokio::task::spawn(async {
|
|
||||||
start(hostname_alpha).await.unwrap();
|
|
||||||
});
|
|
||||||
let handle_beta = tokio::task::spawn(async {
|
|
||||||
start(hostname_beta).await.unwrap();
|
|
||||||
});
|
|
||||||
|
|
||||||
// create article on alpha
|
// create article on alpha
|
||||||
let create_article = CreateArticle {
|
let create_article = CreateArticle {
|
||||||
title: "Manu_Chao".to_string(),
|
title: "Manu_Chao".to_string(),
|
||||||
text: "Lorem ipsum".to_string(),
|
text: "Lorem ipsum".to_string(),
|
||||||
};
|
};
|
||||||
let create_res: DbArticle = post(hostname_alpha, "article", &create_article).await?;
|
let create_res: DbArticle = post(data.hostname_alpha, "article", &create_article).await?;
|
||||||
assert_eq!(create_article.title, create_res.title);
|
assert_eq!(create_article.title, create_res.title);
|
||||||
assert!(create_res.local);
|
assert!(create_res.local);
|
||||||
|
|
||||||
|
@ -110,7 +86,7 @@ async fn test_synchronize_articles() -> MyResult<()> {
|
||||||
title: "Manu_Chao".to_string(),
|
title: "Manu_Chao".to_string(),
|
||||||
};
|
};
|
||||||
let get_res = get_query::<DbArticle, _>(
|
let get_res = get_query::<DbArticle, _>(
|
||||||
hostname_beta,
|
data.hostname_beta,
|
||||||
&"article".to_string(),
|
&"article".to_string(),
|
||||||
Some(get_article.clone()),
|
Some(get_article.clone()),
|
||||||
)
|
)
|
||||||
|
@ -119,13 +95,13 @@ async fn test_synchronize_articles() -> MyResult<()> {
|
||||||
|
|
||||||
// fetch alpha instance on beta, articles are also fetched automatically
|
// fetch alpha instance on beta, articles are also fetched automatically
|
||||||
let resolve_object = ResolveObject {
|
let resolve_object = ResolveObject {
|
||||||
id: Url::parse(&format!("http://{hostname_alpha}"))?,
|
id: Url::parse(&format!("http://{}", data.hostname_alpha))?,
|
||||||
};
|
};
|
||||||
get_query::<DbInstance, _>(hostname_beta, "resolve_object", Some(resolve_object)).await?;
|
get_query::<DbInstance, _>(data.hostname_beta, "resolve_object", Some(resolve_object)).await?;
|
||||||
|
|
||||||
// get the article and compare
|
// get the article and compare
|
||||||
let get_res: DbArticle = get_query(
|
let get_res: DbArticle = get_query(
|
||||||
hostname_beta,
|
data.hostname_beta,
|
||||||
&"article".to_string(),
|
&"article".to_string(),
|
||||||
Some(get_article.clone()),
|
Some(get_article.clone()),
|
||||||
)
|
)
|
||||||
|
@ -135,32 +111,22 @@ async fn test_synchronize_articles() -> MyResult<()> {
|
||||||
assert_eq!(create_article.text, get_res.text);
|
assert_eq!(create_article.text, get_res.text);
|
||||||
assert!(!get_res.local);
|
assert!(!get_res.local);
|
||||||
|
|
||||||
handle_alpha.abort();
|
data.stop()
|
||||||
handle_beta.abort();
|
|
||||||
Ok(())
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[tokio::test]
|
#[tokio::test]
|
||||||
#[serial]
|
#[serial]
|
||||||
async fn test_federate_article_changes() -> MyResult<()> {
|
async fn test_federate_article_changes() -> MyResult<()> {
|
||||||
setup();
|
let data = TestData::start();
|
||||||
let hostname_alpha = "localhost:8131";
|
|
||||||
let hostname_beta = "localhost:8132";
|
|
||||||
let handle_alpha = tokio::task::spawn(async {
|
|
||||||
start(hostname_alpha).await.unwrap();
|
|
||||||
});
|
|
||||||
let handle_beta = tokio::task::spawn(async {
|
|
||||||
start(hostname_beta).await.unwrap();
|
|
||||||
});
|
|
||||||
|
|
||||||
follow_instance(hostname_alpha, hostname_beta).await?;
|
follow_instance(data.hostname_alpha, data.hostname_beta).await?;
|
||||||
|
|
||||||
// create new article
|
// create new article
|
||||||
let create_form = CreateArticle {
|
let create_form = CreateArticle {
|
||||||
title: "Manu_Chao".to_string(),
|
title: "Manu_Chao".to_string(),
|
||||||
text: "Lorem ipsum".to_string(),
|
text: "Lorem ipsum".to_string(),
|
||||||
};
|
};
|
||||||
let create_res: DbArticle = post(hostname_beta, "article", &create_form).await?;
|
let create_res: DbArticle = post(data.hostname_beta, "article", &create_form).await?;
|
||||||
assert_eq!(create_res.title, create_form.title);
|
assert_eq!(create_res.title, create_form.title);
|
||||||
|
|
||||||
// article should be federated to alpha
|
// article should be federated to alpha
|
||||||
|
@ -168,7 +134,7 @@ async fn test_federate_article_changes() -> MyResult<()> {
|
||||||
title: create_res.title.clone(),
|
title: create_res.title.clone(),
|
||||||
};
|
};
|
||||||
let get_res =
|
let get_res =
|
||||||
get_query::<DbArticle, _>(hostname_alpha, "article", Some(get_article.clone())).await?;
|
get_query::<DbArticle, _>(data.hostname_alpha, "article", Some(get_article.clone())).await?;
|
||||||
assert_eq!(create_res.title, get_res.title);
|
assert_eq!(create_res.title, get_res.title);
|
||||||
assert_eq!(create_res.text, get_res.text);
|
assert_eq!(create_res.text, get_res.text);
|
||||||
|
|
||||||
|
@ -177,7 +143,7 @@ async fn test_federate_article_changes() -> MyResult<()> {
|
||||||
ap_id: create_res.ap_id,
|
ap_id: create_res.ap_id,
|
||||||
new_text: "Lorem Ipsum 2".to_string(),
|
new_text: "Lorem Ipsum 2".to_string(),
|
||||||
};
|
};
|
||||||
let edit_res: DbArticle = patch(hostname_beta, "article", &edit_form).await?;
|
let edit_res: DbArticle = patch(data.hostname_beta, "article", &edit_form).await?;
|
||||||
assert_eq!(edit_res.text, edit_form.new_text);
|
assert_eq!(edit_res.text, edit_form.new_text);
|
||||||
|
|
||||||
// edit should be federated to alpha
|
// edit should be federated to alpha
|
||||||
|
@ -185,11 +151,9 @@ async fn test_federate_article_changes() -> MyResult<()> {
|
||||||
title: edit_res.title.clone(),
|
title: edit_res.title.clone(),
|
||||||
};
|
};
|
||||||
let get_res =
|
let get_res =
|
||||||
get_query::<DbArticle, _>(hostname_alpha, "article", Some(get_article.clone())).await?;
|
get_query::<DbArticle, _>(data.hostname_alpha, "article", Some(get_article.clone())).await?;
|
||||||
assert_eq!(edit_res.title, get_res.title);
|
assert_eq!(edit_res.title, get_res.title);
|
||||||
assert_eq!(edit_res.text, get_res.text);
|
assert_eq!(edit_res.text, get_res.text);
|
||||||
|
|
||||||
handle_alpha.abort();
|
data.stop()
|
||||||
handle_beta.abort();
|
|
||||||
Ok(())
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue