kitchen-freezer/tests/sync.rs

173 lines
7.5 KiB
Rust
Raw Normal View History

2021-03-22 23:42:41 +01:00
#![cfg(feature = "integration_tests")]
2021-02-25 00:46:32 +01:00
use std::path::PathBuf;
2021-03-18 23:59:06 +01:00
use std::sync::{Arc, Mutex};
2021-02-25 00:46:32 +01:00
use url::Url;
use my_tasks::traits::CalDavSource;
use my_tasks::traits::BaseCalendar;
use my_tasks::traits::CompleteCalendar;
use my_tasks::traits::DavCalendar;
2021-02-25 00:46:32 +01:00
use my_tasks::cache::Cache;
use my_tasks::Item;
2021-03-21 23:54:33 +01:00
use my_tasks::ItemId;
2021-03-22 23:42:41 +01:00
use my_tasks::SyncStatus;
2021-02-25 00:46:32 +01:00
use my_tasks::Task;
2021-03-01 23:39:16 +01:00
use my_tasks::calendar::cached_calendar::CachedCalendar;
2021-02-25 00:46:32 +01:00
use my_tasks::Provider;
#[tokio::test]
/// This test simulates a synchronisation between a local cache and a server
/// To "mock" a server, let's use a second cache
async fn test_regular_sync() {
2021-02-25 00:46:32 +01:00
let _ = env_logger::builder().is_test(true).try_init();
let mut provider = populate_test_provider().await;
2021-03-31 08:40:21 +02:00
let cals_server = provider.remote().get_calendars().await.unwrap();
println!("----Server, before sync-------");
my_tasks::utils::print_calendar_list(&cals_server).await;
let cals_local = provider.local().get_calendars().await.unwrap();
println!("\n----Local, before sync-------");
my_tasks::utils::print_calendar_list(&cals_local).await;
2021-02-25 00:46:32 +01:00
provider.sync().await.unwrap();
2021-03-18 23:59:06 +01:00
2021-03-22 22:39:50 +01:00
let cals_server = provider.remote().get_calendars().await.unwrap();
2021-03-31 08:40:21 +02:00
println!("----Server, after sync-------");
2021-03-21 19:05:22 +01:00
my_tasks::utils::print_calendar_list(&cals_server).await;
2021-02-27 11:58:40 +01:00
let cals_local = provider.local().get_calendars().await.unwrap();
2021-03-31 08:40:21 +02:00
println!("\n----Local, after sync-------");
2021-03-21 19:05:22 +01:00
my_tasks::utils::print_calendar_list(&cals_local).await;
2021-02-27 11:58:40 +01:00
2021-03-22 22:39:50 +01:00
assert!(provider.remote().has_same_contents_than(provider.local()).await.unwrap());
2021-02-25 00:46:32 +01:00
2021-02-27 11:58:40 +01:00
}
2021-02-25 00:46:32 +01:00
/// Populate sources with the following:
2021-02-28 00:19:00 +01:00
/// * At the last sync: both sources had A, B, C, D, E, F, G, H, I, J, K, L, M at last sync
2021-02-25 00:46:32 +01:00
/// * Before the newer sync, this will be the content of the sources:
2021-03-20 20:13:07 +01:00
/// * server: A, C, D, E', F', G✓, H , I', K✓, M, N
/// * cache: A, B, D', E, F'', G , H✓, I✓, J✓, M, O
2021-02-27 11:58:40 +01:00
///
/// Hence, here is the expected result after the sync:
2021-03-20 20:13:07 +01:00
/// * both: A, D', E', F', G✓, H✓, I', K✓, M, N, O
2021-02-25 00:46:32 +01:00
///
/// Notes:
/// * X': name has been modified since the last sync
/// * F'/F'': name conflict
2021-02-28 00:19:00 +01:00
/// * G✓: task has been marked as completed
2021-03-01 23:39:16 +01:00
async fn populate_test_provider() -> Provider<Cache, CachedCalendar, Cache, CachedCalendar> {
2021-02-25 00:46:32 +01:00
let mut server = Cache::new(&PathBuf::from(String::from("server.json")));
let mut local = Cache::new(&PathBuf::from(String::from("local.json")));
2021-03-05 23:32:42 +01:00
let cal_id = Url::parse("http://todo.list/cal").unwrap();
2021-03-23 00:13:03 +01:00
let task_a = Item::Task(Task::new("task A".into(), ItemId::random(), SyncStatus::random_synced()));
let task_b = Item::Task(Task::new("task B".into(), ItemId::random(), SyncStatus::random_synced()));
let task_c = Item::Task(Task::new("task C".into(), ItemId::random(), SyncStatus::random_synced()));
let task_d = Item::Task(Task::new("task D".into(), ItemId::random(), SyncStatus::random_synced()));
let task_e = Item::Task(Task::new("task E".into(), ItemId::random(), SyncStatus::random_synced()));
let task_f = Item::Task(Task::new("task F".into(), ItemId::random(), SyncStatus::random_synced()));
let task_g = Item::Task(Task::new("task G".into(), ItemId::random(), SyncStatus::random_synced()));
let task_h = Item::Task(Task::new("task H".into(), ItemId::random(), SyncStatus::random_synced()));
let task_i = Item::Task(Task::new("task I".into(), ItemId::random(), SyncStatus::random_synced()));
let task_j = Item::Task(Task::new("task J".into(), ItemId::random(), SyncStatus::random_synced()));
let task_k = Item::Task(Task::new("task K".into(), ItemId::random(), SyncStatus::random_synced()));
let task_l = Item::Task(Task::new("task L".into(), ItemId::random(), SyncStatus::random_synced()));
let task_m = Item::Task(Task::new("task M".into(), ItemId::random(), SyncStatus::random_synced()));
2021-02-25 00:46:32 +01:00
let task_b_id = task_b.id().clone();
let task_c_id = task_c.id().clone();
let task_d_id = task_d.id().clone();
let task_e_id = task_e.id().clone();
let task_f_id = task_f.id().clone();
let task_g_id = task_g.id().clone();
let task_h_id = task_h.id().clone();
2021-02-28 00:19:00 +01:00
let task_i_id = task_i.id().clone();
let task_j_id = task_j.id().clone();
let task_k_id = task_k.id().clone();
2021-03-20 20:13:07 +01:00
let task_l_id = task_l.id().clone();
2021-02-25 00:46:32 +01:00
// Step 1
// Build the calendar as it was at the time of the sync
2021-03-05 23:32:42 +01:00
let mut calendar = CachedCalendar::new("a list".into(), cal_id.clone(), my_tasks::calendar::SupportedComponents::TODO);
2021-03-24 09:15:55 +01:00
calendar.add_item(task_a).await.unwrap();
calendar.add_item(task_b).await.unwrap();
calendar.add_item(task_c).await.unwrap();
calendar.add_item(task_d).await.unwrap();
calendar.add_item(task_e).await.unwrap();
calendar.add_item(task_f).await.unwrap();
calendar.add_item(task_g).await.unwrap();
calendar.add_item(task_h).await.unwrap();
calendar.add_item(task_i).await.unwrap();
calendar.add_item(task_j).await.unwrap();
calendar.add_item(task_k).await.unwrap();
calendar.add_item(task_l).await.unwrap();
calendar.add_item(task_m).await.unwrap();
2021-02-25 00:46:32 +01:00
2021-03-18 23:59:06 +01:00
server.add_calendar(Arc::new(Mutex::new(calendar.clone())));
local.add_calendar(Arc::new(Mutex::new(calendar.clone())));
2021-02-25 00:46:32 +01:00
// Step 2
// Edit the server calendar
2021-03-21 19:27:55 +01:00
let cal_server = server.get_calendar(&cal_id).await.unwrap();
2021-03-18 23:59:06 +01:00
let mut cal_server = cal_server.lock().unwrap();
2021-02-25 00:46:32 +01:00
2021-03-21 19:19:49 +01:00
cal_server.delete_item(&task_b_id).await.unwrap();
2021-02-25 00:46:32 +01:00
2021-03-21 19:19:49 +01:00
cal_server.get_item_by_id_mut(&task_e_id).await.unwrap().unwrap_task_mut()
.mock_remote_calendar_set_name("E has been remotely renamed".into());
2021-02-25 00:46:32 +01:00
2021-03-21 19:19:49 +01:00
cal_server.get_item_by_id_mut(&task_f_id).await.unwrap().unwrap_task_mut()
.mock_remote_calendar_set_name("F renamed in the server".into());
2021-02-25 00:46:32 +01:00
2021-03-21 19:19:49 +01:00
cal_server.get_item_by_id_mut(&task_g_id).await.unwrap().unwrap_task_mut()
.mock_remote_calendar_set_completed(true);
2021-02-25 00:46:32 +01:00
2021-03-21 19:19:49 +01:00
cal_server.get_item_by_id_mut(&task_i_id).await.unwrap().unwrap_task_mut()
.mock_remote_calendar_set_name("I renamed in the server".into());
2021-02-28 00:19:00 +01:00
2021-03-21 19:19:49 +01:00
cal_server.delete_item(&task_j_id).await.unwrap();
2021-02-28 00:19:00 +01:00
2021-03-21 19:19:49 +01:00
cal_server.get_item_by_id_mut(&task_k_id).await.unwrap().unwrap_task_mut()
.mock_remote_calendar_set_completed(true);
2021-02-28 12:21:29 +01:00
2021-03-21 19:19:49 +01:00
cal_server.delete_item(&task_l_id).await.unwrap();
2021-03-20 20:13:07 +01:00
2021-03-23 00:13:03 +01:00
let task_n = Item::Task(Task::new("task N (new from server)".into(), ItemId::random(), SyncStatus::random_synced()));
2021-03-24 09:15:55 +01:00
cal_server.add_item(task_n).await.unwrap();
2021-02-25 00:46:32 +01:00
// Step 3
// Edit the local calendar
2021-03-21 19:27:55 +01:00
let cal_local = local.get_calendar(&cal_id).await.unwrap();
2021-03-18 23:59:06 +01:00
let mut cal_local = cal_local.lock().unwrap();
2021-02-25 00:46:32 +01:00
2021-03-24 09:04:23 +01:00
cal_local.mark_for_deletion(&task_c_id).await.unwrap();
2021-02-25 00:46:32 +01:00
2021-03-21 19:19:49 +01:00
cal_local.get_item_by_id_mut(&task_d_id).await.unwrap().unwrap_task_mut()
2021-02-25 00:46:32 +01:00
.set_name("D has been locally renamed".into());
2021-03-21 19:19:49 +01:00
cal_local.get_item_by_id_mut(&task_f_id).await.unwrap().unwrap_task_mut()
2021-02-25 00:46:32 +01:00
.set_name("F renamed locally as well!".into());
2021-03-21 19:19:49 +01:00
cal_local.get_item_by_id_mut(&task_h_id).await.unwrap().unwrap_task_mut()
2021-02-25 00:46:32 +01:00
.set_completed(true);
2021-03-21 19:19:49 +01:00
cal_local.get_item_by_id_mut(&task_i_id).await.unwrap().unwrap_task_mut()
2021-02-28 00:19:00 +01:00
.set_completed(true);
2021-03-21 19:19:49 +01:00
cal_local.get_item_by_id_mut(&task_j_id).await.unwrap().unwrap_task_mut()
2021-02-28 00:19:00 +01:00
.set_completed(true);
2021-03-24 09:04:23 +01:00
cal_local.mark_for_deletion(&task_k_id).await.unwrap();
cal_local.mark_for_deletion(&task_l_id).await.unwrap();
2021-02-28 12:21:29 +01:00
2021-03-23 00:13:03 +01:00
let task_o = Item::Task(Task::new("task O (new from local)".into(), ItemId::random(), SyncStatus::NotSynced));
2021-03-24 09:15:55 +01:00
cal_local.add_item(task_o).await.unwrap();
2021-02-25 00:46:32 +01:00
2021-02-28 18:00:37 +01:00
Provider::new(server, local)
2021-02-25 00:46:32 +01:00
}