123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187 |
- use flowy_database2::entities::{CellChangesetPB, FieldType};
- use flowy_database2::services::cell::ToCellChangeset;
- use flowy_database2::services::field::{
- ChecklistTypeOption, DateCellData, MultiSelectTypeOption, SelectOptionCellChangeset,
- SingleSelectTypeOption, StrCellData, URLCellData,
- };
- use crate::database::cell_test::script::CellScript::UpdateCell;
- use crate::database::cell_test::script::DatabaseCellTest;
- use crate::database::field_test::util::make_date_cell_string;
- #[tokio::test]
- async fn grid_cell_update() {
- let mut test = DatabaseCellTest::new().await;
- let fields = test.get_fields();
- let rows = &test.rows;
- let mut scripts = vec![];
- for (_, row) in rows.iter().enumerate() {
- for field in &fields {
- let field_type = FieldType::from(field.field_type);
- let cell_changeset = match field_type {
- FieldType::RichText => "".to_string(),
- FieldType::Number => "123".to_string(),
- FieldType::DateTime | FieldType::UpdatedAt | FieldType::CreatedAt => {
- make_date_cell_string("123")
- },
- FieldType::SingleSelect => {
- let type_option = field
- .get_type_option::<SingleSelectTypeOption>(field.field_type)
- .unwrap();
- SelectOptionCellChangeset::from_insert_option_id(&type_option.options.first().unwrap().id)
- .to_cell_changeset_str()
- },
- FieldType::MultiSelect => {
- let type_option = field
- .get_type_option::<MultiSelectTypeOption>(field.field_type)
- .unwrap();
- SelectOptionCellChangeset::from_insert_option_id(&type_option.options.first().unwrap().id)
- .to_cell_changeset_str()
- },
- FieldType::Checklist => {
- let type_option = field
- .get_type_option::<ChecklistTypeOption>(field.field_type)
- .unwrap();
- 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: test.view_id.clone(),
- row_id: row.id.clone().into(),
- field_id: field.id.clone(),
- cell_changeset,
- },
- is_err: false,
- });
- }
- }
- test.run_scripts(scripts).await;
- }
- #[tokio::test]
- async fn text_cell_data_test() {
- let test = DatabaseCellTest::new().await;
- let text_field = test.get_first_field(FieldType::RichText);
- let cells = test
- .editor
- .get_cells_for_field(&test.view_id, &text_field.id)
- .await;
- for (i, cell) in cells.into_iter().enumerate() {
- let text = StrCellData::from(cell.as_ref());
- 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_data_test() {
- let test = DatabaseCellTest::new().await;
- let url_field = test.get_first_field(FieldType::URL);
- let cells = test
- .editor
- .get_cells_for_field(&test.view_id, &url_field.id)
- .await;
- for (i, cell) in cells.into_iter().enumerate() {
- let cell = URLCellData::from(cell.as_ref());
- if i == 0 {
- assert_eq!(cell.url.as_str(), "https://www.appflowy.io/");
- }
- }
- }
- #[tokio::test]
- async fn update_updated_at_field_on_other_cell_update() {
- let mut test = DatabaseCellTest::new().await;
- let updated_at_field = test.get_first_field(FieldType::UpdatedAt);
- let text_field = test
- .fields
- .iter()
- .find(|&f| FieldType::from(f.field_type) == FieldType::RichText)
- .unwrap();
- let before_update_timestamp = chrono::offset::Utc::now().timestamp();
- test
- .run_script(UpdateCell {
- changeset: CellChangesetPB {
- view_id: test.view_id.clone(),
- row_id: test.rows[0].id.to_string(),
- field_id: text_field.id.clone(),
- cell_changeset: "change".to_string(),
- },
- is_err: false,
- })
- .await;
- let after_update_timestamp = chrono::offset::Utc::now().timestamp();
- let cells = test
- .editor
- .get_cells_for_field(&test.view_id, &updated_at_field.id)
- .await;
- assert!(cells.len() > 0);
- for (i, cell) in cells.into_iter().enumerate() {
- let timestamp = DateCellData::from(cell.as_ref()).timestamp.unwrap();
- println!(
- "{}, bf: {}, af: {}",
- timestamp, before_update_timestamp, after_update_timestamp
- );
- match i {
- 0 => assert!(
- timestamp >= before_update_timestamp && timestamp <= after_update_timestamp,
- "{} >= {} && {} <= {}",
- timestamp,
- before_update_timestamp,
- timestamp,
- after_update_timestamp
- ),
- 1 => assert!(
- timestamp <= before_update_timestamp,
- "{} <= {}",
- timestamp,
- before_update_timestamp
- ),
- 2 => assert!(
- timestamp <= before_update_timestamp,
- "{} <= {}",
- timestamp,
- before_update_timestamp
- ),
- 3 => assert!(
- timestamp <= before_update_timestamp,
- "{} <= {}",
- timestamp,
- before_update_timestamp
- ),
- 4 => assert!(
- timestamp <= before_update_timestamp,
- "{} <= {}",
- timestamp,
- before_update_timestamp
- ),
- 5 => assert!(
- timestamp <= before_update_timestamp,
- "{} <= {}",
- timestamp,
- before_update_timestamp
- ),
- _ => {},
- }
- }
- }
|