2023-04-28 14:08:53 +08:00
|
|
|
use collab_database::database::gen_option_id;
|
2024-09-25 11:44:19 +08:00
|
|
|
use collab_database::fields::select_type_option::{SelectOption, SelectTypeOption};
|
2024-09-30 22:14:15 +08:00
|
|
|
use flowy_database2::entities::{FieldChangesetPB, FieldType};
|
2024-09-25 11:44:19 +08:00
|
|
|
use flowy_database2::services::field::{CHECK, UNCHECK};
|
2023-04-28 14:08:53 +08:00
|
|
|
|
|
|
|
use crate::database::field_test::script::DatabaseFieldTest;
|
|
|
|
use crate::database::field_test::util::*;
|
2024-09-25 11:44:19 +08:00
|
|
|
use collab_database::fields::select_type_option::SingleSelectTypeOption;
|
2023-04-28 14:08:53 +08:00
|
|
|
|
|
|
|
#[tokio::test]
|
|
|
|
async fn grid_create_field() {
|
|
|
|
let mut test = DatabaseFieldTest::new().await;
|
|
|
|
|
2024-10-15 09:32:06 +08:00
|
|
|
// Create and assert text field
|
|
|
|
let (params, field) = create_text_field(&test.view_id());
|
|
|
|
test.create_field(params).await;
|
|
|
|
test
|
|
|
|
.assert_field_type_option_equal(
|
|
|
|
test.field_count() - 1,
|
|
|
|
field.get_any_type_option(field.field_type).unwrap(),
|
|
|
|
)
|
|
|
|
.await;
|
|
|
|
|
|
|
|
// Create and assert single select field
|
2023-04-28 14:08:53 +08:00
|
|
|
let (params, field) = create_single_select_field(&test.view_id());
|
2024-10-15 09:32:06 +08:00
|
|
|
test.create_field(params).await;
|
|
|
|
test
|
|
|
|
.assert_field_type_option_equal(
|
|
|
|
test.field_count() - 1,
|
|
|
|
field.get_any_type_option(field.field_type).unwrap(),
|
|
|
|
)
|
|
|
|
.await;
|
|
|
|
|
|
|
|
// Create and assert timestamp field
|
2023-09-08 10:07:24 +08:00
|
|
|
let (params, field) = create_timestamp_field(&test.view_id(), FieldType::CreatedTime);
|
2024-10-15 09:32:06 +08:00
|
|
|
test.create_field(params).await;
|
|
|
|
test
|
|
|
|
.assert_field_type_option_equal(
|
|
|
|
test.field_count() - 1,
|
|
|
|
field.get_any_type_option(field.field_type).unwrap(),
|
|
|
|
)
|
|
|
|
.await;
|
|
|
|
|
|
|
|
// Create and assert time field
|
2024-06-13 10:22:13 +03:30
|
|
|
let (params, field) = create_time_field(&test.view_id());
|
2024-10-15 09:32:06 +08:00
|
|
|
test.create_field(params).await;
|
|
|
|
test
|
|
|
|
.assert_field_type_option_equal(
|
|
|
|
test.field_count() - 1,
|
|
|
|
field.get_any_type_option(field.field_type).unwrap(),
|
|
|
|
)
|
|
|
|
.await;
|
2023-04-28 14:08:53 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
#[tokio::test]
|
|
|
|
async fn grid_create_duplicate_field() {
|
|
|
|
let mut test = DatabaseFieldTest::new().await;
|
|
|
|
let (params, _) = create_text_field(&test.view_id());
|
|
|
|
let field_count = test.field_count();
|
|
|
|
let expected_field_count = field_count + 1;
|
2024-10-15 09:32:06 +08:00
|
|
|
|
|
|
|
test.create_field(params.clone()).await;
|
|
|
|
test.assert_field_count(expected_field_count).await;
|
2023-04-28 14:08:53 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
#[tokio::test]
|
|
|
|
async fn grid_update_field_with_empty_change() {
|
|
|
|
let mut test = DatabaseFieldTest::new().await;
|
|
|
|
let (params, _) = create_single_select_field(&test.view_id());
|
|
|
|
let create_field_index = test.field_count();
|
2024-10-15 09:32:06 +08:00
|
|
|
|
|
|
|
test.create_field(params).await;
|
2023-04-28 14:08:53 +08:00
|
|
|
|
2024-08-18 05:16:42 +02:00
|
|
|
let field = test.get_fields().await.pop().unwrap().clone();
|
2024-09-30 22:14:15 +08:00
|
|
|
let changeset = FieldChangesetPB {
|
2023-04-28 14:08:53 +08:00
|
|
|
field_id: field.id.clone(),
|
|
|
|
view_id: test.view_id(),
|
|
|
|
..Default::default()
|
|
|
|
};
|
|
|
|
|
2024-10-15 09:32:06 +08:00
|
|
|
test.update_field(changeset).await;
|
|
|
|
test
|
|
|
|
.assert_field_type_option_equal(
|
|
|
|
create_field_index,
|
|
|
|
field.get_any_type_option(field.field_type).unwrap(),
|
|
|
|
)
|
|
|
|
.await;
|
2023-04-28 14:08:53 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
#[tokio::test]
|
|
|
|
async fn grid_delete_field() {
|
|
|
|
let mut test = DatabaseFieldTest::new().await;
|
|
|
|
let original_field_count = test.field_count();
|
|
|
|
let (params, _) = create_text_field(&test.view_id());
|
2024-10-15 09:32:06 +08:00
|
|
|
|
|
|
|
test.create_field(params).await;
|
2023-04-28 14:08:53 +08:00
|
|
|
|
2024-08-18 05:16:42 +02:00
|
|
|
let field = test.get_fields().await.pop().unwrap();
|
2024-10-15 09:32:06 +08:00
|
|
|
test.delete_field(field).await;
|
|
|
|
test.assert_field_count(original_field_count).await;
|
2023-04-28 14:08:53 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
#[tokio::test]
|
|
|
|
async fn grid_switch_from_select_option_to_checkbox_test() {
|
|
|
|
let mut test = DatabaseFieldTest::new().await;
|
2024-08-18 05:16:42 +02:00
|
|
|
let field = test.get_first_field(FieldType::SingleSelect).await;
|
2024-08-25 14:28:51 +08:00
|
|
|
let view_id = test.view_id();
|
2023-04-28 14:08:53 +08:00
|
|
|
|
|
|
|
// Update the type option data of single select option
|
2024-08-18 05:16:42 +02:00
|
|
|
let mut options = test.get_single_select_type_option(&field.id).await;
|
2024-03-16 17:18:30 +08:00
|
|
|
options.clear();
|
|
|
|
options.push(SelectOption {
|
2023-04-28 14:08:53 +08:00
|
|
|
id: gen_option_id(),
|
|
|
|
name: CHECK.to_string(),
|
|
|
|
color: Default::default(),
|
|
|
|
});
|
2024-03-16 17:18:30 +08:00
|
|
|
options.push(SelectOption {
|
2023-04-28 14:08:53 +08:00
|
|
|
id: gen_option_id(),
|
|
|
|
name: UNCHECK.to_string(),
|
|
|
|
color: Default::default(),
|
|
|
|
});
|
|
|
|
|
2024-10-15 09:32:06 +08:00
|
|
|
test
|
|
|
|
.update_type_option(
|
|
|
|
field.id.clone(),
|
|
|
|
SingleSelectTypeOption(SelectTypeOption {
|
2024-03-16 17:18:30 +08:00
|
|
|
options,
|
|
|
|
disable_color: false,
|
2024-09-25 11:44:19 +08:00
|
|
|
})
|
2024-03-16 17:18:30 +08:00
|
|
|
.into(),
|
2024-10-15 09:32:06 +08:00
|
|
|
)
|
|
|
|
.await;
|
|
|
|
|
|
|
|
// Switch to checkbox field
|
|
|
|
test
|
|
|
|
.switch_to_field(view_id, field.id.clone(), FieldType::Checkbox)
|
|
|
|
.await;
|
2023-04-28 14:08:53 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
#[tokio::test]
|
|
|
|
async fn grid_switch_from_checkbox_to_select_option_test() {
|
|
|
|
let mut test = DatabaseFieldTest::new().await;
|
2024-08-18 05:16:42 +02:00
|
|
|
let checkbox_field = test.get_first_field(FieldType::Checkbox).await.clone();
|
2023-04-28 14:08:53 +08:00
|
|
|
|
2024-10-15 09:32:06 +08:00
|
|
|
// Switch to single-select field
|
|
|
|
test
|
|
|
|
.switch_to_field(
|
|
|
|
test.view_id(),
|
|
|
|
checkbox_field.id.clone(),
|
|
|
|
FieldType::SingleSelect,
|
|
|
|
)
|
|
|
|
.await;
|
|
|
|
|
|
|
|
// Assert cell content after switching the field type
|
|
|
|
test
|
|
|
|
.assert_cell_content(
|
|
|
|
checkbox_field.id.clone(),
|
|
|
|
1, // row_index
|
|
|
|
CHECK.to_string(), // expected content
|
|
|
|
)
|
|
|
|
.await;
|
|
|
|
|
|
|
|
// Check that the options contain both "CHECK" and "UNCHECK"
|
2024-08-18 05:16:42 +02:00
|
|
|
let options = test.get_single_select_type_option(&checkbox_field.id).await;
|
2024-03-16 17:18:30 +08:00
|
|
|
assert_eq!(options.len(), 2);
|
|
|
|
assert!(options.iter().any(|option| option.name == UNCHECK));
|
|
|
|
assert!(options.iter().any(|option| option.name == CHECK));
|
2023-04-28 14:08:53 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
#[tokio::test]
|
|
|
|
async fn grid_switch_from_multi_select_to_text_test() {
|
|
|
|
let mut test = DatabaseFieldTest::new().await;
|
2024-08-18 05:16:42 +02:00
|
|
|
let field_rev = test.get_first_field(FieldType::MultiSelect).await.clone();
|
2023-04-28 14:08:53 +08:00
|
|
|
|
2024-08-18 05:16:42 +02:00
|
|
|
let multi_select_type_option = test.get_multi_select_type_option(&field_rev.id).await;
|
2023-04-28 14:08:53 +08:00
|
|
|
|
2024-10-15 09:32:06 +08:00
|
|
|
test
|
|
|
|
.switch_to_field(test.view_id(), field_rev.id.clone(), FieldType::RichText)
|
|
|
|
.await;
|
|
|
|
|
|
|
|
test
|
|
|
|
.assert_cell_content(
|
|
|
|
field_rev.id.clone(),
|
|
|
|
0, // row_index
|
|
|
|
format!(
|
|
|
|
"{},{}",
|
|
|
|
multi_select_type_option.first().unwrap().name,
|
|
|
|
multi_select_type_option.get(1).unwrap().name
|
|
|
|
),
|
|
|
|
)
|
|
|
|
.await;
|
2023-04-28 14:08:53 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
#[tokio::test]
|
|
|
|
async fn grid_switch_from_checkbox_to_text_test() {
|
|
|
|
let mut test = DatabaseFieldTest::new().await;
|
2024-08-18 05:16:42 +02:00
|
|
|
let field_rev = test.get_first_field(FieldType::Checkbox).await;
|
2023-04-28 14:08:53 +08:00
|
|
|
|
2024-10-15 09:32:06 +08:00
|
|
|
test
|
|
|
|
.switch_to_field(test.view_id(), field_rev.id.clone(), FieldType::RichText)
|
|
|
|
.await;
|
|
|
|
|
|
|
|
test
|
|
|
|
.assert_cell_content(field_rev.id.clone(), 1, "Yes".to_string())
|
|
|
|
.await;
|
|
|
|
test
|
|
|
|
.assert_cell_content(field_rev.id.clone(), 2, "No".to_string())
|
|
|
|
.await;
|
2023-04-28 14:08:53 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
#[tokio::test]
|
|
|
|
async fn grid_switch_from_date_to_text_test() {
|
|
|
|
let mut test = DatabaseFieldTest::new().await;
|
2024-08-18 05:16:42 +02:00
|
|
|
let field = test.get_first_field(FieldType::DateTime).await.clone();
|
2024-10-15 09:32:06 +08:00
|
|
|
|
|
|
|
test
|
|
|
|
.switch_to_field(test.view_id(), field.id.clone(), FieldType::RichText)
|
|
|
|
.await;
|
|
|
|
|
|
|
|
test
|
|
|
|
.assert_cell_content(field.id.clone(), 2, "2022/03/14".to_string())
|
|
|
|
.await;
|
|
|
|
test
|
|
|
|
.assert_cell_content(field.id.clone(), 3, "2022/11/17".to_string())
|
|
|
|
.await;
|
2023-04-28 14:08:53 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
#[tokio::test]
|
|
|
|
async fn grid_switch_from_number_to_text_test() {
|
|
|
|
let mut test = DatabaseFieldTest::new().await;
|
2024-08-18 05:16:42 +02:00
|
|
|
let field = test.get_first_field(FieldType::Number).await.clone();
|
2023-04-28 14:08:53 +08:00
|
|
|
|
2024-10-15 09:32:06 +08:00
|
|
|
test
|
|
|
|
.switch_to_field(test.view_id(), field.id.clone(), FieldType::RichText)
|
|
|
|
.await;
|
|
|
|
|
|
|
|
test
|
|
|
|
.assert_cell_content(field.id.clone(), 0, "$1".to_string())
|
|
|
|
.await;
|
|
|
|
test
|
|
|
|
.assert_cell_content(field.id.clone(), 4, "".to_string())
|
|
|
|
.await;
|
2023-04-28 14:08:53 +08:00
|
|
|
}
|
2024-02-28 22:04:32 +08:00
|
|
|
|
|
|
|
#[tokio::test]
|
|
|
|
async fn grid_switch_from_checklist_to_text_test() {
|
|
|
|
let mut test = DatabaseFieldTest::new().await;
|
2024-08-18 05:16:42 +02:00
|
|
|
let field_rev = test.get_first_field(FieldType::Checklist).await;
|
2024-02-28 22:04:32 +08:00
|
|
|
|
2024-10-15 09:32:06 +08:00
|
|
|
test
|
|
|
|
.switch_to_field(test.view_id(), field_rev.id.clone(), FieldType::RichText)
|
|
|
|
.await;
|
|
|
|
|
|
|
|
test
|
|
|
|
.assert_cell_content(field_rev.id.clone(), 0, "First thing".to_string())
|
|
|
|
.await;
|
2024-02-28 22:04:32 +08:00
|
|
|
}
|