123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222 |
- use std::{collections::HashMap, sync::Arc, vec};
- use appflowy_integrate::collab_builder::AppFlowyCollabBuilder;
- use appflowy_integrate::config::AppFlowyCollabConfig;
- use collab_document::blocks::{Block, BlockAction, BlockActionPayload, BlockActionType};
- use nanoid::nanoid;
- use serde_json::{json, to_value, Value};
- use flowy_document2::{document::DocumentDataWrapper, manager::DocumentManager};
- use super::util::FakeUser;
- #[tokio::test]
- async fn restore_document() {
- let user = FakeUser::new();
- let manager = DocumentManager::new(Arc::new(user), default_collab_builder());
- // create a document
- let doc_id: String = nanoid!(10);
- let data = DocumentDataWrapper::default();
- let document_a = manager
- .create_document(doc_id.clone(), data.clone())
- .await
- .unwrap();
- let data_a = document_a.lock().get_document().unwrap();
- assert_eq!(data_a, data.0);
- // open a document
- let data_b = manager
- .open_document(doc_id.clone())
- .await
- .unwrap()
- .lock()
- .get_document()
- .unwrap();
- // close a document
- _ = manager.close_document(doc_id.clone());
- assert_eq!(data_b, data.0);
- // restore
- _ = manager.create_document(doc_id.clone(), data.clone()).await;
- // open a document
- let data_b = manager
- .open_document(doc_id.clone())
- .await
- .unwrap()
- .lock()
- .get_document()
- .unwrap();
- // close a document
- _ = manager.close_document(doc_id);
- assert_eq!(data_b, data.0);
- }
- #[tokio::test]
- async fn document_apply_insert_action() {
- let user = FakeUser::new();
- let manager = DocumentManager::new(Arc::new(user), default_collab_builder());
- let doc_id: String = nanoid!(10);
- let data = DocumentDataWrapper::default();
- // create a document
- _ = manager.create_document(doc_id.clone(), data.clone()).await;
- // open a document
- let document = manager.open_document(doc_id.clone()).await.unwrap();
- let page_block = document.lock().get_block(&data.0.page_id).unwrap();
- // insert a text block
- let text_block = Block {
- id: nanoid!(10),
- ty: "text".to_string(),
- parent: page_block.id,
- children: nanoid!(10),
- external_id: None,
- external_type: None,
- data: HashMap::new(),
- };
- let insert_text_action = BlockAction {
- action: BlockActionType::Insert,
- payload: BlockActionPayload {
- block: text_block,
- parent_id: None,
- prev_id: None,
- },
- };
- document.lock().apply_action(vec![insert_text_action]);
- let data_a = document.lock().get_document().unwrap();
- // close the original document
- _ = manager.close_document(doc_id.clone());
- // re-open the document
- let data_b = manager
- .open_document(doc_id.clone())
- .await
- .unwrap()
- .lock()
- .get_document()
- .unwrap();
- // close a document
- _ = manager.close_document(doc_id);
- assert_eq!(data_b, data_a);
- }
- #[tokio::test]
- async fn document_apply_update_page_action() {
- let user = FakeUser::new();
- let manager = DocumentManager::new(Arc::new(user), default_collab_builder());
- let doc_id: String = nanoid!(10);
- let data = DocumentDataWrapper::default();
- // create a document
- _ = manager.create_document(doc_id.clone(), data.clone()).await;
- // open a document
- let document = manager.open_document(doc_id.clone()).await.unwrap();
- let page_block = document.lock().get_block(&data.0.page_id).unwrap();
- let mut page_block_clone = page_block;
- page_block_clone.data = HashMap::new();
- page_block_clone.data.insert(
- "delta".to_string(),
- to_value(json!([{"insert": "Hello World!"}])).unwrap(),
- );
- let action = BlockAction {
- action: BlockActionType::Update,
- payload: BlockActionPayload {
- block: page_block_clone,
- parent_id: None,
- prev_id: None,
- },
- };
- let actions = vec![action];
- tracing::trace!("{:?}", &actions);
- document.lock().apply_action(actions);
- let page_block_old = document.lock().get_block(&data.0.page_id).unwrap();
- _ = manager.close_document(doc_id.clone());
- // re-open the document
- let document = manager.open_document(doc_id).await.unwrap();
- let page_block_new = document.lock().get_block(&data.0.page_id).unwrap();
- assert_eq!(page_block_old, page_block_new);
- assert!(page_block_new.data.contains_key("delta"));
- }
- #[tokio::test]
- async fn document_apply_update_action() {
- let user = FakeUser::new();
- let manager = DocumentManager::new(Arc::new(user), default_collab_builder());
- let doc_id: String = nanoid!(10);
- let data = DocumentDataWrapper::default();
- // create a document
- _ = manager.create_document(doc_id.clone(), data.clone()).await;
- // open a document
- let document = manager.open_document(doc_id.clone()).await.unwrap();
- let page_block = document.lock().get_block(&data.0.page_id).unwrap();
- // insert a text block
- let text_block_id = nanoid!(10);
- let text_block = Block {
- id: text_block_id.clone(),
- ty: "text".to_string(),
- parent: page_block.id,
- children: nanoid!(10),
- external_id: None,
- external_type: None,
- data: HashMap::new(),
- };
- let insert_text_action = BlockAction {
- action: BlockActionType::Insert,
- payload: BlockActionPayload {
- block: text_block,
- parent_id: None,
- prev_id: None,
- },
- };
- document.lock().apply_action(vec![insert_text_action]);
- // update the text block
- let existing_text_block = document.lock().get_block(&text_block_id).unwrap();
- let mut updated_text_block_data = HashMap::new();
- updated_text_block_data.insert("delta".to_string(), Value::String("delta".to_string()));
- let updated_text_block = Block {
- id: existing_text_block.id,
- ty: existing_text_block.ty,
- parent: existing_text_block.parent,
- children: existing_text_block.children,
- external_id: None,
- external_type: None,
- data: updated_text_block_data.clone(),
- };
- let update_text_action = BlockAction {
- action: BlockActionType::Update,
- payload: BlockActionPayload {
- block: updated_text_block,
- parent_id: None,
- prev_id: None,
- },
- };
- document.lock().apply_action(vec![update_text_action]);
- // close the original document
- _ = manager.close_document(doc_id.clone());
- // re-open the document
- let document = manager.open_document(doc_id.clone()).await.unwrap();
- let block = document.lock().get_block(&text_block_id).unwrap();
- assert_eq!(block.data, updated_text_block_data);
- // close a document
- _ = manager.close_document(doc_id);
- }
- fn default_collab_builder() -> Arc<AppFlowyCollabBuilder> {
- let builder = AppFlowyCollabBuilder::new(AppFlowyCollabConfig::default());
- Arc::new(builder)
- }
|