script.rs 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. use flowy_grid::services::field::*;
  2. use flowy_grid::services::grid_editor::{ClientGridEditor, GridPadBuilder};
  3. use flowy_grid_data_model::entities::{AnyData, Field, FieldChangeset, FieldType};
  4. use flowy_sync::REVISION_WRITE_INTERVAL_IN_MILLIS;
  5. use flowy_test::event_builder::FolderEventBuilder;
  6. use flowy_test::helper::ViewTest;
  7. use flowy_test::FlowySDKTest;
  8. use std::sync::Arc;
  9. use std::time::Duration;
  10. use tokio::time::sleep;
  11. pub enum EditorScript {
  12. CreateField { field: Field },
  13. UpdateField { change: FieldChangeset },
  14. AssertFieldCount(usize),
  15. AssertFieldEqual { field_index: usize, field: Field },
  16. AssertGridMetaPad,
  17. CreateRow,
  18. }
  19. pub struct GridEditorTest {
  20. pub sdk: FlowySDKTest,
  21. pub grid_id: String,
  22. pub editor: Arc<ClientGridEditor>,
  23. }
  24. impl GridEditorTest {
  25. pub async fn new() -> Self {
  26. let sdk = FlowySDKTest::default();
  27. let _ = sdk.init_user().await;
  28. let test = ViewTest::new_grid_view(&sdk).await;
  29. let editor = sdk.grid_manager.open_grid(&test.view.id).await.unwrap();
  30. let grid_id = test.view.id;
  31. Self { sdk, grid_id, editor }
  32. }
  33. pub async fn run_scripts(&mut self, scripts: Vec<EditorScript>) {
  34. for script in scripts {
  35. self.run_script(script).await;
  36. }
  37. }
  38. pub async fn run_script(&mut self, script: EditorScript) {
  39. let grid_manager = self.sdk.grid_manager.clone();
  40. let pool = self.sdk.user_session.db_pool().unwrap();
  41. let rev_manager = self.editor.rev_manager();
  42. let cache = rev_manager.revision_cache().await;
  43. match script {
  44. EditorScript::CreateField { field } => {
  45. self.editor.create_field(field).await.unwrap();
  46. }
  47. EditorScript::UpdateField { change } => {
  48. self.editor.update_field(change).await.unwrap();
  49. }
  50. EditorScript::AssertFieldCount(count) => {
  51. assert_eq!(self.editor.get_fields(None).await.unwrap().len(), count);
  52. }
  53. EditorScript::AssertFieldEqual { field_index, field } => {
  54. let repeated_fields = self.editor.get_fields(None).await.unwrap();
  55. let compared_field = repeated_fields[field_index].clone();
  56. assert_eq!(compared_field, field);
  57. }
  58. EditorScript::AssertGridMetaPad => {
  59. sleep(Duration::from_millis(2 * REVISION_WRITE_INTERVAL_IN_MILLIS)).await;
  60. let mut grid_rev_manager = grid_manager.make_grid_rev_manager(&self.grid_id, pool.clone()).unwrap();
  61. let grid_pad = grid_rev_manager.load::<GridPadBuilder>(None).await.unwrap();
  62. println!("{}", grid_pad.delta_str());
  63. }
  64. EditorScript::CreateRow => {}
  65. }
  66. }
  67. }
  68. pub fn create_text_field() -> Field {
  69. FieldBuilder::new(RichTextTypeOptionsBuilder::new())
  70. .name("Name")
  71. .visibility(true)
  72. .field_type(FieldType::RichText)
  73. .build()
  74. }
  75. pub fn create_single_select_field() -> Field {
  76. let single_select = SingleSelectTypeOptionsBuilder::new()
  77. .option(SelectOption::new("Done"))
  78. .option(SelectOption::new("Progress"));
  79. FieldBuilder::new(single_select)
  80. .name("Name")
  81. .visibility(true)
  82. .field_type(FieldType::SingleSelect)
  83. .build()
  84. }