| 
									
										
										
										
											2023-10-02 17:22:22 +08:00
										 |  |  | use std::time::Duration;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-25 15:25:31 +08:00
										 |  |  | use event_integration::document_event::assert_document_data_equal;
 | 
					
						
							| 
									
										
										
										
											2023-12-31 07:29:40 +08:00
										 |  |  | use flowy_document::entities::DocumentSyncStatePB;
 | 
					
						
							| 
									
										
										
										
											2023-10-02 17:22:22 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | use crate::document::supabase_test::helper::FlowySupabaseDocumentTest;
 | 
					
						
							|  |  |  | use crate::util::receive_with_timeout;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #[tokio::test]
 | 
					
						
							|  |  |  | async fn supabase_document_edit_sync_test() {
 | 
					
						
							|  |  |  |   if let Some(test) = FlowySupabaseDocumentTest::new().await {
 | 
					
						
							|  |  |  |     let view = test.create_document().await;
 | 
					
						
							|  |  |  |     let document_id = view.id.clone();
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     let cloned_test = test.clone();
 | 
					
						
							|  |  |  |     let cloned_document_id = document_id.clone();
 | 
					
						
							| 
									
										
										
										
											2023-12-27 11:42:39 +08:00
										 |  |  |     test.appflowy_core.dispatcher().spawn(async move {
 | 
					
						
							| 
									
										
										
										
											2023-10-02 17:22:22 +08:00
										 |  |  |       cloned_test
 | 
					
						
							|  |  |  |         .insert_document_text(&cloned_document_id, "hello world", 0)
 | 
					
						
							|  |  |  |         .await;
 | 
					
						
							|  |  |  |     });
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // wait all update are send to the remote
 | 
					
						
							| 
									
										
										
										
											2023-10-30 12:35:06 +08:00
										 |  |  |     let rx = test
 | 
					
						
							| 
									
										
										
										
											2023-10-02 17:22:22 +08:00
										 |  |  |       .notification_sender
 | 
					
						
							| 
									
										
										
										
											2023-12-21 08:12:40 +08:00
										 |  |  |       .subscribe_with_condition::<DocumentSyncStatePB, _>(&document_id, |pb| !pb.is_syncing);
 | 
					
						
							| 
									
										
										
										
											2023-10-30 12:35:06 +08:00
										 |  |  |     receive_with_timeout(rx, Duration::from_secs(30))
 | 
					
						
							| 
									
										
										
										
											2023-10-02 17:22:22 +08:00
										 |  |  |       .await
 | 
					
						
							|  |  |  |       .unwrap();
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     let document_data = test.get_document_data(&document_id).await;
 | 
					
						
							| 
									
										
										
										
											2023-12-27 11:42:39 +08:00
										 |  |  |     let update = test.get_document_doc_state(&document_id).await;
 | 
					
						
							| 
									
										
										
										
											2023-10-02 17:22:22 +08:00
										 |  |  |     assert_document_data_equal(&update, &document_id, document_data);
 | 
					
						
							|  |  |  |   }
 | 
					
						
							|  |  |  | }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #[tokio::test]
 | 
					
						
							|  |  |  | async fn supabase_document_edit_sync_test2() {
 | 
					
						
							|  |  |  |   if let Some(test) = FlowySupabaseDocumentTest::new().await {
 | 
					
						
							|  |  |  |     let view = test.create_document().await;
 | 
					
						
							|  |  |  |     let document_id = view.id.clone();
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     for i in 0..10 {
 | 
					
						
							|  |  |  |       test
 | 
					
						
							|  |  |  |         .insert_document_text(&document_id, "hello world", i)
 | 
					
						
							|  |  |  |         .await;
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // wait all update are send to the remote
 | 
					
						
							| 
									
										
										
										
											2023-10-30 12:35:06 +08:00
										 |  |  |     let rx = test
 | 
					
						
							| 
									
										
										
										
											2023-10-02 17:22:22 +08:00
										 |  |  |       .notification_sender
 | 
					
						
							| 
									
										
										
										
											2023-12-21 08:12:40 +08:00
										 |  |  |       .subscribe_with_condition::<DocumentSyncStatePB, _>(&document_id, |pb| !pb.is_syncing);
 | 
					
						
							| 
									
										
										
										
											2023-10-30 12:35:06 +08:00
										 |  |  |     receive_with_timeout(rx, Duration::from_secs(30))
 | 
					
						
							| 
									
										
										
										
											2023-10-02 17:22:22 +08:00
										 |  |  |       .await
 | 
					
						
							|  |  |  |       .unwrap();
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     let document_data = test.get_document_data(&document_id).await;
 | 
					
						
							| 
									
										
										
										
											2023-12-27 11:42:39 +08:00
										 |  |  |     let update = test.get_document_doc_state(&document_id).await;
 | 
					
						
							| 
									
										
										
										
											2023-10-02 17:22:22 +08:00
										 |  |  |     assert_document_data_equal(&update, &document_id, document_data);
 | 
					
						
							|  |  |  |   }
 | 
					
						
							|  |  |  | }
 |