test.rs 9.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316
  1. use collab_database::database::gen_option_id;
  2. use flowy_database2::entities::{FieldChangesetParams, FieldType};
  3. use flowy_database2::services::field::{SelectOption, CHECK, UNCHECK};
  4. use crate::database::field_test::script::DatabaseFieldTest;
  5. use crate::database::field_test::script::FieldScript::*;
  6. use crate::database::field_test::util::*;
  7. #[tokio::test]
  8. async fn grid_create_field() {
  9. let mut test = DatabaseFieldTest::new().await;
  10. let (params, field) = create_text_field(&test.view_id());
  11. let scripts = vec![
  12. CreateField { params },
  13. AssertFieldTypeOptionEqual {
  14. field_index: test.field_count(),
  15. expected_type_option_data: field.get_any_type_option(field.field_type).unwrap(),
  16. },
  17. ];
  18. test.run_scripts(scripts).await;
  19. let (params, field) = create_single_select_field(&test.view_id());
  20. let scripts = vec![
  21. CreateField { params },
  22. AssertFieldTypeOptionEqual {
  23. field_index: test.field_count(),
  24. expected_type_option_data: field.get_any_type_option(field.field_type).unwrap(),
  25. },
  26. ];
  27. test.run_scripts(scripts).await;
  28. let (params, field) = create_date_field(&test.view_id(), FieldType::CreatedAt);
  29. let scripts = vec![
  30. CreateField { params },
  31. AssertFieldTypeOptionEqual {
  32. field_index: test.field_count(),
  33. expected_type_option_data: field.get_any_type_option(field.field_type).unwrap(),
  34. },
  35. ];
  36. test.run_scripts(scripts).await;
  37. }
  38. #[tokio::test]
  39. async fn grid_create_duplicate_field() {
  40. let mut test = DatabaseFieldTest::new().await;
  41. let (params, _) = create_text_field(&test.view_id());
  42. let field_count = test.field_count();
  43. let expected_field_count = field_count + 1;
  44. let scripts = vec![
  45. CreateField {
  46. params: params.clone(),
  47. },
  48. AssertFieldCount(expected_field_count),
  49. ];
  50. test.run_scripts(scripts).await;
  51. }
  52. #[tokio::test]
  53. async fn grid_update_field_with_empty_change() {
  54. let mut test = DatabaseFieldTest::new().await;
  55. let (params, _) = create_single_select_field(&test.view_id());
  56. let create_field_index = test.field_count();
  57. let scripts = vec![CreateField { params }];
  58. test.run_scripts(scripts).await;
  59. let field = test.get_fields().pop().unwrap().clone();
  60. let changeset = FieldChangesetParams {
  61. field_id: field.id.clone(),
  62. view_id: test.view_id(),
  63. ..Default::default()
  64. };
  65. let scripts = vec![
  66. UpdateField { changeset },
  67. AssertFieldTypeOptionEqual {
  68. field_index: create_field_index,
  69. expected_type_option_data: field.get_any_type_option(field.field_type).unwrap(),
  70. },
  71. ];
  72. test.run_scripts(scripts).await;
  73. }
  74. #[tokio::test]
  75. async fn grid_delete_field() {
  76. let mut test = DatabaseFieldTest::new().await;
  77. let original_field_count = test.field_count();
  78. let (params, _) = create_text_field(&test.view_id());
  79. let scripts = vec![CreateField { params }];
  80. test.run_scripts(scripts).await;
  81. let field = test.get_fields().pop().unwrap();
  82. let scripts = vec![
  83. DeleteField { field },
  84. AssertFieldCount(original_field_count),
  85. ];
  86. test.run_scripts(scripts).await;
  87. }
  88. #[tokio::test]
  89. async fn grid_switch_from_select_option_to_checkbox_test() {
  90. let mut test = DatabaseFieldTest::new().await;
  91. let field = test.get_first_field(FieldType::SingleSelect);
  92. // Update the type option data of single select option
  93. let mut single_select_type_option = test.get_single_select_type_option(&field.id);
  94. single_select_type_option.options.clear();
  95. // Add a new option with name CHECK
  96. single_select_type_option.options.push(SelectOption {
  97. id: gen_option_id(),
  98. name: CHECK.to_string(),
  99. color: Default::default(),
  100. });
  101. // Add a new option with name UNCHECK
  102. single_select_type_option.options.push(SelectOption {
  103. id: gen_option_id(),
  104. name: UNCHECK.to_string(),
  105. color: Default::default(),
  106. });
  107. let scripts = vec![
  108. UpdateTypeOption {
  109. field_id: field.id.clone(),
  110. type_option: single_select_type_option.into(),
  111. },
  112. SwitchToField {
  113. field_id: field.id.clone(),
  114. new_field_type: FieldType::Checkbox,
  115. },
  116. ];
  117. test.run_scripts(scripts).await;
  118. }
  119. #[tokio::test]
  120. async fn grid_switch_from_checkbox_to_select_option_test() {
  121. let mut test = DatabaseFieldTest::new().await;
  122. let checkbox_field = test.get_first_field(FieldType::Checkbox).clone();
  123. let scripts = vec![
  124. // switch to single-select field type
  125. SwitchToField {
  126. field_id: checkbox_field.id.clone(),
  127. new_field_type: FieldType::SingleSelect,
  128. },
  129. // Assert the cell content after switch the field type. The cell content will be changed if
  130. // the FieldType::SingleSelect implement the cell data TypeOptionTransform. Check out the
  131. // TypeOptionTransform trait for more information.
  132. //
  133. // Make sure which cell of the row you want to check.
  134. AssertCellContent {
  135. field_id: checkbox_field.id.clone(),
  136. // the mock data of the checkbox with row_index one is "true"
  137. row_index: 1,
  138. // the from_field_type represents as the current field type
  139. from_field_type: FieldType::Checkbox,
  140. // The content of the checkbox should transform to the corresponding option name.
  141. expected_content: CHECK.to_string(),
  142. },
  143. ];
  144. test.run_scripts(scripts).await;
  145. let single_select_type_option = test.get_single_select_type_option(&checkbox_field.id);
  146. assert_eq!(single_select_type_option.options.len(), 2);
  147. assert!(single_select_type_option
  148. .options
  149. .iter()
  150. .any(|option| option.name == UNCHECK));
  151. assert!(single_select_type_option
  152. .options
  153. .iter()
  154. .any(|option| option.name == CHECK));
  155. }
  156. // Test when switching the current field from Multi-select to Text test
  157. // The build-in test data is located in `make_test_grid` method(flowy-database/tests/grid_editor.rs).
  158. // input:
  159. // option1, option2 -> "option1.name, option2.name"
  160. #[tokio::test]
  161. async fn grid_switch_from_multi_select_to_text_test() {
  162. let mut test = DatabaseFieldTest::new().await;
  163. let field_rev = test.get_first_field(FieldType::MultiSelect).clone();
  164. let multi_select_type_option = test.get_multi_select_type_option(&field_rev.id);
  165. let script_switch_field = vec![SwitchToField {
  166. field_id: field_rev.id.clone(),
  167. new_field_type: FieldType::RichText,
  168. }];
  169. test.run_scripts(script_switch_field).await;
  170. let script_assert_field = vec![AssertCellContent {
  171. field_id: field_rev.id.clone(),
  172. row_index: 0,
  173. from_field_type: FieldType::MultiSelect,
  174. expected_content: format!(
  175. "{},{}",
  176. multi_select_type_option.get(0).unwrap().name,
  177. multi_select_type_option.get(1).unwrap().name
  178. ),
  179. }];
  180. test.run_scripts(script_assert_field).await;
  181. }
  182. // Test when switching the current field from Checkbox to Text test
  183. // input:
  184. // check -> "Yes"
  185. // unchecked -> ""
  186. #[tokio::test]
  187. async fn grid_switch_from_checkbox_to_text_test() {
  188. let mut test = DatabaseFieldTest::new().await;
  189. let field_rev = test.get_first_field(FieldType::Checkbox);
  190. let scripts = vec![
  191. SwitchToField {
  192. field_id: field_rev.id.clone(),
  193. new_field_type: FieldType::RichText,
  194. },
  195. AssertCellContent {
  196. field_id: field_rev.id.clone(),
  197. row_index: 1,
  198. from_field_type: FieldType::Checkbox,
  199. expected_content: "Yes".to_string(),
  200. },
  201. AssertCellContent {
  202. field_id: field_rev.id.clone(),
  203. row_index: 2,
  204. from_field_type: FieldType::Checkbox,
  205. expected_content: "No".to_string(),
  206. },
  207. ];
  208. test.run_scripts(scripts).await;
  209. }
  210. // Test when switching the current field from Checkbox to Text test
  211. // input:
  212. // "Yes" -> check
  213. // "" -> unchecked
  214. #[tokio::test]
  215. async fn grid_switch_from_text_to_checkbox_test() {
  216. let mut test = DatabaseFieldTest::new().await;
  217. let field = test.get_first_field(FieldType::RichText).clone();
  218. let scripts = vec![
  219. SwitchToField {
  220. field_id: field.id.clone(),
  221. new_field_type: FieldType::Checkbox,
  222. },
  223. AssertCellContent {
  224. field_id: field.id.clone(),
  225. row_index: 0,
  226. from_field_type: FieldType::RichText,
  227. expected_content: "".to_string(),
  228. },
  229. ];
  230. test.run_scripts(scripts).await;
  231. }
  232. // Test when switching the current field from Date to Text test
  233. // input:
  234. // 1647251762 -> Mar 14,2022 (This string will be different base on current data setting)
  235. #[tokio::test]
  236. async fn grid_switch_from_date_to_text_test() {
  237. let mut test = DatabaseFieldTest::new().await;
  238. let field = test.get_first_field(FieldType::DateTime).clone();
  239. let scripts = vec![
  240. SwitchToField {
  241. field_id: field.id.clone(),
  242. new_field_type: FieldType::RichText,
  243. },
  244. AssertCellContent {
  245. field_id: field.id.clone(),
  246. row_index: 2,
  247. from_field_type: FieldType::DateTime,
  248. expected_content: "2022/03/14".to_string(),
  249. },
  250. AssertCellContent {
  251. field_id: field.id.clone(),
  252. row_index: 3,
  253. from_field_type: FieldType::DateTime,
  254. expected_content: "2022/11/17".to_string(),
  255. },
  256. ];
  257. test.run_scripts(scripts).await;
  258. }
  259. // Test when switching the current field from Number to Text test
  260. // input:
  261. // $1 -> "$1"(This string will be different base on current data setting)
  262. #[tokio::test]
  263. async fn grid_switch_from_number_to_text_test() {
  264. let mut test = DatabaseFieldTest::new().await;
  265. let field = test.get_first_field(FieldType::Number).clone();
  266. let scripts = vec![
  267. SwitchToField {
  268. field_id: field.id.clone(),
  269. new_field_type: FieldType::RichText,
  270. },
  271. AssertCellContent {
  272. field_id: field.id.clone(),
  273. row_index: 0,
  274. from_field_type: FieldType::Number,
  275. expected_content: "$1".to_string(),
  276. },
  277. AssertCellContent {
  278. field_id: field.id.clone(),
  279. row_index: 4,
  280. from_field_type: FieldType::Number,
  281. expected_content: "".to_string(),
  282. },
  283. ];
  284. test.run_scripts(scripts).await;
  285. }