AppFlowy/shared-lib/lib-ot/tests/node/tree_test.rs

319 lines
8.3 KiB
Rust
Raw Normal View History

2022-09-09 07:05:41 +00:00
use crate::node::script::NodeScript::*;
use crate::node::script::NodeTest;
2022-09-11 04:59:01 +00:00
use lib_ot::core::NodeBody;
use lib_ot::core::NodeBodyChangeset;
use lib_ot::core::OperationTransform;
use lib_ot::core::{NodeData, NodeDataBuilder, Path};
2022-09-12 02:44:33 +00:00
use lib_ot::text_delta::TextDeltaBuilder;
2022-09-09 07:05:41 +00:00
#[test]
fn node_insert_test() {
let mut test = NodeTest::new();
2022-09-11 00:59:12 +00:00
let inserted_node = NodeData::new("text");
2022-09-09 07:05:41 +00:00
let path: Path = 0.into();
let scripts = vec![
InsertNode {
path: path.clone(),
2022-09-13 12:23:56 +00:00
node_data: inserted_node.clone(),
rev_id: 1,
2022-09-09 07:05:41 +00:00
},
2022-09-13 12:23:56 +00:00
AssertNodeData {
2022-09-09 07:05:41 +00:00
path,
expected: Some(inserted_node),
},
];
test.run_scripts(scripts);
}
#[test]
fn node_insert_node_with_children_test() {
let mut test = NodeTest::new();
let inserted_node = NodeDataBuilder::new("text").add_node(NodeData::new("image")).build();
2022-09-09 07:05:41 +00:00
let path: Path = 0.into();
let scripts = vec![
InsertNode {
path: path.clone(),
2022-09-13 12:23:56 +00:00
node_data: inserted_node.clone(),
rev_id: 1,
2022-09-09 07:05:41 +00:00
},
2022-09-13 12:23:56 +00:00
AssertNodeData {
2022-09-09 07:05:41 +00:00
path,
expected: Some(inserted_node),
},
];
test.run_scripts(scripts);
}
#[test]
fn node_insert_multi_nodes_test() {
let mut test = NodeTest::new();
let path_1: Path = 0.into();
2022-09-11 00:59:12 +00:00
let node_1 = NodeData::new("text_1");
2022-09-09 07:05:41 +00:00
let path_2: Path = 1.into();
2022-09-11 00:59:12 +00:00
let node_2 = NodeData::new("text_2");
2022-09-09 07:05:41 +00:00
let path_3: Path = 2.into();
2022-09-11 00:59:12 +00:00
let node_3 = NodeData::new("text_3");
2022-09-09 07:05:41 +00:00
let scripts = vec![
InsertNode {
path: path_1.clone(),
2022-09-13 12:23:56 +00:00
node_data: node_1.clone(),
rev_id: 1,
2022-09-09 07:05:41 +00:00
},
InsertNode {
path: path_2.clone(),
2022-09-13 12:23:56 +00:00
node_data: node_2.clone(),
rev_id: 2,
2022-09-09 07:05:41 +00:00
},
InsertNode {
path: path_3.clone(),
2022-09-13 12:23:56 +00:00
node_data: node_3.clone(),
rev_id: 3,
2022-09-09 07:05:41 +00:00
},
2022-09-13 12:23:56 +00:00
AssertNodeData {
2022-09-09 07:05:41 +00:00
path: path_1,
expected: Some(node_1),
},
2022-09-13 12:23:56 +00:00
AssertNodeData {
2022-09-09 07:05:41 +00:00
path: path_2,
expected: Some(node_2),
},
2022-09-13 12:23:56 +00:00
AssertNodeData {
2022-09-09 07:05:41 +00:00
path: path_3,
expected: Some(node_3),
},
];
test.run_scripts(scripts);
}
#[test]
fn node_insert_node_in_ordered_nodes_test() {
let mut test = NodeTest::new();
let path_1: Path = 0.into();
2022-09-11 00:59:12 +00:00
let node_1 = NodeData::new("text_1");
2022-09-09 07:05:41 +00:00
let path_2: Path = 1.into();
2022-09-11 00:59:12 +00:00
let node_2_1 = NodeData::new("text_2_1");
let node_2_2 = NodeData::new("text_2_2");
2022-09-09 07:05:41 +00:00
let path_3: Path = 2.into();
2022-09-11 00:59:12 +00:00
let node_3 = NodeData::new("text_3");
2022-09-09 07:05:41 +00:00
let scripts = vec![
InsertNode {
path: path_1.clone(),
2022-09-13 12:23:56 +00:00
node_data: node_1.clone(),
rev_id: 1,
2022-09-09 07:05:41 +00:00
},
InsertNode {
path: path_2.clone(),
2022-09-13 12:23:56 +00:00
node_data: node_2_1.clone(),
rev_id: 2,
2022-09-09 07:05:41 +00:00
},
InsertNode {
path: path_3.clone(),
2022-09-13 12:23:56 +00:00
node_data: node_3.clone(),
rev_id: 3,
2022-09-09 07:05:41 +00:00
},
2022-09-14 04:03:52 +00:00
// 0:text_1
// 1:text_2_1
// 2:text_3
2022-09-09 07:05:41 +00:00
InsertNode {
path: path_2.clone(),
2022-09-13 12:23:56 +00:00
node_data: node_2_2.clone(),
rev_id: 4,
2022-09-09 07:05:41 +00:00
},
2022-09-14 04:03:52 +00:00
// 0:text_1
// 1:text_2_2
// 2:text_2_1
// 3:text_3
2022-09-13 12:23:56 +00:00
AssertNodeData {
2022-09-09 07:05:41 +00:00
path: path_1,
expected: Some(node_1),
},
2022-09-13 12:23:56 +00:00
AssertNodeData {
2022-09-09 07:05:41 +00:00
path: path_2,
expected: Some(node_2_2),
},
2022-09-13 12:23:56 +00:00
AssertNodeData {
2022-09-09 07:05:41 +00:00
path: path_3,
expected: Some(node_2_1),
},
AssertNumberOfNodesAtPath { path: None, len: 4 },
2022-09-09 07:05:41 +00:00
];
test.run_scripts(scripts);
}
2022-09-14 04:03:52 +00:00
#[test]
fn node_insert_nested_nodes_test() {
let mut test = NodeTest::new();
let node_data_1_1 = NodeDataBuilder::new("text_1_1").build();
let node_data_1_2 = NodeDataBuilder::new("text_1_2").build();
let node_data_1 = NodeDataBuilder::new("text_1")
.add_node(node_data_1_1.clone())
.add_node(node_data_1_2.clone())
.build();
let node_data_2_1 = NodeDataBuilder::new("text_2_1").build();
let node_data_2_2 = NodeDataBuilder::new("text_2_2").build();
let node_data_2 = NodeDataBuilder::new("text_2")
.add_node(node_data_2_1.clone())
.add_node(node_data_2_2.clone())
.build();
let scripts = vec![
InsertNode {
path: 0.into(),
node_data: node_data_1.clone(),
rev_id: 1,
},
InsertNode {
path: 1.into(),
node_data: node_data_2.clone(),
rev_id: 2,
},
// the tree will be:
// 0:text_1
// 0:text_1_1
// 1:text_1_2
// 1:text_2
// 0:text_2_1
// 1:text_2_2
AssertNode {
path: vec![0, 0].into(),
expected: Some(node_data_1_1.into()),
},
AssertNode {
path: vec![0, 1].into(),
expected: Some(node_data_1_2.into()),
},
AssertNode {
path: vec![1, 0].into(),
expected: Some(node_data_2_1.into()),
},
AssertNode {
path: vec![1, 1].into(),
expected: Some(node_data_2_2.into()),
},
];
test.run_scripts(scripts);
}
#[test]
fn node_insert_node_before_existing_nested_nodes_test() {
let mut test = NodeTest::new();
let node_data_1_1 = NodeDataBuilder::new("text_1_1").build();
let node_data_1_2 = NodeDataBuilder::new("text_1_2").build();
let node_data_1 = NodeDataBuilder::new("text_1")
.add_node(node_data_1_1.clone())
.add_node(node_data_1_2.clone())
.build();
let scripts = vec![
InsertNode {
path: 0.into(),
node_data: node_data_1.clone(),
rev_id: 1,
},
// 0:text_1
// 0:text_1_1
// 1:text_1_2
InsertNode {
path: 0.into(),
node_data: NodeDataBuilder::new("text_0").build(),
rev_id: 2,
},
// 0:text_0
// 1:text_1
// 0:text_1_1
// 1:text_1_2
AssertNode {
path: vec![1, 0].into(),
expected: Some(node_data_1_1.into()),
},
AssertNode {
path: vec![1, 1].into(),
expected: Some(node_data_1_2.into()),
},
];
test.run_scripts(scripts);
}
2022-09-09 07:05:41 +00:00
#[test]
fn node_insert_with_attributes_test() {
let mut test = NodeTest::new();
let path: Path = 0.into();
2022-09-11 00:59:12 +00:00
let mut inserted_node = NodeData::new("text");
2022-09-10 00:42:53 +00:00
inserted_node.attributes.insert("bold", true);
inserted_node.attributes.insert("underline", true);
2022-09-09 07:05:41 +00:00
let scripts = vec![
InsertNode {
path: path.clone(),
2022-09-13 12:23:56 +00:00
node_data: inserted_node.clone(),
rev_id: 1,
2022-09-09 07:05:41 +00:00
},
2022-09-11 04:59:01 +00:00
UpdateAttributes {
2022-09-09 07:05:41 +00:00
path: path.clone(),
attributes: inserted_node.attributes.clone(),
},
2022-09-13 12:23:56 +00:00
AssertNodeData {
2022-09-09 07:05:41 +00:00
path,
expected: Some(inserted_node),
},
];
test.run_scripts(scripts);
}
#[test]
fn node_delete_test() {
let mut test = NodeTest::new();
2022-09-11 00:59:12 +00:00
let inserted_node = NodeData::new("text");
2022-09-09 07:05:41 +00:00
let path: Path = 0.into();
let scripts = vec![
InsertNode {
path: path.clone(),
2022-09-13 12:23:56 +00:00
node_data: inserted_node,
rev_id: 1,
2022-09-09 07:05:41 +00:00
},
2022-09-14 01:23:33 +00:00
DeleteNode {
path: path.clone(),
rev_id: 2,
},
2022-09-13 12:23:56 +00:00
AssertNodeData { path, expected: None },
2022-09-09 07:05:41 +00:00
];
test.run_scripts(scripts);
}
2022-09-11 04:59:01 +00:00
#[test]
fn node_update_body_test() {
let mut test = NodeTest::new();
let path: Path = 0.into();
let s = "Hello".to_owned();
2022-09-12 02:44:33 +00:00
let init_delta = TextDeltaBuilder::new().insert(&s).build();
let delta = TextDeltaBuilder::new().retain(s.len()).insert(" AppFlowy").build();
2022-09-11 04:59:01 +00:00
let inverted = delta.invert(&init_delta);
let expected = init_delta.compose(&delta).unwrap();
let node = NodeDataBuilder::new("text")
2022-09-11 04:59:01 +00:00
.insert_body(NodeBody::Delta(init_delta))
.build();
let scripts = vec![
InsertNode {
path: path.clone(),
2022-09-13 12:23:56 +00:00
node_data: node,
rev_id: 1,
2022-09-11 04:59:01 +00:00
},
UpdateBody {
path: path.clone(),
changeset: NodeBodyChangeset::Delta { delta, inverted },
},
AssertNodeDelta { path, expected },
];
test.run_scripts(scripts);
}