row_test.rs 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  1. use crate::grid::field_util::*;
  2. use crate::grid::row_util::GridRowTestBuilder;
  3. use crate::grid::script::EditorScript::*;
  4. use crate::grid::script::*;
  5. use chrono::NaiveDateTime;
  6. use flowy_grid::services::field::{
  7. DateCellData, MultiSelectTypeOption, SingleSelectTypeOption, SELECTION_IDS_SEPARATOR,
  8. };
  9. use flowy_grid::services::row::{
  10. decode_cell_data_from_type_option_cell_data, CreateRowRevisionBuilder, CreateRowRevisionPayload,
  11. };
  12. use flowy_grid_data_model::entities::FieldType;
  13. use flowy_grid_data_model::revision::{FieldRevision, RowMetaChangeset};
  14. #[tokio::test]
  15. async fn grid_create_row_count_test() {
  16. let test = GridEditorTest::new().await;
  17. let scripts = vec![
  18. AssertRowCount(3),
  19. CreateEmptyRow,
  20. CreateEmptyRow,
  21. CreateRow {
  22. payload: GridRowTestBuilder::new(&test).build(),
  23. },
  24. AssertRowCount(6),
  25. ];
  26. GridEditorTest::new().await.run_scripts(scripts).await;
  27. }
  28. #[tokio::test]
  29. async fn grid_update_row() {
  30. let mut test = GridEditorTest::new().await;
  31. let payload = GridRowTestBuilder::new(&test).build();
  32. let changeset = RowMetaChangeset {
  33. row_id: payload.row_id.clone(),
  34. height: None,
  35. visibility: None,
  36. cell_by_field_id: Default::default(),
  37. };
  38. let scripts = vec![AssertRowCount(3), CreateRow { payload }, UpdateRow { changeset }];
  39. test.run_scripts(scripts).await;
  40. let expected_row = (&*test.row_revs.last().cloned().unwrap()).clone();
  41. let scripts = vec![AssertRow { expected_row }, AssertRowCount(4)];
  42. test.run_scripts(scripts).await;
  43. }
  44. #[tokio::test]
  45. async fn grid_delete_row() {
  46. let mut test = GridEditorTest::new().await;
  47. let payload1 = GridRowTestBuilder::new(&test).build();
  48. let payload2 = GridRowTestBuilder::new(&test).build();
  49. let row_ids = vec![payload1.row_id.clone(), payload2.row_id.clone()];
  50. let scripts = vec![
  51. AssertRowCount(3),
  52. CreateRow { payload: payload1 },
  53. CreateRow { payload: payload2 },
  54. AssertBlockCount(1),
  55. AssertBlock {
  56. block_index: 0,
  57. row_count: 5,
  58. start_row_index: 0,
  59. },
  60. DeleteRows { row_ids },
  61. AssertBlock {
  62. block_index: 0,
  63. row_count: 3,
  64. start_row_index: 0,
  65. },
  66. ];
  67. test.run_scripts(scripts).await;
  68. }
  69. #[tokio::test]
  70. async fn grid_row_add_cells_test() {
  71. let mut test = GridEditorTest::new().await;
  72. let mut builder = CreateRowRevisionBuilder::new(&test.field_revs);
  73. for field in &test.field_revs {
  74. match field.field_type {
  75. FieldType::RichText => {
  76. builder.add_cell(&field.id, "hello world".to_owned()).unwrap();
  77. }
  78. FieldType::Number => {
  79. builder.add_cell(&field.id, "18,443".to_owned()).unwrap();
  80. }
  81. FieldType::DateTime => {
  82. builder
  83. .add_cell(&field.id, make_date_cell_string("1647251762"))
  84. .unwrap();
  85. }
  86. FieldType::SingleSelect => {
  87. let type_option = SingleSelectTypeOption::from(field);
  88. let option = type_option.options.first().unwrap();
  89. builder.add_select_option_cell(&field.id, option.id.clone()).unwrap();
  90. }
  91. FieldType::MultiSelect => {
  92. let type_option = MultiSelectTypeOption::from(field);
  93. let ops_ids = type_option
  94. .options
  95. .iter()
  96. .map(|option| option.id.clone())
  97. .collect::<Vec<_>>()
  98. .join(SELECTION_IDS_SEPARATOR);
  99. builder.add_select_option_cell(&field.id, ops_ids).unwrap();
  100. }
  101. FieldType::Checkbox => {
  102. builder.add_cell(&field.id, "false".to_string()).unwrap();
  103. }
  104. FieldType::URL => {
  105. builder.add_cell(&field.id, "1".to_string()).unwrap();
  106. }
  107. }
  108. }
  109. let context = builder.build();
  110. let scripts = vec![CreateRow { payload: context }, AssertGridRevisionPad];
  111. test.run_scripts(scripts).await;
  112. }
  113. #[tokio::test]
  114. async fn grid_row_add_date_cell_test() {
  115. let mut test = GridEditorTest::new().await;
  116. let mut builder = CreateRowRevisionBuilder::new(&test.field_revs);
  117. let mut date_field = None;
  118. let timestamp = 1647390674;
  119. for field in &test.field_revs {
  120. if field.field_type == FieldType::DateTime {
  121. date_field = Some(field.clone());
  122. NaiveDateTime::from_timestamp(123, 0);
  123. // The data should not be empty
  124. assert!(builder.add_cell(&field.id, "".to_string()).is_err());
  125. assert!(builder.add_cell(&field.id, make_date_cell_string("123")).is_ok());
  126. assert!(builder
  127. .add_cell(&field.id, make_date_cell_string(&timestamp.to_string()))
  128. .is_ok());
  129. }
  130. }
  131. let context = builder.build();
  132. let date_field = date_field.unwrap();
  133. let cell_data = context.cell_by_field_id.get(&date_field.id).unwrap().clone();
  134. assert_eq!(
  135. decode_cell_data_from_type_option_cell_data(cell_data.data.clone(), &date_field, &date_field.field_type)
  136. .parse::<DateCellData>()
  137. .unwrap()
  138. .date,
  139. "2022/03/16",
  140. );
  141. let scripts = vec![CreateRow { payload: context }];
  142. test.run_scripts(scripts).await;
  143. }