| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103 | 
							- use crate::database::cell_test::script::CellScript::*;
 
- use crate::database::cell_test::script::DatabaseCellTest;
 
- use crate::database::field_test::util::make_date_cell_string;
 
- use flowy_database::entities::{CellChangesetPB, FieldType};
 
- use flowy_database::services::cell::ToCellChangesetString;
 
- use flowy_database::services::field::selection_type_option::SelectOptionCellChangeset;
 
- use flowy_database::services::field::{
 
-   ChecklistTypeOptionPB, MultiSelectTypeOptionPB, SingleSelectTypeOptionPB,
 
- };
 
- #[tokio::test]
 
- async fn grid_cell_update() {
 
-   let mut test = DatabaseCellTest::new().await;
 
-   let field_revs = &test.field_revs;
 
-   let row_revs = &test.row_revs;
 
-   let grid_blocks = &test.block_meta_revs;
 
-   // For the moment, We only have one block to store rows
 
-   let block_id = &grid_blocks.first().unwrap().block_id;
 
-   let mut scripts = vec![];
 
-   for (_, row_rev) in row_revs.iter().enumerate() {
 
-     for field_rev in field_revs {
 
-       let field_type: FieldType = field_rev.ty.into();
 
-       let data = match field_type {
 
-         FieldType::RichText => "".to_string(),
 
-         FieldType::Number => "123".to_string(),
 
-         FieldType::DateTime => make_date_cell_string("123"),
 
-         FieldType::SingleSelect => {
 
-           let type_option = SingleSelectTypeOptionPB::from(field_rev);
 
-           SelectOptionCellChangeset::from_insert_option_id(&type_option.options.first().unwrap().id)
 
-             .to_cell_changeset_str()
 
-         },
 
-         FieldType::MultiSelect => {
 
-           let type_option = MultiSelectTypeOptionPB::from(field_rev);
 
-           SelectOptionCellChangeset::from_insert_option_id(&type_option.options.first().unwrap().id)
 
-             .to_cell_changeset_str()
 
-         },
 
-         FieldType::Checklist => {
 
-           let type_option = ChecklistTypeOptionPB::from(field_rev);
 
-           SelectOptionCellChangeset::from_insert_option_id(&type_option.options.first().unwrap().id)
 
-             .to_cell_changeset_str()
 
-         },
 
-         FieldType::Checkbox => "1".to_string(),
 
-         FieldType::URL => "1".to_string(),
 
-       };
 
-       scripts.push(UpdateCell {
 
-         changeset: CellChangesetPB {
 
-           view_id: block_id.to_string(),
 
-           row_id: row_rev.id.clone(),
 
-           field_id: field_rev.id.clone(),
 
-           type_cell_data: data,
 
-         },
 
-         is_err: false,
 
-       });
 
-     }
 
-   }
 
-   test.run_scripts(scripts).await;
 
- }
 
- #[tokio::test]
 
- async fn text_cell_date_test() {
 
-   let test = DatabaseCellTest::new().await;
 
-   let text_field = test.get_first_field_rev(FieldType::RichText);
 
-   let cells = test
 
-     .editor
 
-     .get_cells_for_field(&test.view_id, &text_field.id)
 
-     .await
 
-     .unwrap();
 
-   for (i, cell) in cells.into_iter().enumerate() {
 
-     let text = cell.into_text_field_cell_data().unwrap();
 
-     match i {
 
-       0 => assert_eq!(text.as_str(), "A"),
 
-       1 => assert_eq!(text.as_str(), ""),
 
-       2 => assert_eq!(text.as_str(), "C"),
 
-       3 => assert_eq!(text.as_str(), "DA"),
 
-       4 => assert_eq!(text.as_str(), "AE"),
 
-       5 => assert_eq!(text.as_str(), "AE"),
 
-       _ => {},
 
-     }
 
-   }
 
- }
 
- #[tokio::test]
 
- async fn url_cell_date_test() {
 
-   let test = DatabaseCellTest::new().await;
 
-   let url_field = test.get_first_field_rev(FieldType::URL);
 
-   let cells = test
 
-     .editor
 
-     .get_cells_for_field(&test.view_id, &url_field.id)
 
-     .await
 
-     .unwrap();
 
-   for (i, cell) in cells.into_iter().enumerate() {
 
-     let url_cell_data = cell.into_url_field_cell_data().unwrap();
 
-     if i == 0 {
 
-       assert_eq!(url_cell_data.url.as_str(), "https://www.appflowy.io/");
 
-     }
 
-   }
 
- }
 
 
  |