mirror of
https://github.com/AppFlowy-IO/AppFlowy.git
synced 2024-08-30 18:12:39 +00:00
e1c8135f5d
* feat: try using folder2 * feat: update * feat: implement handlers * fix: compile errors * chore: add unsafe send + sync * feat: remove unsafe impl * fix: replace folder with foler2 * chore: dart compile errors * test: fix test * test: fix test * test: bypass existing tests * feat: open latest view * chore: fix dart warnings * chore: config notification * fix: folder notification bugs * fix: doesn't open the new view after creating * chore: rename struct * refactor: user id * test: fix test * chore: remove unused user_id * fix: fix read workspace views * chore: rename appflowy data folder * chore: update ref * fix: tauri build
96 lines
3.1 KiB
Rust
96 lines
3.1 KiB
Rust
use flowy_document::old_editor::editor::DeltaDocumentEditor;
|
|
use flowy_document::TEXT_BLOCK_SYNC_INTERVAL_IN_MILLIS;
|
|
use flowy_revision_persistence::RevisionState;
|
|
use flowy_test::{helper::ViewTest, FlowySDKTest};
|
|
use lib_ot::{core::Interval, text_delta::DeltaTextOperations};
|
|
use std::sync::Arc;
|
|
use tokio::time::{sleep, Duration};
|
|
|
|
pub enum EditorScript {
|
|
InsertText(&'static str, usize),
|
|
Delete(Interval),
|
|
Replace(Interval, &'static str),
|
|
|
|
AssertRevisionState(i64, RevisionState),
|
|
AssertNextSyncRevId(Option<i64>),
|
|
AssertCurrentRevId(i64),
|
|
AssertJson(&'static str),
|
|
}
|
|
|
|
pub struct DeltaDocumentEditorTest {
|
|
pub sdk: FlowySDKTest,
|
|
pub editor: Arc<DeltaDocumentEditor>,
|
|
}
|
|
|
|
impl DeltaDocumentEditorTest {
|
|
pub async fn new() -> Self {
|
|
let sdk = FlowySDKTest::default();
|
|
let _ = sdk.init_user().await;
|
|
let test = ViewTest::new_document_view(&sdk).await;
|
|
let document_editor = sdk
|
|
.document_manager
|
|
.open_document_editor(&test.view.id)
|
|
.await
|
|
.unwrap();
|
|
let editor = match document_editor
|
|
.as_any()
|
|
.downcast_ref::<Arc<DeltaDocumentEditor>>()
|
|
{
|
|
None => panic!(),
|
|
Some(editor) => editor.clone(),
|
|
};
|
|
Self { sdk, editor }
|
|
}
|
|
|
|
pub async fn run_scripts(mut self, scripts: Vec<EditorScript>) {
|
|
for script in scripts {
|
|
self.run_script(script).await;
|
|
}
|
|
}
|
|
|
|
async fn run_script(&mut self, script: EditorScript) {
|
|
let rev_manager = self.editor.rev_manager();
|
|
let cache = rev_manager.revision_cache().await;
|
|
|
|
match script {
|
|
EditorScript::InsertText(s, offset) => {
|
|
self.editor.insert(offset, s).await.unwrap();
|
|
},
|
|
EditorScript::Delete(interval) => {
|
|
self.editor.delete(interval).await.unwrap();
|
|
},
|
|
EditorScript::Replace(interval, s) => {
|
|
self.editor.replace(interval, s).await.unwrap();
|
|
},
|
|
EditorScript::AssertRevisionState(rev_id, state) => {
|
|
let record = cache.get(rev_id).await.unwrap();
|
|
assert_eq!(record.state, state);
|
|
},
|
|
EditorScript::AssertCurrentRevId(rev_id) => {
|
|
assert_eq!(self.editor.rev_manager().rev_id(), rev_id);
|
|
},
|
|
EditorScript::AssertNextSyncRevId(rev_id) => {
|
|
let next_revision = rev_manager.next_sync_revision().await.unwrap();
|
|
if rev_id.is_none() {
|
|
assert!(next_revision.is_none(), "Next revision should be None");
|
|
return;
|
|
}
|
|
let next_revision = next_revision.unwrap();
|
|
let mut notify = rev_manager.ack_notify();
|
|
let _ = notify.recv().await;
|
|
assert_eq!(next_revision.rev_id, rev_id.unwrap());
|
|
},
|
|
EditorScript::AssertJson(expected) => {
|
|
let expected_delta: DeltaTextOperations = serde_json::from_str(expected).unwrap();
|
|
let delta = self.editor.document_operations().await.unwrap();
|
|
if expected_delta != delta {
|
|
eprintln!("✅ expect: {}", expected,);
|
|
eprintln!("❌ receive: {}", delta.json_str());
|
|
}
|
|
assert_eq!(expected_delta, delta);
|
|
},
|
|
}
|
|
sleep(Duration::from_millis(TEXT_BLOCK_SYNC_INTERVAL_IN_MILLIS)).await;
|
|
}
|
|
}
|