edit_script.rs 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183
  1. #![allow(clippy::all)]
  2. #![cfg_attr(rustfmt, rustfmt::skip)]
  3. use std::convert::TryInto;
  4. use actix_web::web::Data;
  5. use flowy_document::services::doc::edit::ClientDocEditor as ClientEditDocContext;
  6. use flowy_test::{helper::ViewTest, FlowySDKTest};
  7. use flowy_user::services::user::UserSession;
  8. use futures_util::{stream, stream::StreamExt};
  9. use sqlx::PgPool;
  10. use std::sync::Arc;
  11. use tokio::time::{sleep, Duration};
  12. // use crate::helper::*;
  13. use crate::util::helper::{spawn_server, TestServer};
  14. use flowy_collaboration::{entities::doc::DocIdentifier, protobuf::ResetDocumentParams};
  15. use lib_ot::rich_text::{RichTextAttribute, RichTextDelta};
  16. use parking_lot::RwLock;
  17. use flowy_collaboration::entities::revision::RepeatedRevision;
  18. use lib_ot::core::Interval;
  19. use flowy_net::services::ws::FlowyWSConnect;
  20. use crate::util::helper::*;
  21. pub struct DocumentTest {
  22. server: TestServer,
  23. flowy_test: FlowySDKTest,
  24. }
  25. #[derive(Clone)]
  26. pub enum DocScript {
  27. ClientConnectWS,
  28. ClientInsertText(usize, &'static str),
  29. ClientFormatText(Interval, RichTextAttribute),
  30. ClientOpenDoc,
  31. AssertClient(&'static str),
  32. AssertServer(&'static str, i64),
  33. ServerSaveDocument(RepeatedRevision), // delta_json, rev_id
  34. }
  35. impl DocumentTest {
  36. pub async fn new() -> Self {
  37. let server = spawn_server().await;
  38. let flowy_test = FlowySDKTest::setup_with(server.client_server_config.clone());
  39. Self { server, flowy_test }
  40. }
  41. pub async fn run_scripts(self, scripts: Vec<DocScript>) {
  42. let _ = self.flowy_test.sign_up().await;
  43. let DocumentTest { server, flowy_test } = self;
  44. let script_context = Arc::new(RwLock::new(ScriptContext::new(flowy_test, server).await));
  45. run_scripts(script_context, scripts).await;
  46. sleep(Duration::from_secs(5)).await;
  47. }
  48. }
  49. #[derive(Clone)]
  50. struct ScriptContext {
  51. client_edit_context: Option<Arc<ClientEditDocContext>>,
  52. client_sdk: FlowySDKTest,
  53. client_user_session: Arc<UserSession>,
  54. ws_conn: Arc<FlowyWSConnect>,
  55. server: TestServer,
  56. doc_id: String,
  57. }
  58. impl ScriptContext {
  59. async fn new(client_sdk: FlowySDKTest, server: TestServer) -> Self {
  60. let user_session = client_sdk.user_session.clone();
  61. let ws_manager = client_sdk.ws_manager.clone();
  62. let doc_id = create_doc(&client_sdk).await;
  63. Self {
  64. client_edit_context: None,
  65. client_sdk,
  66. client_user_session: user_session,
  67. ws_conn: ws_manager,
  68. server,
  69. doc_id,
  70. }
  71. }
  72. async fn open_doc(&mut self) {
  73. let flowy_document = self.client_sdk.flowy_document.clone();
  74. let doc_id = self.doc_id.clone();
  75. let edit_context = flowy_document.open(DocIdentifier { doc_id }).await.unwrap();
  76. self.client_edit_context = Some(edit_context);
  77. }
  78. fn client_edit_context(&self) -> Arc<ClientEditDocContext> { self.client_edit_context.as_ref().unwrap().clone() }
  79. }
  80. async fn run_scripts(context: Arc<RwLock<ScriptContext>>, scripts: Vec<DocScript>) {
  81. let mut fut_scripts = vec![];
  82. for script in scripts {
  83. let context = context.clone();
  84. let fut = async move {
  85. let doc_id = context.read().doc_id.clone();
  86. match script {
  87. DocScript::ClientConnectWS => {
  88. // sleep(Duration::from_millis(300)).await;
  89. let ws_manager = context.read().ws_conn.clone();
  90. let user_session = context.read().client_user_session.clone();
  91. let token = user_session.token().unwrap();
  92. let _ = ws_manager.start(token).await.unwrap();
  93. },
  94. DocScript::ClientOpenDoc => {
  95. context.write().open_doc().await;
  96. },
  97. DocScript::ClientInsertText(index, s) => {
  98. context.read().client_edit_context().insert(index, s).await.unwrap();
  99. },
  100. DocScript::ClientFormatText(interval, attribute) => {
  101. context
  102. .read()
  103. .client_edit_context()
  104. .format(interval, attribute)
  105. .await
  106. .unwrap();
  107. },
  108. DocScript::AssertClient(s) => {
  109. sleep(Duration::from_millis(2000)).await;
  110. let json = context.read().client_edit_context().doc_json().await.unwrap();
  111. assert_eq(s, &json);
  112. },
  113. DocScript::AssertServer(s, rev_id) => {
  114. sleep(Duration::from_millis(100)).await;
  115. // let doc_identifier = DocIdentifier {
  116. // doc_id
  117. // };
  118. //
  119. // let doc = context.read().server.read_doc()
  120. // let pg_pool = context.read().server_pg_pool.clone();
  121. // let doc_manager = context.read().server_doc_manager.clone();
  122. // let edit_doc = doc_manager.get(&doc_id).await.unwrap();
  123. // let json = edit_doc.document_json().await.unwrap();
  124. // assert_eq(s, &json);
  125. // assert_eq!(edit_doc.rev_id().await.unwrap(), rev_id);
  126. },
  127. DocScript::ServerSaveDocument(repeated_revision) => {
  128. let pg_pool = Data::new(context.read().server.pg_pool.clone());
  129. reset_doc(&doc_id, repeated_revision, pg_pool).await;
  130. },
  131. // DocScript::Sleep(sec) => {
  132. // sleep(Duration::from_secs(sec)).await;
  133. // },
  134. }
  135. };
  136. fut_scripts.push(fut);
  137. }
  138. let mut stream = stream::iter(fut_scripts);
  139. while let Some(script) = stream.next().await {
  140. let _ = script.await;
  141. }
  142. std::mem::forget(context);
  143. }
  144. fn assert_eq(expect: &str, receive: &str) {
  145. let expected_delta: RichTextDelta = serde_json::from_str(expect).unwrap();
  146. let target_delta: RichTextDelta = serde_json::from_str(receive).unwrap();
  147. if expected_delta != target_delta {
  148. log::error!("✅ expect: {}", expect,);
  149. log::error!("❌ receive: {}", receive);
  150. }
  151. assert_eq!(target_delta, expected_delta);
  152. }
  153. async fn create_doc(flowy_test: &FlowySDKTest) -> String {
  154. let view_test = ViewTest::new(flowy_test).await;
  155. view_test.view.id
  156. }
  157. async fn reset_doc(doc_id: &str, repeated_revision: RepeatedRevision, pool: Data<PgPool>) {
  158. let pb: flowy_collaboration::protobuf::RepeatedRevision = repeated_revision.try_into().unwrap();
  159. let mut params = ResetDocumentParams::new();
  160. params.set_doc_id(doc_id.to_owned());
  161. params.set_revisions(pb);
  162. // let _ = reset_document_handler(pool.get_ref(), params).await.unwrap();
  163. }