1
0
Fork 0
mirror of https://github.com/Nutomic/ibis.git synced 2025-01-25 16:45:52 +00:00
ibis/tests/test.rs

565 lines
19 KiB
Rust
Raw Normal View History

2024-01-17 15:40:01 +00:00
extern crate ibis_lib;
2023-11-16 09:25:54 +00:00
2023-11-16 14:27:35 +00:00
mod common;
2024-01-17 16:14:16 +00:00
use crate::common::{TestData, TEST_ARTICLE_DEFAULT_TEXT};
2024-01-18 11:38:31 +00:00
use ibis_lib::common::SearchArticleData;
use ibis_lib::common::{ArticleView, EditArticleData, ForkArticleData, GetArticleData};
2024-01-18 11:18:17 +00:00
use ibis_lib::common::{LoginUserData, RegisterUserData};
2024-01-17 15:40:01 +00:00
use ibis_lib::frontend::error::MyResult;
2023-12-01 13:04:51 +00:00
use pretty_assertions::{assert_eq, assert_ne};
2023-11-16 11:48:57 +00:00
use url::Url;
2023-11-15 12:05:07 +00:00
#[tokio::test]
2024-01-17 15:40:01 +00:00
async fn test_create_read_and_edit_local_article() -> MyResult<()> {
let data = TestData::start().await;
2023-11-15 12:05:07 +00:00
2023-11-16 12:38:41 +00:00
// create article
let title = "Manu_Chao".to_string();
2024-01-17 16:14:16 +00:00
let create_res = data
.alpha
.create_article(title.clone(), TEST_ARTICLE_DEFAULT_TEXT.to_string())
.await?;
2023-11-30 14:55:05 +00:00
assert_eq!(title, create_res.article.title);
assert!(create_res.article.local);
2023-11-16 12:38:41 +00:00
// now article can be read
2024-01-17 15:40:01 +00:00
let get_article_data = GetArticleData {
title: Some(create_res.article.title.clone()),
instance_id: None,
id: None,
};
2024-01-17 16:14:16 +00:00
let get_res = data.alpha.get_article(get_article_data.clone()).await?;
2023-11-30 14:55:05 +00:00
assert_eq!(title, get_res.article.title);
assert_eq!(TEST_ARTICLE_DEFAULT_TEXT, get_res.article.text);
assert!(get_res.article.local);
2023-11-16 12:38:41 +00:00
// error on article which wasnt federated
2024-01-17 15:40:01 +00:00
let not_found = data.beta.get_article(get_article_data.clone()).await;
assert!(not_found.is_err());
// edit article
let edit_form = EditArticleData {
2023-11-30 14:55:05 +00:00
article_id: create_res.article.id,
2024-01-26 10:13:46 +00:00
new_text: "Lorem Ipsum 2\n".to_string(),
summary: "summary".to_string(),
2023-12-05 00:17:02 +00:00
previous_version_id: get_res.latest_version,
2023-11-27 15:34:45 +00:00
resolve_conflict_id: None,
};
2024-01-17 16:14:16 +00:00
let edit_res = data.alpha.edit_article(&edit_form).await?;
2023-11-30 14:55:05 +00:00
assert_eq!(edit_form.new_text, edit_res.article.text);
assert_eq!(2, edit_res.edits.len());
2024-01-26 10:13:46 +00:00
assert_eq!(edit_form.summary, edit_res.edits[1].summary);
let search_form = SearchArticleData {
2023-11-30 14:14:30 +00:00
query: title.clone(),
};
2024-01-17 16:14:16 +00:00
let search_res = data.alpha.search(&search_form).await?;
assert_eq!(1, search_res.len());
2023-11-30 14:55:05 +00:00
assert_eq!(edit_res.article, search_res[0]);
data.stop()
}
#[tokio::test]
async fn test_create_duplicate_article() -> MyResult<()> {
let data = TestData::start().await;
// create article
let title = "Manu_Chao".to_string();
2024-01-17 16:14:16 +00:00
let create_res = data
.alpha
.create_article(title.clone(), TEST_ARTICLE_DEFAULT_TEXT.to_string())
.await?;
2023-11-30 14:55:05 +00:00
assert_eq!(title, create_res.article.title);
assert!(create_res.article.local);
2024-01-17 16:14:16 +00:00
let create_res = data
.alpha
.create_article(title.clone(), TEST_ARTICLE_DEFAULT_TEXT.to_string())
.await;
assert!(create_res.is_err());
2023-11-17 13:36:56 +00:00
data.stop()
2023-11-15 12:05:07 +00:00
}
2023-11-15 14:07:02 +00:00
#[tokio::test]
2023-11-16 09:25:54 +00:00
async fn test_follow_instance() -> MyResult<()> {
let data = TestData::start().await;
2023-11-15 14:07:02 +00:00
2023-11-16 11:48:57 +00:00
// check initial state
2024-01-17 16:14:16 +00:00
let alpha_instance = data.alpha.get_local_instance().await?;
assert_eq!(0, alpha_instance.followers.len());
2023-12-04 14:10:07 +00:00
assert_eq!(0, alpha_instance.following.len());
2024-01-17 16:14:16 +00:00
let beta_instance = data.beta.get_local_instance().await?;
2023-11-16 11:48:57 +00:00
assert_eq!(0, beta_instance.followers.len());
2023-12-04 14:10:07 +00:00
assert_eq!(0, beta_instance.following.len());
2023-11-16 11:48:57 +00:00
2024-01-17 16:14:16 +00:00
data.alpha.follow_instance(&data.beta.hostname).await?;
2023-11-16 11:48:57 +00:00
// check that follow was federated
2024-01-17 16:14:16 +00:00
let alpha_instance = data.alpha.get_local_instance().await?;
2023-12-04 14:10:07 +00:00
assert_eq!(1, alpha_instance.following.len());
assert_eq!(0, alpha_instance.followers.len());
assert_eq!(
beta_instance.instance.ap_id,
alpha_instance.following[0].ap_id
);
2024-01-17 16:14:16 +00:00
let beta_instance = data.beta.get_local_instance().await?;
2023-12-04 14:10:07 +00:00
assert_eq!(0, beta_instance.following.len());
2023-11-16 11:48:57 +00:00
assert_eq!(1, beta_instance.followers.len());
2023-12-14 16:06:44 +00:00
// TODO: compare full ap_id of alpha user, but its not available through api yet
2023-12-04 14:10:07 +00:00
assert_eq!(
2023-12-14 16:06:44 +00:00
alpha_instance.instance.ap_id.inner().domain(),
beta_instance.followers[0].ap_id.inner().domain()
2023-12-04 14:10:07 +00:00
);
2023-11-16 09:25:54 +00:00
2023-11-17 13:36:56 +00:00
data.stop()
2023-11-16 09:25:54 +00:00
}
2023-12-01 11:11:19 +00:00
2023-11-16 15:40:43 +00:00
#[tokio::test]
async fn test_synchronize_articles() -> MyResult<()> {
let data = TestData::start().await;
2023-11-16 15:40:43 +00:00
// create article on alpha
2023-11-24 14:48:43 +00:00
let title = "Manu_Chao".to_string();
2024-01-17 16:14:16 +00:00
let create_res = data
.alpha
.create_article(title.clone(), TEST_ARTICLE_DEFAULT_TEXT.to_string())
.await?;
2023-11-30 14:55:05 +00:00
assert_eq!(title, create_res.article.title);
assert_eq!(1, create_res.edits.len());
2023-11-30 14:55:05 +00:00
assert!(create_res.article.local);
2023-11-16 15:40:43 +00:00
// edit the article
let edit_form = EditArticleData {
2023-11-30 14:55:05 +00:00
article_id: create_res.article.id,
new_text: "Lorem Ipsum 2\n".to_string(),
2024-01-26 10:13:46 +00:00
summary: "summary".to_string(),
2023-12-05 00:17:02 +00:00
previous_version_id: create_res.latest_version,
2023-11-27 15:34:45 +00:00
resolve_conflict_id: None,
};
2024-01-17 16:14:16 +00:00
data.alpha.edit_article(&edit_form).await?;
2023-11-16 15:40:43 +00:00
// fetch alpha instance on beta, articles are also fetched automatically
2024-01-18 11:18:17 +00:00
let instance = data
.beta
.resolve_instance(Url::parse(&format!("http://{}", &data.alpha.hostname))?)
.await?;
2023-11-16 15:40:43 +00:00
2024-01-17 15:40:01 +00:00
let mut get_article_data = GetArticleData {
title: Some(create_res.article.title),
instance_id: None,
id: None,
};
// try to read remote article by name, fails without domain
let get_res = data.beta.get_article(get_article_data.clone()).await;
assert!(get_res.is_err());
// get the article with instance id and compare
get_article_data.instance_id = Some(instance.id);
let get_res = data.beta.get_article(get_article_data).await?;
2023-11-30 14:55:05 +00:00
assert_eq!(create_res.article.ap_id, get_res.article.ap_id);
assert_eq!(title, get_res.article.title);
assert_eq!(2, get_res.edits.len());
2023-11-30 14:55:05 +00:00
assert_eq!(edit_form.new_text, get_res.article.text);
assert!(!get_res.article.local);
2023-11-16 15:40:43 +00:00
2023-11-17 13:36:56 +00:00
data.stop()
2023-11-16 15:40:43 +00:00
}
2023-11-17 13:22:31 +00:00
#[tokio::test]
async fn test_edit_local_article() -> MyResult<()> {
let data = TestData::start().await;
2023-11-17 13:36:56 +00:00
2024-01-17 16:14:16 +00:00
let beta_instance = data.alpha.follow_instance(&data.beta.hostname).await?;
2023-11-17 13:22:31 +00:00
// create new article
2023-11-24 14:48:43 +00:00
let title = "Manu_Chao".to_string();
2024-01-17 16:14:16 +00:00
let create_res = data
.beta
.create_article(title.clone(), TEST_ARTICLE_DEFAULT_TEXT.to_string())
.await?;
2023-11-30 14:55:05 +00:00
assert_eq!(title, create_res.article.title);
assert!(create_res.article.local);
2023-11-17 13:22:31 +00:00
// article should be federated to alpha
2024-01-17 15:40:01 +00:00
let get_article_data = GetArticleData {
title: Some(create_res.article.title.to_string()),
instance_id: Some(beta_instance.id),
id: None,
};
let get_res = data.alpha.get_article(get_article_data.clone()).await?;
2023-11-30 14:55:05 +00:00
assert_eq!(create_res.article.title, get_res.article.title);
assert_eq!(1, get_res.edits.len());
2023-11-30 14:55:05 +00:00
assert!(!get_res.article.local);
assert_eq!(create_res.article.text, get_res.article.text);
2023-11-17 13:22:31 +00:00
// edit the article
2023-11-21 15:27:18 +00:00
let edit_form = EditArticleData {
2023-11-30 14:55:05 +00:00
article_id: create_res.article.id,
2024-01-26 10:13:46 +00:00
new_text: "Lorem Ipsum 2\n".to_string(),
summary: "summary".to_string(),
2023-12-05 00:17:02 +00:00
previous_version_id: get_res.latest_version,
2023-11-27 15:34:45 +00:00
resolve_conflict_id: None,
2023-11-17 13:22:31 +00:00
};
2024-01-17 16:14:16 +00:00
let edit_res = data.beta.edit_article(&edit_form).await?;
2023-11-30 14:55:05 +00:00
assert_eq!(edit_res.article.text, edit_form.new_text);
assert_eq!(edit_res.edits.len(), 2);
2023-11-21 15:27:18 +00:00
assert!(edit_res.edits[0]
2023-11-30 14:55:05 +00:00
.ap_id
2023-11-21 15:27:18 +00:00
.to_string()
2023-11-30 14:55:05 +00:00
.starts_with(&edit_res.article.ap_id.to_string()));
2023-11-17 13:22:31 +00:00
// edit should be federated to alpha
2024-01-17 15:40:01 +00:00
let get_res = data.alpha.get_article(get_article_data).await?;
2023-11-30 14:55:05 +00:00
assert_eq!(edit_res.article.title, get_res.article.title);
assert_eq!(edit_res.edits.len(), 2);
2023-11-30 14:55:05 +00:00
assert_eq!(edit_res.article.text, get_res.article.text);
data.stop()
}
#[tokio::test]
async fn test_edit_remote_article() -> MyResult<()> {
let data = TestData::start().await;
2024-01-17 16:14:16 +00:00
let beta_id_on_alpha = data.alpha.follow_instance(&data.beta.hostname).await?;
let beta_id_on_gamma = data.gamma.follow_instance(&data.beta.hostname).await?;
// create new article
2023-11-24 14:48:43 +00:00
let title = "Manu_Chao".to_string();
2024-01-17 16:14:16 +00:00
let create_res = data
.beta
.create_article(title.clone(), TEST_ARTICLE_DEFAULT_TEXT.to_string())
.await?;
2024-01-17 15:40:01 +00:00
assert_eq!(&title, &create_res.article.title);
2023-11-30 14:55:05 +00:00
assert!(create_res.article.local);
// article should be federated to alpha and gamma
2024-01-17 15:40:01 +00:00
let get_article_data_alpha = GetArticleData {
title: Some(create_res.article.title.to_string()),
instance_id: Some(beta_id_on_alpha.id),
id: None,
};
let get_res = data
.alpha
.get_article(get_article_data_alpha.clone())
.await?;
2023-11-30 14:55:05 +00:00
assert_eq!(create_res.article.title, get_res.article.title);
assert_eq!(1, get_res.edits.len());
2023-11-30 14:55:05 +00:00
assert!(!get_res.article.local);
2024-01-17 15:40:01 +00:00
let get_article_data_gamma = GetArticleData {
title: Some(create_res.article.title.to_string()),
instance_id: Some(beta_id_on_gamma.id),
id: None,
};
let get_res = data
.gamma
.get_article(get_article_data_gamma.clone())
.await?;
2023-11-30 14:55:05 +00:00
assert_eq!(create_res.article.title, get_res.article.title);
assert_eq!(create_res.article.text, get_res.article.text);
let edit_form = EditArticleData {
2024-01-17 15:40:01 +00:00
article_id: get_res.article.id,
2024-01-26 10:13:46 +00:00
new_text: "Lorem Ipsum 2\n".to_string(),
summary: "summary".to_string(),
2023-12-05 00:17:02 +00:00
previous_version_id: get_res.latest_version,
2023-11-27 15:34:45 +00:00
resolve_conflict_id: None,
};
2024-01-17 16:14:16 +00:00
let edit_res = data.alpha.edit_article(&edit_form).await?;
2023-11-30 14:55:05 +00:00
assert_eq!(edit_form.new_text, edit_res.article.text);
assert_eq!(2, edit_res.edits.len());
2023-11-30 14:55:05 +00:00
assert!(!edit_res.article.local);
assert!(edit_res.edits[0]
2023-11-30 14:55:05 +00:00
.ap_id
.to_string()
2023-11-30 14:55:05 +00:00
.starts_with(&edit_res.article.ap_id.to_string()));
// edit should be federated to beta and gamma
2024-01-17 15:40:01 +00:00
let get_res = data.alpha.get_article(get_article_data_alpha).await?;
2023-11-30 14:55:05 +00:00
assert_eq!(edit_res.article.title, get_res.article.title);
assert_eq!(edit_res.edits.len(), 2);
2023-11-30 14:55:05 +00:00
assert_eq!(edit_res.article.text, get_res.article.text);
2024-01-17 15:40:01 +00:00
let get_res = data.gamma.get_article(get_article_data_gamma).await?;
2023-11-30 14:55:05 +00:00
assert_eq!(edit_res.article.title, get_res.article.title);
assert_eq!(edit_res.edits.len(), 2);
2023-11-30 14:55:05 +00:00
assert_eq!(edit_res.article.text, get_res.article.text);
2023-11-17 13:22:31 +00:00
2023-11-17 13:36:56 +00:00
data.stop()
2023-11-17 13:22:31 +00:00
}
2023-11-22 15:41:34 +00:00
#[tokio::test]
2023-11-27 15:34:45 +00:00
async fn test_local_edit_conflict() -> MyResult<()> {
let data = TestData::start().await;
2023-11-27 15:34:45 +00:00
// create new article
let title = "Manu_Chao".to_string();
2024-01-17 16:14:16 +00:00
let create_res = data
.alpha
.create_article(title.clone(), TEST_ARTICLE_DEFAULT_TEXT.to_string())
.await?;
2023-11-30 14:55:05 +00:00
assert_eq!(title, create_res.article.title);
assert!(create_res.article.local);
2023-11-27 15:34:45 +00:00
// one user edits article
let edit_form = EditArticleData {
2023-11-30 14:55:05 +00:00
article_id: create_res.article.id,
2023-11-27 15:34:45 +00:00
new_text: "Lorem Ipsum\n".to_string(),
2024-01-26 10:13:46 +00:00
summary: "summary".to_string(),
2023-12-05 00:17:02 +00:00
previous_version_id: create_res.latest_version.clone(),
2023-11-27 15:34:45 +00:00
resolve_conflict_id: None,
};
2024-01-17 16:14:16 +00:00
let edit_res = data.alpha.edit_article(&edit_form).await?;
2023-11-30 14:55:05 +00:00
assert_eq!(edit_res.article.text, edit_form.new_text);
2023-11-27 15:34:45 +00:00
assert_eq!(2, edit_res.edits.len());
// another user edits article, without being aware of previous edit
let edit_form = EditArticleData {
2023-11-30 14:55:05 +00:00
article_id: create_res.article.id,
2023-11-27 15:34:45 +00:00
new_text: "Ipsum Lorem\n".to_string(),
2024-01-26 10:13:46 +00:00
summary: "summary".to_string(),
2023-12-05 00:17:02 +00:00
previous_version_id: create_res.latest_version,
2023-11-27 15:34:45 +00:00
resolve_conflict_id: None,
};
2024-01-17 16:14:16 +00:00
let edit_res = data
.alpha
.edit_article_with_conflict(&edit_form)
2023-11-27 15:34:45 +00:00
.await?
.unwrap();
assert_eq!("<<<<<<< ours\nIpsum Lorem\n||||||| original\nsome\nexample\ntext\n=======\nLorem Ipsum\n>>>>>>> theirs\n", edit_res.three_way_merge);
2023-11-27 15:34:45 +00:00
2024-01-18 11:18:17 +00:00
let conflicts = data.alpha.get_conflicts().await?;
2023-11-27 15:34:45 +00:00
assert_eq!(1, conflicts.len());
assert_eq!(conflicts[0], edit_res);
let edit_form = EditArticleData {
2023-11-30 14:55:05 +00:00
article_id: create_res.article.id,
2023-11-27 15:34:45 +00:00
new_text: "Lorem Ipsum and Ipsum Lorem\n".to_string(),
2024-01-26 10:13:46 +00:00
summary: "summary".to_string(),
2023-12-05 00:17:02 +00:00
previous_version_id: edit_res.previous_version_id,
2023-11-27 15:34:45 +00:00
resolve_conflict_id: Some(edit_res.id),
};
2024-01-17 16:14:16 +00:00
let edit_res = data.alpha.edit_article(&edit_form).await?;
2023-11-30 14:55:05 +00:00
assert_eq!(edit_form.new_text, edit_res.article.text);
2023-11-27 15:34:45 +00:00
2024-01-18 11:18:17 +00:00
let conflicts = data.alpha.get_conflicts().await?;
2023-11-27 15:34:45 +00:00
assert_eq!(0, conflicts.len());
data.stop()
}
#[tokio::test]
async fn test_federated_edit_conflict() -> MyResult<()> {
let data = TestData::start().await;
2023-11-22 15:41:34 +00:00
2024-01-17 16:14:16 +00:00
let beta_id_on_alpha = data.alpha.follow_instance(&data.beta.hostname).await?;
2023-11-22 15:41:34 +00:00
// create new article
2023-11-24 14:48:43 +00:00
let title = "Manu_Chao".to_string();
2024-01-17 16:14:16 +00:00
let create_res = data
.beta
.create_article(title.clone(), TEST_ARTICLE_DEFAULT_TEXT.to_string())
.await?;
2023-11-30 14:55:05 +00:00
assert_eq!(title, create_res.article.title);
assert!(create_res.article.local);
2023-11-22 15:41:34 +00:00
2023-11-24 14:31:31 +00:00
// fetch article to gamma
2024-01-18 11:18:17 +00:00
let resolve_res: ArticleView = data
.gamma
.resolve_article(create_res.article.ap_id.inner().clone())
.await?;
2023-12-01 13:04:51 +00:00
assert_eq!(create_res.article.text, resolve_res.article.text);
2023-11-24 14:31:31 +00:00
2023-11-22 15:41:34 +00:00
// alpha edits article
2024-01-17 15:40:01 +00:00
let get_article_data = GetArticleData {
title: Some(title.to_string()),
instance_id: Some(beta_id_on_alpha.id),
id: None,
};
let get_res = data.alpha.get_article(get_article_data).await?;
assert_eq!(&create_res.edits.len(), &get_res.edits.len());
assert_eq!(&create_res.edits[0].hash, &get_res.edits[0].hash);
2023-11-22 15:41:34 +00:00
let edit_form = EditArticleData {
2024-01-17 15:40:01 +00:00
article_id: get_res.article.id,
new_text: "Lorem Ipsum\n".to_string(),
2024-01-26 10:13:46 +00:00
summary: "summary".to_string(),
2023-12-05 00:17:02 +00:00
previous_version_id: create_res.latest_version.clone(),
2023-11-27 15:34:45 +00:00
resolve_conflict_id: None,
2023-11-22 15:41:34 +00:00
};
2024-01-17 16:14:16 +00:00
let edit_res = data.alpha.edit_article(&edit_form).await?;
2023-11-30 14:55:05 +00:00
assert_eq!(edit_res.article.text, edit_form.new_text);
assert_eq!(2, edit_res.edits.len());
2023-11-30 14:55:05 +00:00
assert!(!edit_res.article.local);
assert!(edit_res.edits[1]
2023-11-30 14:55:05 +00:00
.ap_id
2023-11-22 15:41:34 +00:00
.to_string()
2023-11-30 14:55:05 +00:00
.starts_with(&edit_res.article.ap_id.to_string()));
2023-11-22 15:41:34 +00:00
// gamma also edits, as its not the latest version there is a conflict. local version should
// not be updated with this conflicting version, instead user needs to handle the conflict
2023-11-22 15:41:34 +00:00
let edit_form = EditArticleData {
2024-01-17 15:40:01 +00:00
article_id: resolve_res.article.id,
new_text: "aaaa\n".to_string(),
2024-01-26 10:13:46 +00:00
summary: "summary".to_string(),
2023-12-05 00:17:02 +00:00
previous_version_id: create_res.latest_version,
2023-11-27 15:34:45 +00:00
resolve_conflict_id: None,
2023-11-22 15:41:34 +00:00
};
2024-01-17 16:14:16 +00:00
let edit_res = data.gamma.edit_article(&edit_form).await?;
2023-11-30 14:55:05 +00:00
assert_ne!(edit_form.new_text, edit_res.article.text);
2023-12-05 11:54:38 +00:00
assert_eq!(1, edit_res.edits.len());
2023-11-30 14:55:05 +00:00
assert!(!edit_res.article.local);
2023-11-22 15:41:34 +00:00
2024-01-18 11:18:17 +00:00
let conflicts = data.gamma.get_conflicts().await?;
assert_eq!(1, conflicts.len());
2023-11-27 15:34:45 +00:00
// resolve the conflict
let edit_form = EditArticleData {
2024-01-17 15:40:01 +00:00
article_id: resolve_res.article.id,
2023-11-27 15:34:45 +00:00
new_text: "aaaa\n".to_string(),
2024-01-26 10:13:46 +00:00
summary: "summary".to_string(),
2023-12-05 00:17:02 +00:00
previous_version_id: conflicts[0].previous_version_id.clone(),
resolve_conflict_id: Some(conflicts[0].id.clone()),
2023-11-27 15:34:45 +00:00
};
2024-01-17 16:14:16 +00:00
let edit_res = data.gamma.edit_article(&edit_form).await?;
2023-11-30 14:55:05 +00:00
assert_eq!(edit_form.new_text, edit_res.article.text);
2023-11-27 15:34:45 +00:00
assert_eq!(3, edit_res.edits.len());
2024-01-18 11:18:17 +00:00
let conflicts = data.gamma.get_conflicts().await?;
2023-11-27 15:34:45 +00:00
assert_eq!(0, conflicts.len());
2023-11-22 15:41:34 +00:00
data.stop()
}
#[tokio::test]
async fn test_overlapping_edits_no_conflict() -> MyResult<()> {
let data = TestData::start().await;
// create new article
let title = "Manu_Chao".to_string();
2024-01-17 16:14:16 +00:00
let create_res = data
.alpha
.create_article(title.clone(), TEST_ARTICLE_DEFAULT_TEXT.to_string())
.await?;
2023-11-30 14:55:05 +00:00
assert_eq!(title, create_res.article.title);
assert!(create_res.article.local);
// one user edits article
let edit_form = EditArticleData {
2023-11-30 14:55:05 +00:00
article_id: create_res.article.id,
new_text: "my\nexample\ntext\n".to_string(),
2024-01-26 10:13:46 +00:00
summary: "summary".to_string(),
2023-12-05 00:17:02 +00:00
previous_version_id: create_res.latest_version.clone(),
resolve_conflict_id: None,
};
2024-01-17 16:14:16 +00:00
let edit_res = data.alpha.edit_article(&edit_form).await?;
2023-11-30 14:55:05 +00:00
assert_eq!(edit_res.article.text, edit_form.new_text);
assert_eq!(2, edit_res.edits.len());
// another user edits article, without being aware of previous edit
let edit_form = EditArticleData {
2023-11-30 14:55:05 +00:00
article_id: create_res.article.id,
new_text: "some\nexample\narticle\n".to_string(),
2024-01-26 10:13:46 +00:00
summary: "summary".to_string(),
2023-12-05 00:17:02 +00:00
previous_version_id: create_res.latest_version,
resolve_conflict_id: None,
};
2024-01-17 16:14:16 +00:00
let edit_res = data.alpha.edit_article(&edit_form).await?;
2024-01-18 11:18:17 +00:00
let conflicts = data.alpha.get_conflicts().await?;
assert_eq!(0, conflicts.len());
assert_eq!(3, edit_res.edits.len());
2023-11-30 14:55:05 +00:00
assert_eq!("my\nexample\narticle\n", edit_res.article.text);
data.stop()
}
#[tokio::test]
async fn test_fork_article() -> MyResult<()> {
let data = TestData::start().await;
// create article
let title = "Manu_Chao".to_string();
2024-01-17 16:14:16 +00:00
let create_res = data
.alpha
.create_article(title.clone(), TEST_ARTICLE_DEFAULT_TEXT.to_string())
.await?;
2023-11-30 14:55:05 +00:00
assert_eq!(title, create_res.article.title);
assert!(create_res.article.local);
// fetch on beta
2024-01-18 11:18:17 +00:00
let resolve_res = data
.beta
.resolve_article(create_res.article.ap_id.into_inner())
.await?;
2023-11-30 14:55:05 +00:00
let resolved_article = resolve_res.article;
assert_eq!(create_res.edits.len(), resolve_res.edits.len());
// fork the article to local instance
let fork_form = ForkArticleData {
2023-11-30 14:14:30 +00:00
article_id: resolved_article.id,
};
2024-01-18 11:18:17 +00:00
let fork_res = data.beta.fork_article(&fork_form).await?;
2023-11-30 14:55:05 +00:00
let forked_article = fork_res.article;
assert_eq!(resolved_article.title, forked_article.title);
assert_eq!(resolved_article.text, forked_article.text);
2023-12-01 13:04:51 +00:00
assert_eq!(resolve_res.edits.len(), fork_res.edits.len());
assert_eq!(resolve_res.edits[0].diff, fork_res.edits[0].diff);
2023-12-05 00:17:02 +00:00
assert_eq!(resolve_res.edits[0].hash, fork_res.edits[0].hash);
2023-12-01 13:04:51 +00:00
assert_ne!(resolve_res.edits[0].id, fork_res.edits[0].id);
assert_eq!(resolve_res.latest_version, fork_res.latest_version);
2023-11-30 14:55:05 +00:00
assert_ne!(resolved_article.ap_id, forked_article.ap_id);
assert!(forked_article.local);
2024-01-17 16:14:16 +00:00
let beta_instance = data.beta.get_local_instance().await?;
assert_eq!(forked_article.instance_id, beta_instance.instance.id);
// now search returns two articles for this title (original and forked)
let search_form = SearchArticleData {
2023-11-30 14:14:30 +00:00
query: title.clone(),
};
2024-01-17 16:14:16 +00:00
let search_res = data.beta.search(&search_form).await?;
assert_eq!(2, search_res.len());
data.stop()
}
2023-12-08 21:21:31 +00:00
#[tokio::test]
async fn test_user_registration_login() -> MyResult<()> {
let data = TestData::start().await;
2023-12-13 15:58:29 +00:00
let username = "my_user";
let password = "hunter2";
2024-01-17 15:40:01 +00:00
let register_data = RegisterUserData {
username: username.to_string(),
password: password.to_string(),
};
data.alpha.register(register_data).await?;
2023-12-12 15:32:57 +00:00
2024-01-17 15:40:01 +00:00
let login_data = LoginUserData {
username: username.to_string(),
password: "asd123".to_string(),
};
let invalid_login = data.alpha.login(login_data).await;
2023-12-12 15:32:57 +00:00
assert!(invalid_login.is_err());
2024-01-17 15:40:01 +00:00
let login_data = LoginUserData {
username: username.to_string(),
password: password.to_string(),
};
data.alpha.login(login_data).await?;
2023-12-08 21:21:31 +00:00
2024-01-18 11:18:17 +00:00
let my_profile = data.alpha.my_profile().await?;
assert_eq!(username, my_profile.person.username);
2024-01-18 11:18:17 +00:00
data.alpha.logout().await?;
let my_profile_after_logout = data.alpha.my_profile().await;
assert!(my_profile_after_logout.is_err());
2023-12-08 21:21:31 +00:00
data.stop()
2023-12-12 15:32:57 +00:00
}