mirror of
https://github.com/AppFlowy-IO/AppFlowy.git
synced 2024-08-30 18:12:39 +00:00
69469e9989
* refactor: traits * feat: import data * chore: track database view * fix: import * refactor: collab doc state * refactor: get collab doc state * feat: batch create collab object * fix: test * ci: run docker compose if the server is not up * chore: bump collab * chore: update ci * chore: update ci * chore: update ci * chore: implement ui * chore: implement ui * chore: implement ui
192 lines
4.8 KiB
Rust
192 lines
4.8 KiB
Rust
use std::ops::Deref;
|
|
use std::sync::Arc;
|
|
|
|
use anyhow::Error;
|
|
use bytes::Bytes;
|
|
use collab::core::collab::CollabDocState;
|
|
use collab::preclude::CollabPlugin;
|
|
use collab_document::blocks::DocumentData;
|
|
use collab_document::document_data::default_document_data;
|
|
use nanoid::nanoid;
|
|
use parking_lot::Once;
|
|
use tempfile::TempDir;
|
|
use tracing_subscriber::{fmt::Subscriber, util::SubscriberInitExt, EnvFilter};
|
|
use uuid::Uuid;
|
|
|
|
use collab_integrate::collab_builder::{
|
|
AppFlowyCollabBuilder, CollabDataSource, CollabStorageProvider, CollabStorageProviderContext,
|
|
};
|
|
use collab_integrate::RocksCollabDB;
|
|
use flowy_document2::document::MutexDocument;
|
|
use flowy_document2::manager::{DocumentManager, DocumentUser};
|
|
use flowy_document_deps::cloud::*;
|
|
use flowy_error::FlowyError;
|
|
use flowy_storage::{FileStorageService, StorageObject};
|
|
use lib_infra::async_trait::async_trait;
|
|
use lib_infra::future::{to_fut, Fut, FutureResult};
|
|
|
|
pub struct DocumentTest {
|
|
inner: DocumentManager,
|
|
}
|
|
|
|
impl DocumentTest {
|
|
pub fn new() -> Self {
|
|
let user = FakeUser::new();
|
|
let cloud_service = Arc::new(LocalTestDocumentCloudServiceImpl());
|
|
let file_storage = Arc::new(DocumentTestFileStorageService) as Arc<dyn FileStorageService>;
|
|
let manager = DocumentManager::new(
|
|
Arc::new(user),
|
|
default_collab_builder(),
|
|
cloud_service,
|
|
Arc::downgrade(&file_storage),
|
|
);
|
|
Self { inner: manager }
|
|
}
|
|
}
|
|
|
|
impl Deref for DocumentTest {
|
|
type Target = DocumentManager;
|
|
|
|
fn deref(&self) -> &Self::Target {
|
|
&self.inner
|
|
}
|
|
}
|
|
|
|
pub struct FakeUser {
|
|
collab_db: Arc<RocksCollabDB>,
|
|
}
|
|
|
|
impl FakeUser {
|
|
pub fn new() -> Self {
|
|
setup_log();
|
|
|
|
let tempdir = TempDir::new().unwrap();
|
|
let path = tempdir.into_path();
|
|
let collab_db = Arc::new(RocksCollabDB::open(path).unwrap());
|
|
|
|
Self { collab_db }
|
|
}
|
|
}
|
|
|
|
impl DocumentUser for FakeUser {
|
|
fn user_id(&self) -> Result<i64, FlowyError> {
|
|
Ok(1)
|
|
}
|
|
|
|
fn workspace_id(&self) -> Result<String, FlowyError> {
|
|
Ok(Uuid::new_v4().to_string())
|
|
}
|
|
|
|
fn token(&self) -> Result<Option<String>, FlowyError> {
|
|
Ok(None)
|
|
}
|
|
|
|
fn collab_db(&self, _uid: i64) -> Result<std::sync::Weak<RocksCollabDB>, FlowyError> {
|
|
Ok(Arc::downgrade(&self.collab_db))
|
|
}
|
|
}
|
|
|
|
pub fn setup_log() {
|
|
static START: Once = Once::new();
|
|
START.call_once(|| {
|
|
std::env::set_var("RUST_LOG", "collab_persistence=trace");
|
|
let subscriber = Subscriber::builder()
|
|
.with_env_filter(EnvFilter::from_default_env())
|
|
.with_ansi(true)
|
|
.finish();
|
|
subscriber.try_init().unwrap();
|
|
});
|
|
}
|
|
|
|
pub fn default_collab_builder() -> Arc<AppFlowyCollabBuilder> {
|
|
let builder =
|
|
AppFlowyCollabBuilder::new(DefaultCollabStorageProvider(), "fake_device_id".to_string());
|
|
builder.initialize(uuid::Uuid::new_v4().to_string());
|
|
Arc::new(builder)
|
|
}
|
|
|
|
pub async fn create_and_open_empty_document() -> (DocumentTest, Arc<MutexDocument>, String) {
|
|
let test = DocumentTest::new();
|
|
let doc_id: String = gen_document_id();
|
|
let data = default_document_data();
|
|
let uid = test.user.user_id().unwrap();
|
|
// create a document
|
|
test
|
|
.create_document(uid, &doc_id, Some(data.clone()))
|
|
.await
|
|
.unwrap();
|
|
|
|
let document = test.get_document(&doc_id).await.unwrap();
|
|
|
|
(test, document, data.page_id)
|
|
}
|
|
|
|
pub fn gen_document_id() -> String {
|
|
let uuid = uuid::Uuid::new_v4();
|
|
uuid.to_string()
|
|
}
|
|
|
|
pub fn gen_id() -> String {
|
|
nanoid!(10)
|
|
}
|
|
|
|
pub struct LocalTestDocumentCloudServiceImpl();
|
|
impl DocumentCloudService for LocalTestDocumentCloudServiceImpl {
|
|
fn get_document_doc_state(
|
|
&self,
|
|
_document_id: &str,
|
|
_workspace_id: &str,
|
|
) -> FutureResult<CollabDocState, FlowyError> {
|
|
FutureResult::new(async move { Ok(vec![]) })
|
|
}
|
|
|
|
fn get_document_snapshots(
|
|
&self,
|
|
_document_id: &str,
|
|
_limit: usize,
|
|
_workspace_id: &str,
|
|
) -> FutureResult<Vec<DocumentSnapshot>, Error> {
|
|
FutureResult::new(async move { Ok(vec![]) })
|
|
}
|
|
|
|
fn get_document_data(
|
|
&self,
|
|
_document_id: &str,
|
|
_workspace_id: &str,
|
|
) -> FutureResult<Option<DocumentData>, Error> {
|
|
FutureResult::new(async move { Ok(None) })
|
|
}
|
|
}
|
|
|
|
pub struct DocumentTestFileStorageService;
|
|
impl FileStorageService for DocumentTestFileStorageService {
|
|
fn create_object(&self, _object: StorageObject) -> FutureResult<String, FlowyError> {
|
|
todo!()
|
|
}
|
|
|
|
fn delete_object_by_url(&self, _object_url: String) -> FutureResult<(), FlowyError> {
|
|
todo!()
|
|
}
|
|
|
|
fn get_object_by_url(&self, _object_url: String) -> FutureResult<Bytes, FlowyError> {
|
|
todo!()
|
|
}
|
|
}
|
|
|
|
struct DefaultCollabStorageProvider();
|
|
|
|
#[async_trait]
|
|
impl CollabStorageProvider for DefaultCollabStorageProvider {
|
|
fn storage_source(&self) -> CollabDataSource {
|
|
CollabDataSource::Local
|
|
}
|
|
|
|
fn get_plugins(&self, _context: CollabStorageProviderContext) -> Fut<Vec<Arc<dyn CollabPlugin>>> {
|
|
to_fut(async move { vec![] })
|
|
}
|
|
|
|
fn is_sync_enabled(&self) -> bool {
|
|
false
|
|
}
|
|
}
|