123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127 |
- use std::time::Duration;
- use flowy_folder2::entities::{ChildViewUpdatePB, RepeatedViewPB, UpdateViewPayloadPB};
- use flowy_folder2::notification::FolderNotification;
- use flowy_test::FlowyCoreTest;
- use crate::util::receive_with_timeout;
- #[tokio::test]
- /// The primary purpose of this test is to validate that the notification subscription mechanism
- /// correctly notifies the subscriber of updates to workspace views.
- /// 1. Initialize the `FlowyCoreTest` with a guest user.
- /// 2. Retrieve the current workspace for the test user.
- /// 3. Subscribe to workspace view updates using the `RepeatedViewPB` notification.
- /// 4. Spawn a new asynchronous task to create a new view named "test_view" within the workspace.
- /// 5. Await the notification for workspace view updates with a timeout of 30 seconds.
- /// 6. Ensure that the received views contain the newly created "test_view".
- async fn create_child_view_in_workspace_subscription_test() {
- let test = FlowyCoreTest::new_with_guest_user().await;
- let workspace = test.get_current_workspace().await.workspace;
- let mut rx = test
- .notification_sender
- .subscribe::<RepeatedViewPB>(&workspace.id, FolderNotification::DidUpdateWorkspaceViews);
- let cloned_test = test.clone();
- let cloned_workspace_id = workspace.id.clone();
- tokio::spawn(async move {
- cloned_test
- .create_view(&cloned_workspace_id, "workspace child view".to_string())
- .await;
- });
- let views = receive_with_timeout(&mut rx, Duration::from_secs(30))
- .await
- .unwrap()
- .items;
- assert_eq!(views.len(), 2);
- assert_eq!(views[1].name, "workspace child view".to_string());
- }
- #[tokio::test]
- async fn create_child_view_in_view_subscription_test() {
- let test = FlowyCoreTest::new_with_guest_user().await;
- let mut workspace = test.get_current_workspace().await.workspace;
- let workspace_child_view = workspace.views.pop().unwrap();
- let mut rx = test.notification_sender.subscribe::<ChildViewUpdatePB>(
- &workspace_child_view.id,
- FolderNotification::DidUpdateChildViews,
- );
- let cloned_test = test.clone();
- let child_view_id = workspace_child_view.id.clone();
- tokio::spawn(async move {
- cloned_test
- .create_view(
- &child_view_id,
- "workspace child view's child view".to_string(),
- )
- .await;
- });
- let update = receive_with_timeout(&mut rx, Duration::from_secs(30))
- .await
- .unwrap();
- assert_eq!(update.create_child_views.len(), 1);
- assert_eq!(
- update.create_child_views[0].name,
- "workspace child view's child view".to_string()
- );
- }
- #[tokio::test]
- async fn delete_view_subscription_test() {
- let test = FlowyCoreTest::new_with_guest_user().await;
- let workspace = test.get_current_workspace().await.workspace;
- let mut rx = test
- .notification_sender
- .subscribe::<ChildViewUpdatePB>(&workspace.id, FolderNotification::DidUpdateChildViews);
- let cloned_test = test.clone();
- let delete_view_id = workspace.views.first().unwrap().id.clone();
- let cloned_delete_view_id = delete_view_id.clone();
- tokio::spawn(async move {
- cloned_test.delete_view(&cloned_delete_view_id).await;
- });
- let update = receive_with_timeout(&mut rx, Duration::from_secs(30))
- .await
- .unwrap();
- assert_eq!(update.delete_child_views.len(), 1);
- assert_eq!(update.delete_child_views[0], delete_view_id);
- }
- #[tokio::test]
- async fn update_view_subscription_test() {
- let test = FlowyCoreTest::new_with_guest_user().await;
- let mut workspace = test.get_current_workspace().await.workspace;
- let mut rx = test
- .notification_sender
- .subscribe::<ChildViewUpdatePB>(&workspace.id, FolderNotification::DidUpdateChildViews);
- let cloned_test = test.clone();
- let view = workspace.views.pop().unwrap();
- assert_eq!(view.is_favorite, false);
- let update_view_id = view.id.clone();
- tokio::spawn(async move {
- cloned_test
- .update_view(UpdateViewPayloadPB {
- view_id: update_view_id,
- name: Some("hello world".to_string()),
- is_favorite: Some(true),
- ..Default::default()
- })
- .await;
- });
- let update = receive_with_timeout(&mut rx, Duration::from_secs(30))
- .await
- .unwrap();
- assert_eq!(update.update_child_views.len(), 1);
- let expected_view = update.update_child_views.first().unwrap();
- assert_eq!(expected_view.id, view.id);
- assert_eq!(expected_view.name, "hello world".to_string());
- assert_eq!(expected_view.is_favorite, true);
- }
|