mirror of
				https://github.com/AppFlowy-IO/AppFlowy.git
				synced 2025-10-20 20:42:42 +00:00 
			
		
		
		
	 4708c0f779
			
		
	
	
		4708c0f779
		
			
		
	
	
	
	
		
			
			* feat: billing client * feat: subscribe workspace default impl * feat: added create subscription * feat: add get workspace subs * feat: added subscription cancellation * feat: add workspace limits api * fix: update client api * feat: user billing portal * feat: billing UI (#5455) * feat: plan ui * feat: billing ui * feat: settings plan comparison dialog * feat: complete plan+billing ui * feat: backend integration * chore: cleaning * chore: fixes after merge * fix: dependency issue * feat: added subscription plan cancellation information * feat: subscription callback + canceled date * feat: put behind feature flag * feat: downgrade/upgrade dialogs * feat: update limit error codes * fix: billing refresh + downgrade dialog * fix: some minor improvements to settings * chore: use patch for client-api in tauri * fix: add shared-entity to patch * fix: compile * ci: try to add back maximize build space step * test: increase timeout in failing test --------- Co-authored-by: Zack Fu Zi Xiang <speed2exe@live.com.sg>
		
			
				
	
	
		
			137 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			Rust
		
	
	
	
	
	
			
		
		
	
	
			137 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			Rust
		
	
	
	
	
	
| use std::time::Duration;
 | |
| 
 | |
| use event_integration_test::EventIntegrationTest;
 | |
| use flowy_folder::entities::{ChildViewUpdatePB, RepeatedViewPB, UpdateViewPayloadPB};
 | |
| use flowy_folder::notification::FolderNotification;
 | |
| 
 | |
| 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 = EventIntegrationTest::new_anon().await;
 | |
|   let workspace = test.get_current_workspace().await;
 | |
|   let rx = test
 | |
|     .notification_sender
 | |
|     .subscribe::<RepeatedViewPB>(&workspace.id, FolderNotification::DidUpdateWorkspaceViews);
 | |
| 
 | |
|   let cloned_test = test.clone();
 | |
|   let cloned_workspace_id = workspace.id.clone();
 | |
|   test.appflowy_core.dispatcher().spawn(async move {
 | |
|     cloned_test
 | |
|       .create_view(&cloned_workspace_id, "workspace child view".to_string())
 | |
|       .await;
 | |
|   });
 | |
| 
 | |
|   let views = receive_with_timeout(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 = EventIntegrationTest::new_anon().await;
 | |
|   let mut workspace = test.get_current_workspace().await;
 | |
|   let workspace_child_view = workspace.views.pop().unwrap();
 | |
|   let 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();
 | |
|   test.appflowy_core.dispatcher().spawn(async move {
 | |
|     cloned_test
 | |
|       .create_view(
 | |
|         &child_view_id,
 | |
|         "workspace child view's child view".to_string(),
 | |
|       )
 | |
|       .await;
 | |
|   });
 | |
| 
 | |
|   let update = receive_with_timeout(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 = EventIntegrationTest::new_anon().await;
 | |
|   let workspace = test.get_current_workspace().await;
 | |
|   let 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();
 | |
|   test
 | |
|     .appflowy_core
 | |
|     .dispatcher()
 | |
|     .spawn(async move {
 | |
|       cloned_test.delete_view(&cloned_delete_view_id).await;
 | |
|     })
 | |
|     .await
 | |
|     .unwrap();
 | |
| 
 | |
|   let update = test
 | |
|     .appflowy_core
 | |
|     .dispatcher()
 | |
|     .run_until(receive_with_timeout(rx, Duration::from_secs(60)))
 | |
|     .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 = EventIntegrationTest::new_anon().await;
 | |
|   let mut workspace = test.get_current_workspace().await;
 | |
|   let rx = test
 | |
|     .notification_sender
 | |
|     .subscribe::<ChildViewUpdatePB>(&workspace.id, FolderNotification::DidUpdateChildViews);
 | |
| 
 | |
|   let cloned_test = test.clone();
 | |
|   let view = workspace.views.pop().unwrap();
 | |
|   assert!(!view.is_favorite);
 | |
| 
 | |
|   let update_view_id = view.id.clone();
 | |
|   test.appflowy_core.dispatcher().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(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!(expected_view.is_favorite);
 | |
| }
 |