123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282 |
- #![allow(clippy::all)]
- use crate::util::helper::{BackendViewTest, *};
- use flowy_collaboration::{
- client_document::{ClientDocument, PlainDoc},
- entities::{
- document_info::{CreateDocParams, DocumentId},
- revision::{md5, RepeatedRevision, Revision},
- },
- };
- use flowy_folder_data_model::entities::{
- app::{AppId, UpdateAppParams},
- trash::{RepeatedTrashId, TrashId, TrashType},
- view::{RepeatedViewId, UpdateViewParams, ViewId},
- workspace::{CreateWorkspaceParams, UpdateWorkspaceParams, WorkspaceId},
- };
- #[actix_rt::test]
- async fn workspace_create() {
- let test = BackendWorkspaceTest::new().await;
- tracing::info!("{:?}", test.workspace);
- }
- #[actix_rt::test]
- async fn workspace_read() {
- let test = BackendWorkspaceTest::new().await;
- let read_params = WorkspaceId::new(Some(test.workspace.id.clone()));
- let repeated_workspace = test.server.read_workspaces(read_params).await;
- tracing::info!("{:?}", repeated_workspace);
- }
- #[actix_rt::test]
- async fn workspace_read_with_belongs() {
- let test = BackendWorkspaceTest::new().await;
- let _ = test.create_app().await;
- let _ = test.create_app().await;
- let _ = test.create_app().await;
- let read_params = WorkspaceId::new(Some(test.workspace.id.clone()));
- let workspaces = test.server.read_workspaces(read_params).await;
- let workspace = workspaces.items.first().unwrap();
- assert_eq!(workspace.apps.len(), 3);
- }
- #[actix_rt::test]
- async fn workspace_update() {
- let test = BackendWorkspaceTest::new().await;
- let new_name = "rename workspace name";
- let new_desc = "rename workspace description";
- let update_params = UpdateWorkspaceParams {
- id: test.workspace.id.clone(),
- name: Some(new_name.to_string()),
- desc: Some(new_desc.to_string()),
- };
- test.server.update_workspace(update_params).await;
- let read_params = WorkspaceId::new(Some(test.workspace.id.clone()));
- let repeated_workspace = test.server.read_workspaces(read_params).await;
- let workspace = repeated_workspace.first().unwrap();
- assert_eq!(workspace.name, new_name);
- assert_eq!(workspace.desc, new_desc);
- }
- #[actix_rt::test]
- async fn workspace_delete() {
- let test = BackendWorkspaceTest::new().await;
- let delete_params = WorkspaceId {
- workspace_id: Some(test.workspace.id.clone()),
- };
- let _ = test.server.delete_workspace(delete_params).await;
- let read_params = WorkspaceId::new(Some(test.workspace.id.clone()));
- let repeated_workspace = test.server.read_workspaces(read_params).await;
- assert_eq!(repeated_workspace.len(), 0);
- }
- #[actix_rt::test]
- async fn app_create() {
- let test = BackendAppTest::new().await;
- tracing::info!("{:?}", test.app);
- }
- #[actix_rt::test]
- async fn app_read() {
- let test = BackendAppTest::new().await;
- let read_params = AppId::new(&test.app.id);
- assert_eq!(test.server.read_app(read_params).await.is_some(), true);
- }
- #[actix_rt::test]
- async fn app_read_with_belongs() {
- let test = BackendAppTest::new().await;
- let _ = create_test_view(&test.server, &test.app.id).await;
- let _ = create_test_view(&test.server, &test.app.id).await;
- let read_params = AppId::new(&test.app.id);
- let app = test.server.read_app(read_params).await.unwrap();
- assert_eq!(app.belongings.len(), 2);
- }
- #[actix_rt::test]
- async fn app_read_with_belongs_in_trash() {
- let test = BackendAppTest::new().await;
- let _ = create_test_view(&test.server, &test.app.id).await;
- let view = create_test_view(&test.server, &test.app.id).await;
- test.server.create_view_trash(&view.id).await;
- let read_params = AppId::new(&test.app.id);
- let app = test.server.read_app(read_params).await.unwrap();
- assert_eq!(app.belongings.len(), 1);
- }
- #[actix_rt::test]
- async fn app_update() {
- let test = BackendAppTest::new().await;
- let new_name = "flowy";
- let update_params = UpdateAppParams::new(&test.app.id).name(new_name);
- test.server.update_app(update_params).await;
- let read_params = AppId::new(&test.app.id);
- let app = test.server.read_app(read_params).await.unwrap();
- assert_eq!(&app.name, new_name);
- }
- #[actix_rt::test]
- async fn app_delete() {
- let test = BackendAppTest::new().await;
- let delete_params = AppId {
- app_id: test.app.id.clone(),
- };
- test.server.delete_app(delete_params).await;
- let read_params = AppId::new(&test.app.id);
- assert_eq!(test.server.read_app(read_params).await.is_none(), true);
- }
- #[actix_rt::test]
- async fn view_create() {
- let test = BackendViewTest::new().await;
- tracing::info!("{:?}", test.view);
- }
- #[actix_rt::test]
- async fn view_update() {
- let test = BackendViewTest::new().await;
- let new_name = "name view name";
- // update
- let update_params = UpdateViewParams::new(&test.view.id).name(new_name);
- test.server.update_view(update_params).await;
- // read
- let read_params: ViewId = test.view.id.clone().into();
- let view = test.server.read_view(read_params).await.unwrap();
- assert_eq!(&view.name, new_name);
- }
- #[actix_rt::test]
- async fn view_delete() {
- let test = BackendViewTest::new().await;
- test.server.create_view_trash(&test.view.id).await;
- let trash_ids = test
- .server
- .read_trash()
- .await
- .items
- .into_iter()
- .map(|item| item.id)
- .collect::<Vec<String>>();
- // read
- let read_params: ViewId = test.view.id.clone().into();
- // the view can't read from the server. it should be in the trash
- assert_eq!(test.server.read_view(read_params).await.is_none(), true);
- assert_eq!(trash_ids.contains(&test.view.id), true);
- }
- #[actix_rt::test]
- async fn trash_delete() {
- let test = BackendViewTest::new().await;
- test.server.create_view_trash(&test.view.id).await;
- let identifier = TrashId {
- id: test.view.id.clone(),
- ty: TrashType::View,
- };
- test.server.delete_view_trash(vec![identifier].into()).await;
- assert_eq!(test.server.read_trash().await.is_empty(), true);
- }
- #[actix_rt::test]
- async fn trash_delete_all() {
- let test = BackendViewTest::new().await;
- test.server.create_view_trash(&test.view.id).await;
- test.server.delete_view_trash(RepeatedTrashId::all()).await;
- assert_eq!(test.server.read_trash().await.is_empty(), true);
- }
- #[actix_rt::test]
- async fn workspace_list_read() {
- let mut server = spawn_user_server().await;
- let token = server.register_user().await.token;
- server.user_token = Some(token);
- for i in 0..3 {
- let params = CreateWorkspaceParams {
- name: format!("{} workspace", i),
- desc: format!("This is my {} workspace", i),
- };
- let _ = server.create_workspace(params).await;
- }
- let read_params = WorkspaceId::new(None);
- let workspaces = server.read_workspaces(read_params).await;
- assert_eq!(workspaces.len(), 3);
- }
- #[actix_rt::test]
- async fn doc_read() {
- let test = BackendViewTest::new().await;
- let params = DocumentId {
- doc_id: test.view.id.clone(),
- };
- let doc = test.server.read_doc(params).await;
- assert_eq!(doc.is_some(), true);
- }
- #[actix_rt::test]
- async fn doc_create() {
- let mut revisions: Vec<Revision> = vec![];
- let server = TestUserServer::new().await;
- let doc_id = uuid::Uuid::new_v4().to_string();
- let user_id = "a".to_owned();
- let mut document = ClientDocument::new::<PlainDoc>();
- let mut offset = 0;
- for i in 0..5 {
- let content = i.to_string();
- let delta = document.insert(offset, content.clone()).unwrap();
- offset += content.len();
- let bytes = delta.to_bytes();
- let md5 = md5(&bytes);
- let revision = if i == 0 {
- Revision::new(&doc_id, i, i, bytes, &user_id, md5)
- } else {
- Revision::new(&doc_id, i - 1, i, bytes, &user_id, md5)
- };
- revisions.push(revision);
- }
- let params = CreateDocParams {
- id: doc_id.clone(),
- revisions: RepeatedRevision::new(revisions),
- };
- server.create_doc(params).await;
- let doc = server.read_doc(DocumentId { doc_id }).await;
- assert_eq!(doc.unwrap().text, document.to_json());
- }
- #[actix_rt::test]
- async fn doc_delete() {
- let test = BackendViewTest::new().await;
- let delete_params = RepeatedViewId {
- items: vec![test.view.id.clone()],
- };
- test.server.delete_view(delete_params).await;
- let params = DocumentId {
- doc_id: test.view.id.clone(),
- };
- let doc = test.server.read_doc(params).await;
- assert_eq!(doc.is_none(), true);
- }
|