invert_test.rs 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. pub mod helper;
  2. use crate::helper::{TestOp::*, *};
  3. use flowy_ot::core::{Delta, Interval, OpBuilder};
  4. #[test]
  5. fn delta_invert_delta_test() {
  6. let mut delta = Delta::default();
  7. delta.add(OpBuilder::insert("123").build());
  8. let mut change = Delta::default();
  9. change.add(OpBuilder::retain(3).build());
  10. change.add(OpBuilder::insert("456").build());
  11. let undo = change.invert_delta(&delta);
  12. let new_delta = delta.compose(&change).unwrap();
  13. let delta_after_undo = new_delta.compose(&undo).unwrap();
  14. assert_eq!(delta_after_undo, delta);
  15. }
  16. #[test]
  17. fn delta_invert_delta_test2() {
  18. let ops = vec![
  19. Insert(0, "123", 0),
  20. Insert(1, "4567", 0),
  21. Invert(0, 1),
  22. AssertOpsJson(0, r#"[{"insert":"123"}]"#),
  23. ];
  24. OpTester::new().run_script(ops);
  25. }
  26. #[test]
  27. fn delta_invert_delta_with_attribute() {
  28. let ops = vec![
  29. Insert(0, "123", 0),
  30. Bold(0, Interval::new(0, 3), true),
  31. AssertOpsJson(0, r#"[{"insert":"123","attributes":{"bold":"true"}}]"#),
  32. Insert(1, "4567", 0),
  33. Invert(0, 1),
  34. AssertOpsJson(0, r#"[{"insert":"123","attributes":{"bold":"true"}}]"#),
  35. ];
  36. OpTester::new().run_script(ops);
  37. }
  38. #[test]
  39. fn delta_invert_delta() {
  40. let ops = vec![
  41. Insert(0, "123", 0),
  42. Bold(0, Interval::new(0, 3), true),
  43. Insert(0, "456", 3),
  44. AssertOpsJson(0, r#"[{"insert":"123456","attributes":{"bold":"true"}}]"#),
  45. Italic(0, Interval::new(2, 4), true),
  46. AssertOpsJson(
  47. 0,
  48. r#"[{"insert":"12","attributes":{"bold":"true"}},{"insert":"34","attributes":{"bold":"true","italic":"true"}},{"insert":"56","attributes":{"bold":"true"}}]"#,
  49. ),
  50. /* Insert(1, "4567", 0),
  51. *
  52. * Invert(0, 1),
  53. * AssertOpsJson(0, r#"[{"insert":"123","attributes":{"bold":"true"}}]"#), */
  54. ];
  55. OpTester::new().run_script(ops);
  56. }
  57. #[test]
  58. fn delta_get_ops_in_interval_1() {
  59. let mut delta = Delta::default();
  60. let insert_a = OpBuilder::insert("123").build();
  61. let insert_b = OpBuilder::insert("4").build();
  62. delta.add(insert_a.clone());
  63. delta.add(insert_b.clone());
  64. assert_eq!(
  65. delta.ops_in_interval(Interval::new(0, 3)),
  66. vec![delta.ops.last().unwrap().clone()]
  67. );
  68. }
  69. #[test]
  70. fn delta_get_ops_in_interval_2() {
  71. let mut delta = Delta::default();
  72. let insert_a = OpBuilder::insert("123").build();
  73. let insert_b = OpBuilder::insert("4").build();
  74. let insert_c = OpBuilder::insert("5").build();
  75. let retain_a = OpBuilder::retain(3).build();
  76. delta.add(insert_a.clone());
  77. delta.add(retain_a.clone());
  78. delta.add(insert_b.clone());
  79. delta.add(insert_c.clone());
  80. assert_eq!(
  81. delta.ops_in_interval(Interval::new(0, 3)),
  82. vec![insert_a.clone()]
  83. );
  84. assert_eq!(
  85. delta.ops_in_interval(Interval::new(0, 4)),
  86. vec![insert_a.clone(), retain_a.clone()]
  87. );
  88. assert_eq!(
  89. delta.ops_in_interval(Interval::new(0, 7)),
  90. vec![
  91. insert_a.clone(),
  92. retain_a.clone(),
  93. // insert_b and insert_c will be merged into one. insert: "45"
  94. delta.ops.last().unwrap().clone()
  95. ]
  96. );
  97. }