document_test.rs 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215
  1. use std::{collections::HashMap, sync::Arc, vec};
  2. use collab_document::blocks::{Block, BlockAction, BlockActionPayload, BlockActionType};
  3. use nanoid::nanoid;
  4. use serde_json::{json, to_value, Value};
  5. use flowy_document2::document_block_keys::PARAGRAPH_BLOCK_TYPE;
  6. use flowy_document2::document_data::default_document_data;
  7. use flowy_document2::manager::DocumentManager;
  8. use crate::document::util::default_collab_builder;
  9. use super::util::FakeUser;
  10. #[test]
  11. fn restore_document() {
  12. let user = FakeUser::new();
  13. let manager = DocumentManager::new(Arc::new(user), default_collab_builder());
  14. // create a document
  15. let doc_id: String = nanoid!(10);
  16. let data = default_document_data();
  17. let document_a = manager
  18. .create_document(doc_id.clone(), Some(data.clone()))
  19. .unwrap();
  20. let data_a = document_a.lock().get_document().unwrap();
  21. assert_eq!(data_a, data);
  22. // open a document
  23. let data_b = manager
  24. .open_document(doc_id.clone())
  25. .unwrap()
  26. .lock()
  27. .get_document()
  28. .unwrap();
  29. // close a document
  30. _ = manager.close_document(&doc_id);
  31. assert_eq!(data_b, data);
  32. // restore
  33. _ = manager.create_document(doc_id.clone(), Some(data.clone()));
  34. // open a document
  35. let data_b = manager
  36. .open_document(doc_id.clone())
  37. .unwrap()
  38. .lock()
  39. .get_document()
  40. .unwrap();
  41. // close a document
  42. _ = manager.close_document(&doc_id);
  43. assert_eq!(data_b, data);
  44. }
  45. #[test]
  46. fn document_apply_insert_action() {
  47. let user = FakeUser::new();
  48. let manager = DocumentManager::new(Arc::new(user), default_collab_builder());
  49. let doc_id: String = nanoid!(10);
  50. let data = default_document_data();
  51. // create a document
  52. _ = manager.create_document(doc_id.clone(), Some(data.clone()));
  53. // open a document
  54. let document = manager.open_document(doc_id.clone()).unwrap();
  55. let page_block = document.lock().get_block(&data.page_id).unwrap();
  56. // insert a text block
  57. let text_block = Block {
  58. id: nanoid!(10),
  59. ty: PARAGRAPH_BLOCK_TYPE.to_string(),
  60. parent: page_block.id,
  61. children: nanoid!(10),
  62. external_id: None,
  63. external_type: None,
  64. data: HashMap::new(),
  65. };
  66. let insert_text_action = BlockAction {
  67. action: BlockActionType::Insert,
  68. payload: BlockActionPayload {
  69. block: text_block,
  70. parent_id: None,
  71. prev_id: None,
  72. },
  73. };
  74. document.lock().apply_action(vec![insert_text_action]);
  75. let data_a = document.lock().get_document().unwrap();
  76. // close the original document
  77. _ = manager.close_document(&doc_id);
  78. // re-open the document
  79. let data_b = manager
  80. .open_document(doc_id.clone())
  81. .unwrap()
  82. .lock()
  83. .get_document()
  84. .unwrap();
  85. // close a document
  86. _ = manager.close_document(&doc_id);
  87. assert_eq!(data_b, data_a);
  88. }
  89. #[test]
  90. fn document_apply_update_page_action() {
  91. let user = FakeUser::new();
  92. let manager = DocumentManager::new(Arc::new(user), default_collab_builder());
  93. let doc_id: String = nanoid!(10);
  94. let data = default_document_data();
  95. // create a document
  96. _ = manager.create_document(doc_id.clone(), Some(data.clone()));
  97. // open a document
  98. let document = manager.open_document(doc_id.clone()).unwrap();
  99. let page_block = document.lock().get_block(&data.page_id).unwrap();
  100. let mut page_block_clone = page_block;
  101. page_block_clone.data = HashMap::new();
  102. page_block_clone.data.insert(
  103. "delta".to_string(),
  104. to_value(json!([{"insert": "Hello World!"}])).unwrap(),
  105. );
  106. let action = BlockAction {
  107. action: BlockActionType::Update,
  108. payload: BlockActionPayload {
  109. block: page_block_clone,
  110. parent_id: None,
  111. prev_id: None,
  112. },
  113. };
  114. let actions = vec![action];
  115. tracing::trace!("{:?}", &actions);
  116. document.lock().apply_action(actions);
  117. let page_block_old = document.lock().get_block(&data.page_id).unwrap();
  118. _ = manager.close_document(&doc_id);
  119. // re-open the document
  120. let document = manager.open_document(doc_id).unwrap();
  121. let page_block_new = document.lock().get_block(&data.page_id).unwrap();
  122. assert_eq!(page_block_old, page_block_new);
  123. assert!(page_block_new.data.contains_key("delta"));
  124. }
  125. #[test]
  126. fn document_apply_update_action() {
  127. let user = FakeUser::new();
  128. let manager = DocumentManager::new(Arc::new(user), default_collab_builder());
  129. let doc_id: String = nanoid!(10);
  130. let data = default_document_data();
  131. // create a document
  132. _ = manager.create_document(doc_id.clone(), Some(data.clone()));
  133. // open a document
  134. let document = manager.open_document(doc_id.clone()).unwrap();
  135. let page_block = document.lock().get_block(&data.page_id).unwrap();
  136. // insert a text block
  137. let text_block_id = nanoid!(10);
  138. let text_block = Block {
  139. id: text_block_id.clone(),
  140. ty: PARAGRAPH_BLOCK_TYPE.to_string(),
  141. parent: page_block.id,
  142. children: nanoid!(10),
  143. external_id: None,
  144. external_type: None,
  145. data: HashMap::new(),
  146. };
  147. let insert_text_action = BlockAction {
  148. action: BlockActionType::Insert,
  149. payload: BlockActionPayload {
  150. block: text_block,
  151. parent_id: None,
  152. prev_id: None,
  153. },
  154. };
  155. document.lock().apply_action(vec![insert_text_action]);
  156. // update the text block
  157. let existing_text_block = document.lock().get_block(&text_block_id).unwrap();
  158. let mut updated_text_block_data = HashMap::new();
  159. updated_text_block_data.insert("delta".to_string(), Value::String("delta".to_string()));
  160. let updated_text_block = Block {
  161. id: existing_text_block.id,
  162. ty: existing_text_block.ty,
  163. parent: existing_text_block.parent,
  164. children: existing_text_block.children,
  165. external_id: None,
  166. external_type: None,
  167. data: updated_text_block_data.clone(),
  168. };
  169. let update_text_action = BlockAction {
  170. action: BlockActionType::Update,
  171. payload: BlockActionPayload {
  172. block: updated_text_block,
  173. parent_id: None,
  174. prev_id: None,
  175. },
  176. };
  177. document.lock().apply_action(vec![update_text_action]);
  178. // close the original document
  179. _ = manager.close_document(&doc_id);
  180. // re-open the document
  181. let document = manager.open_document(doc_id.clone()).unwrap();
  182. let block = document.lock().get_block(&text_block_id).unwrap();
  183. assert_eq!(block.data, updated_text_block_data);
  184. // close a document
  185. _ = manager.close_document(&doc_id);
  186. }