script.rs 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229
  1. use crate::grid::grid_editor::GridEditorTest;
  2. use flowy_grid::entities::{
  3. CreateRowParams, FieldChangesetParams, FieldType, GridLayout, GroupPB, MoveGroupParams, MoveGroupRowParams, RowPB,
  4. };
  5. use flowy_grid::services::cell::{delete_select_option_cell, insert_select_option_cell};
  6. use flowy_grid_data_model::revision::{FieldRevision, RowChangeset};
  7. use std::sync::Arc;
  8. use std::time::Duration;
  9. use tokio::time::interval;
  10. pub enum GroupScript {
  11. AssertGroupRowCount {
  12. group_index: usize,
  13. row_count: usize,
  14. },
  15. AssertGroupCount(usize),
  16. AssertGroup {
  17. group_index: usize,
  18. expected_group: GroupPB,
  19. },
  20. AssertRow {
  21. group_index: usize,
  22. row_index: usize,
  23. row: RowPB,
  24. },
  25. MoveRow {
  26. from_group_index: usize,
  27. from_row_index: usize,
  28. to_group_index: usize,
  29. to_row_index: usize,
  30. },
  31. CreateRow {
  32. group_index: usize,
  33. },
  34. DeleteRow {
  35. group_index: usize,
  36. row_index: usize,
  37. },
  38. UpdateRow {
  39. from_group_index: usize,
  40. row_index: usize,
  41. to_group_index: usize,
  42. },
  43. MoveGroup {
  44. from_group_index: usize,
  45. to_group_index: usize,
  46. },
  47. UpdateField {
  48. changeset: FieldChangesetParams,
  49. },
  50. GroupField {
  51. field_id: String,
  52. },
  53. }
  54. pub struct GridGroupTest {
  55. inner: GridEditorTest,
  56. }
  57. impl GridGroupTest {
  58. pub async fn new() -> Self {
  59. let editor_test = GridEditorTest::new_board().await;
  60. Self { inner: editor_test }
  61. }
  62. pub async fn run_scripts(&mut self, scripts: Vec<GroupScript>) {
  63. for script in scripts {
  64. self.run_script(script).await;
  65. }
  66. }
  67. pub async fn run_script(&mut self, script: GroupScript) {
  68. match script {
  69. GroupScript::AssertGroupRowCount { group_index, row_count } => {
  70. assert_eq!(row_count, self.group_at_index(group_index).await.rows.len());
  71. }
  72. GroupScript::AssertGroupCount(count) => {
  73. let groups = self.editor.load_groups().await.unwrap();
  74. assert_eq!(count, groups.len());
  75. }
  76. GroupScript::MoveRow {
  77. from_group_index,
  78. from_row_index,
  79. to_group_index,
  80. to_row_index,
  81. } => {
  82. let groups: Vec<GroupPB> = self.editor.load_groups().await.unwrap().items;
  83. let from_row = groups.get(from_group_index).unwrap().rows.get(from_row_index).unwrap();
  84. let to_group = groups.get(to_group_index).unwrap();
  85. let to_row = to_group.rows.get(to_row_index).unwrap();
  86. let params = MoveGroupRowParams {
  87. view_id: self.inner.grid_id.clone(),
  88. from_row_id: from_row.id.clone(),
  89. to_group_id: to_group.group_id.clone(),
  90. to_row_id: Some(to_row.id.clone()),
  91. };
  92. self.editor.move_group_row(params).await.unwrap();
  93. }
  94. GroupScript::AssertRow {
  95. group_index,
  96. row_index,
  97. row,
  98. } => {
  99. //
  100. let group = self.group_at_index(group_index).await;
  101. let compare_row = group.rows.get(row_index).unwrap().clone();
  102. assert_eq!(row.id, compare_row.id);
  103. }
  104. GroupScript::CreateRow { group_index } => {
  105. //
  106. let group = self.group_at_index(group_index).await;
  107. let params = CreateRowParams {
  108. grid_id: self.editor.grid_id.clone(),
  109. start_row_id: None,
  110. group_id: Some(group.group_id.clone()),
  111. layout: GridLayout::Board,
  112. };
  113. let _ = self.editor.create_row(params).await.unwrap();
  114. }
  115. GroupScript::DeleteRow { group_index, row_index } => {
  116. let row = self.row_at_index(group_index, row_index).await;
  117. self.editor.delete_row(&row.id).await.unwrap();
  118. }
  119. GroupScript::UpdateRow {
  120. from_group_index,
  121. row_index,
  122. to_group_index,
  123. } => {
  124. let from_group = self.group_at_index(from_group_index).await;
  125. let to_group = self.group_at_index(to_group_index).await;
  126. let field_id = from_group.field_id;
  127. let field_rev = self.editor.get_field_rev(&field_id).await.unwrap();
  128. let field_type: FieldType = field_rev.ty.into();
  129. let cell_rev = if to_group.is_default {
  130. match field_type {
  131. FieldType::SingleSelect => delete_select_option_cell(to_group.group_id.clone(), &field_rev),
  132. FieldType::MultiSelect => delete_select_option_cell(to_group.group_id.clone(), &field_rev),
  133. _ => {
  134. panic!("Unsupported group field type");
  135. }
  136. }
  137. } else {
  138. match field_type {
  139. FieldType::SingleSelect => insert_select_option_cell(to_group.group_id.clone(), &field_rev),
  140. FieldType::MultiSelect => insert_select_option_cell(to_group.group_id.clone(), &field_rev),
  141. _ => {
  142. panic!("Unsupported group field type");
  143. }
  144. }
  145. };
  146. let row_id = self.row_at_index(from_group_index, row_index).await.id;
  147. let mut row_changeset = RowChangeset::new(row_id);
  148. row_changeset.cell_by_field_id.insert(field_id, cell_rev);
  149. self.editor.update_row(row_changeset).await.unwrap();
  150. }
  151. GroupScript::MoveGroup {
  152. from_group_index,
  153. to_group_index,
  154. } => {
  155. let from_group = self.group_at_index(from_group_index).await;
  156. let to_group = self.group_at_index(to_group_index).await;
  157. let params = MoveGroupParams {
  158. view_id: self.editor.grid_id.clone(),
  159. from_group_id: from_group.group_id,
  160. to_group_id: to_group.group_id,
  161. };
  162. self.editor.move_group(params).await.unwrap();
  163. //
  164. }
  165. GroupScript::AssertGroup {
  166. group_index,
  167. expected_group: group_pb,
  168. } => {
  169. let group = self.group_at_index(group_index).await;
  170. assert_eq!(group.group_id, group_pb.group_id);
  171. assert_eq!(group.desc, group_pb.desc);
  172. }
  173. GroupScript::UpdateField { changeset } => {
  174. self.editor.update_field(changeset).await.unwrap();
  175. let mut interval = interval(Duration::from_millis(130));
  176. interval.tick().await;
  177. }
  178. GroupScript::GroupField { field_id } => {
  179. self.editor.group_field(&field_id).await.unwrap();
  180. }
  181. }
  182. }
  183. pub async fn group_at_index(&self, index: usize) -> GroupPB {
  184. let groups = self.editor.load_groups().await.unwrap().items;
  185. groups.get(index).unwrap().clone()
  186. }
  187. pub async fn row_at_index(&self, group_index: usize, row_index: usize) -> RowPB {
  188. let groups = self.group_at_index(group_index).await;
  189. groups.rows.get(row_index).unwrap().clone()
  190. }
  191. pub async fn get_multi_select_field(&self) -> Arc<FieldRevision> {
  192. let field = self
  193. .inner
  194. .field_revs
  195. .iter()
  196. .find(|field_rev| {
  197. let field_type: FieldType = field_rev.ty.into();
  198. field_type.is_multi_select()
  199. })
  200. .unwrap()
  201. .clone();
  202. return field;
  203. }
  204. }
  205. impl std::ops::Deref for GridGroupTest {
  206. type Target = GridEditorTest;
  207. fn deref(&self) -> &Self::Target {
  208. &self.inner
  209. }
  210. }
  211. impl std::ops::DerefMut for GridGroupTest {
  212. fn deref_mut(&mut self) -> &mut Self::Target {
  213. &mut self.inner
  214. }
  215. }