op_test.rs 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610
  1. pub mod helper;
  2. use crate::helper::TestOp::*;
  3. use bytecount::num_chars;
  4. use flowy_ot::core::*;
  5. use helper::*;
  6. #[test]
  7. fn delta_get_ops_in_interval_1() {
  8. let mut delta = Delta::default();
  9. let insert_a = OpBuilder::insert("123").build();
  10. let insert_b = OpBuilder::insert("4").build();
  11. delta.add(insert_a.clone());
  12. delta.add(insert_b.clone());
  13. let mut iterator = DeltaIter::from_interval(&delta, Interval::new(0, 4));
  14. assert_eq!(iterator.ops(), delta.ops);
  15. }
  16. #[test]
  17. fn delta_get_ops_in_interval_2() {
  18. let mut delta = Delta::default();
  19. let insert_a = OpBuilder::insert("123").build();
  20. let insert_b = OpBuilder::insert("4").build();
  21. let insert_c = OpBuilder::insert("5").build();
  22. let retain_a = OpBuilder::retain(3).build();
  23. delta.add(insert_a.clone());
  24. delta.add(retain_a.clone());
  25. delta.add(insert_b.clone());
  26. delta.add(insert_c.clone());
  27. assert_eq!(
  28. DeltaIter::from_interval(&delta, Interval::new(0, 2)).ops(),
  29. vec![OpBuilder::insert("12").build()]
  30. );
  31. assert_eq!(
  32. DeltaIter::from_interval(&delta, Interval::new(1, 3)).ops(),
  33. vec![OpBuilder::insert("23").build()]
  34. );
  35. assert_eq!(
  36. DeltaIter::from_interval(&delta, Interval::new(0, 3)).ops(),
  37. vec![insert_a.clone()]
  38. );
  39. assert_eq!(
  40. DeltaIter::from_interval(&delta, Interval::new(0, 4)).ops(),
  41. vec![insert_a.clone(), OpBuilder::retain(1).build()]
  42. );
  43. assert_eq!(
  44. DeltaIter::from_interval(&delta, Interval::new(0, 6)).ops(),
  45. vec![insert_a.clone(), retain_a.clone()]
  46. );
  47. assert_eq!(
  48. DeltaIter::from_interval(&delta, Interval::new(0, 7)).ops(),
  49. vec![insert_a.clone(), retain_a.clone(), insert_b.clone()]
  50. );
  51. }
  52. #[test]
  53. fn delta_get_ops_in_interval_3() {
  54. let mut delta = Delta::default();
  55. let insert_a = OpBuilder::insert("123456").build();
  56. delta.add(insert_a.clone());
  57. assert_eq!(
  58. DeltaIter::from_interval(&delta, Interval::new(3, 5)).ops(),
  59. vec![OpBuilder::insert("45").build()]
  60. );
  61. }
  62. #[test]
  63. fn delta_get_ops_in_interval_4() {
  64. let mut delta = Delta::default();
  65. let insert_a = OpBuilder::insert("12").build();
  66. let insert_b = OpBuilder::insert("34").build();
  67. let insert_c = OpBuilder::insert("56").build();
  68. delta.ops.push(insert_a.clone());
  69. delta.ops.push(insert_b.clone());
  70. delta.ops.push(insert_c.clone());
  71. assert_eq!(
  72. DeltaIter::from_interval(&delta, Interval::new(0, 2)).ops(),
  73. vec![insert_a]
  74. );
  75. assert_eq!(
  76. DeltaIter::from_interval(&delta, Interval::new(2, 4)).ops(),
  77. vec![insert_b]
  78. );
  79. assert_eq!(
  80. DeltaIter::from_interval(&delta, Interval::new(4, 6)).ops(),
  81. vec![insert_c]
  82. );
  83. assert_eq!(
  84. DeltaIter::from_interval(&delta, Interval::new(2, 5)).ops(),
  85. vec![
  86. OpBuilder::insert("34").build(),
  87. OpBuilder::insert("5").build()
  88. ]
  89. );
  90. }
  91. #[test]
  92. fn delta_get_ops_in_interval_5() {
  93. let mut delta = Delta::default();
  94. let insert_a = OpBuilder::insert("123456").build();
  95. let insert_b = OpBuilder::insert("789").build();
  96. delta.ops.push(insert_a.clone());
  97. delta.ops.push(insert_b.clone());
  98. assert_eq!(
  99. DeltaIter::from_interval(&delta, Interval::new(4, 8)).ops(),
  100. vec![
  101. OpBuilder::insert("56").build(),
  102. OpBuilder::insert("78").build()
  103. ]
  104. );
  105. // assert_eq!(
  106. // DeltaIter::from_interval(&delta, Interval::new(8, 9)).ops(),
  107. // vec![Builder::insert("9").build()]
  108. // );
  109. }
  110. #[test]
  111. fn delta_get_ops_in_interval_6() {
  112. let mut delta = Delta::default();
  113. let insert_a = OpBuilder::insert("12345678").build();
  114. delta.add(insert_a.clone());
  115. assert_eq!(
  116. DeltaIter::from_interval(&delta, Interval::new(4, 6)).ops(),
  117. vec![OpBuilder::insert("56").build()]
  118. );
  119. }
  120. #[test]
  121. fn delta_get_ops_in_interval_7() {
  122. let mut delta = Delta::default();
  123. let insert_a = OpBuilder::insert("12345").build();
  124. let retain_a = OpBuilder::retain(3).build();
  125. delta.add(insert_a.clone());
  126. delta.add(retain_a.clone());
  127. let mut iter_1 = DeltaIter::new(&delta);
  128. iter_1.seek::<CharMetric>(2).unwrap();
  129. assert_eq!(iter_1.next_op().unwrap(), OpBuilder::insert("345").build());
  130. assert_eq!(iter_1.next_op().unwrap(), OpBuilder::retain(3).build());
  131. let mut iter_2 = DeltaIter::new(&delta);
  132. assert_eq!(
  133. iter_2.next_op_with_len(2).unwrap(),
  134. OpBuilder::insert("12").build()
  135. );
  136. assert_eq!(iter_2.next_op().unwrap(), OpBuilder::insert("345").build());
  137. assert_eq!(iter_2.next_op().unwrap(), OpBuilder::retain(3).build());
  138. }
  139. #[test]
  140. fn delta_seek_1() {
  141. let mut delta = Delta::default();
  142. let insert_a = OpBuilder::insert("12345").build();
  143. let retain_a = OpBuilder::retain(3).build();
  144. delta.add(insert_a.clone());
  145. delta.add(retain_a.clone());
  146. let mut iter = DeltaIter::new(&delta);
  147. iter.seek::<OpMetric>(1).unwrap();
  148. assert_eq!(iter.next_op().unwrap(), OpBuilder::retain(3).build());
  149. }
  150. #[test]
  151. fn delta_seek_2() {
  152. let mut delta = Delta::default();
  153. delta.add(OpBuilder::insert("12345").build());
  154. let mut iter = DeltaIter::new(&delta);
  155. assert_eq!(
  156. iter.next_op_with_len(1).unwrap(),
  157. OpBuilder::insert("1").build()
  158. );
  159. }
  160. #[test]
  161. fn delta_seek_3() {
  162. let mut delta = Delta::default();
  163. delta.add(OpBuilder::insert("12345").build());
  164. let mut iter = DeltaIter::new(&delta);
  165. assert_eq!(
  166. iter.next_op_with_len(2).unwrap(),
  167. OpBuilder::insert("12").build()
  168. );
  169. assert_eq!(
  170. iter.next_op_with_len(2).unwrap(),
  171. OpBuilder::insert("34").build()
  172. );
  173. assert_eq!(
  174. iter.next_op_with_len(2).unwrap(),
  175. OpBuilder::insert("5").build()
  176. );
  177. assert_eq!(iter.next_op_with_len(1), None);
  178. }
  179. #[test]
  180. fn delta_seek_4() {
  181. let mut delta = Delta::default();
  182. delta.add(OpBuilder::insert("12345").build());
  183. let mut iter = DeltaIter::new(&delta);
  184. iter.seek::<CharMetric>(3);
  185. assert_eq!(
  186. iter.next_op_with_len(2).unwrap(),
  187. OpBuilder::insert("45").build()
  188. );
  189. }
  190. #[test]
  191. fn delta_next_op_len_test() {
  192. let mut delta = Delta::default();
  193. delta.add(OpBuilder::insert("12345").build());
  194. let mut iter = DeltaIter::new(&delta);
  195. iter.seek::<CharMetric>(3);
  196. assert_eq!(iter.next_op_len(), 2);
  197. assert_eq!(
  198. iter.next_op_with_len(1).unwrap(),
  199. OpBuilder::insert("4").build()
  200. );
  201. assert_eq!(iter.next_op_len(), 1);
  202. assert_eq!(iter.next_op().unwrap(), OpBuilder::insert("5").build());
  203. }
  204. #[test]
  205. fn lengths() {
  206. let mut delta = Delta::default();
  207. assert_eq!(delta.base_len, 0);
  208. assert_eq!(delta.target_len, 0);
  209. delta.retain(5, Attributes::default());
  210. assert_eq!(delta.base_len, 5);
  211. assert_eq!(delta.target_len, 5);
  212. delta.insert("abc", Attributes::default());
  213. assert_eq!(delta.base_len, 5);
  214. assert_eq!(delta.target_len, 8);
  215. delta.retain(2, Attributes::default());
  216. assert_eq!(delta.base_len, 7);
  217. assert_eq!(delta.target_len, 10);
  218. delta.delete(2);
  219. assert_eq!(delta.base_len, 9);
  220. assert_eq!(delta.target_len, 10);
  221. }
  222. #[test]
  223. fn sequence() {
  224. let mut delta = Delta::default();
  225. delta.retain(5, Attributes::default());
  226. delta.retain(0, Attributes::default());
  227. delta.insert("appflowy", Attributes::default());
  228. delta.insert("", Attributes::default());
  229. delta.delete(3);
  230. delta.delete(0);
  231. assert_eq!(delta.ops.len(), 3);
  232. }
  233. #[test]
  234. fn apply_1000() {
  235. for _ in 0..1000 {
  236. let mut rng = Rng::default();
  237. let s = rng.gen_string(50);
  238. let delta = rng.gen_delta(&s);
  239. assert_eq!(num_chars(s.as_bytes()), delta.base_len);
  240. assert_eq!(delta.apply(&s).unwrap().chars().count(), delta.target_len);
  241. }
  242. }
  243. #[test]
  244. fn apply() {
  245. let s = "hello world,".to_owned();
  246. let mut delta_a = Delta::default();
  247. delta_a.insert(&s, Attributes::default());
  248. let mut delta_b = Delta::default();
  249. delta_b.retain(s.len(), Attributes::default());
  250. delta_b.insert("appflowy", Attributes::default());
  251. let after_a = delta_a.apply("").unwrap();
  252. let after_b = delta_b.apply(&after_a).unwrap();
  253. assert_eq!("hello world,appflowy", &after_b);
  254. }
  255. #[test]
  256. fn base_len_test() {
  257. let mut delta_a = Delta::default();
  258. delta_a.insert("a", Attributes::default());
  259. delta_a.insert("b", Attributes::default());
  260. delta_a.insert("c", Attributes::default());
  261. let s = "hello world,".to_owned();
  262. delta_a.delete(s.len());
  263. let after_a = delta_a.apply(&s).unwrap();
  264. delta_a.insert("d", Attributes::default());
  265. assert_eq!("abc", &after_a);
  266. }
  267. #[test]
  268. fn invert() {
  269. for _ in 0..1000 {
  270. let mut rng = Rng::default();
  271. let s = rng.gen_string(50);
  272. let delta_a = rng.gen_delta(&s);
  273. let delta_b = delta_a.invert_str(&s);
  274. assert_eq!(delta_a.base_len, delta_b.target_len);
  275. assert_eq!(delta_a.target_len, delta_b.base_len);
  276. assert_eq!(delta_b.apply(&delta_a.apply(&s).unwrap()).unwrap(), s);
  277. }
  278. }
  279. #[test]
  280. fn empty_ops() {
  281. let mut delta = Delta::default();
  282. delta.retain(0, Attributes::default());
  283. delta.insert("", Attributes::default());
  284. delta.delete(0);
  285. assert_eq!(delta.ops.len(), 0);
  286. }
  287. #[test]
  288. fn eq() {
  289. let mut delta_a = Delta::default();
  290. delta_a.delete(1);
  291. delta_a.insert("lo", Attributes::default());
  292. delta_a.retain(2, Attributes::default());
  293. delta_a.retain(3, Attributes::default());
  294. let mut delta_b = Delta::default();
  295. delta_b.delete(1);
  296. delta_b.insert("l", Attributes::default());
  297. delta_b.insert("o", Attributes::default());
  298. delta_b.retain(5, Attributes::default());
  299. assert_eq!(delta_a, delta_b);
  300. delta_a.delete(1);
  301. delta_b.retain(1, Attributes::default());
  302. assert_ne!(delta_a, delta_b);
  303. }
  304. #[test]
  305. fn ops_merging() {
  306. let mut delta = Delta::default();
  307. assert_eq!(delta.ops.len(), 0);
  308. delta.retain(2, Attributes::default());
  309. assert_eq!(delta.ops.len(), 1);
  310. assert_eq!(delta.ops.last(), Some(&OpBuilder::retain(2).build()));
  311. delta.retain(3, Attributes::default());
  312. assert_eq!(delta.ops.len(), 1);
  313. assert_eq!(delta.ops.last(), Some(&OpBuilder::retain(5).build()));
  314. delta.insert("abc", Attributes::default());
  315. assert_eq!(delta.ops.len(), 2);
  316. assert_eq!(delta.ops.last(), Some(&OpBuilder::insert("abc").build()));
  317. delta.insert("xyz", Attributes::default());
  318. assert_eq!(delta.ops.len(), 2);
  319. assert_eq!(delta.ops.last(), Some(&OpBuilder::insert("abcxyz").build()));
  320. delta.delete(1);
  321. assert_eq!(delta.ops.len(), 3);
  322. assert_eq!(delta.ops.last(), Some(&OpBuilder::delete(1).build()));
  323. delta.delete(1);
  324. assert_eq!(delta.ops.len(), 3);
  325. assert_eq!(delta.ops.last(), Some(&OpBuilder::delete(2).build()));
  326. }
  327. #[test]
  328. fn is_noop() {
  329. let mut delta = Delta::default();
  330. assert!(delta.is_noop());
  331. delta.retain(5, Attributes::default());
  332. assert!(delta.is_noop());
  333. delta.retain(3, Attributes::default());
  334. assert!(delta.is_noop());
  335. delta.insert("lorem", Attributes::default());
  336. assert!(!delta.is_noop());
  337. }
  338. #[test]
  339. fn compose() {
  340. for _ in 0..1000 {
  341. let mut rng = Rng::default();
  342. let s = rng.gen_string(20);
  343. let a = rng.gen_delta(&s);
  344. let after_a = a.apply(&s).unwrap();
  345. assert_eq!(a.target_len, num_chars(after_a.as_bytes()));
  346. let b = rng.gen_delta(&after_a);
  347. let after_b = b.apply(&after_a).unwrap();
  348. assert_eq!(b.target_len, num_chars(after_b.as_bytes()));
  349. let ab = a.compose(&b).unwrap();
  350. assert_eq!(ab.target_len, b.target_len);
  351. let after_ab = ab.apply(&s).unwrap();
  352. assert_eq!(after_b, after_ab);
  353. }
  354. }
  355. #[test]
  356. fn transform() {
  357. for _ in 0..1000 {
  358. let mut rng = Rng::default();
  359. let s = rng.gen_string(20);
  360. let a = rng.gen_delta(&s);
  361. let b = rng.gen_delta(&s);
  362. let (a_prime, b_prime) = a.transform(&b).unwrap();
  363. let ab_prime = a.compose(&b_prime).unwrap();
  364. let ba_prime = b.compose(&a_prime).unwrap();
  365. assert_eq!(ab_prime, ba_prime);
  366. let after_ab_prime = ab_prime.apply(&s).unwrap();
  367. let after_ba_prime = ba_prime.apply(&s).unwrap();
  368. assert_eq!(after_ab_prime, after_ba_prime);
  369. }
  370. }
  371. #[test]
  372. fn transform2() {
  373. let ops = vec![
  374. Insert(0, "123", 0),
  375. Insert(1, "456", 0),
  376. Transform(0, 1),
  377. AssertOpsJson(0, r#"[{"insert":"123456"}]"#),
  378. AssertOpsJson(1, r#"[{"insert":"123456"}]"#),
  379. ];
  380. OpTester::new().run_script(ops);
  381. }
  382. #[test]
  383. fn delta_transform_test() {
  384. let mut a = Delta::default();
  385. let mut a_s = String::new();
  386. a.insert("123", AttrsBuilder::new().bold(true).build());
  387. a_s = a.apply(&a_s).unwrap();
  388. assert_eq!(&a_s, "123");
  389. let mut b = Delta::default();
  390. let mut b_s = String::new();
  391. b.insert("456", Attributes::default());
  392. b_s = b.apply(&b_s).unwrap();
  393. assert_eq!(&b_s, "456");
  394. let (a_prime, b_prime) = a.transform(&b).unwrap();
  395. assert_eq!(
  396. r#"[{"insert":"123","attributes":{"bold":"true"}},{"retain":3}]"#,
  397. serde_json::to_string(&a_prime).unwrap()
  398. );
  399. assert_eq!(
  400. r#"[{"retain":3,"attributes":{"bold":"true"}},{"insert":"456"}]"#,
  401. serde_json::to_string(&b_prime).unwrap()
  402. );
  403. }
  404. #[test]
  405. fn delta_invert_no_attribute_delta() {
  406. let mut delta = Delta::default();
  407. delta.add(OpBuilder::insert("123").build());
  408. let mut change = Delta::default();
  409. change.add(OpBuilder::retain(3).build());
  410. change.add(OpBuilder::insert("456").build());
  411. let undo = change.invert(&delta);
  412. let new_delta = delta.compose(&change).unwrap();
  413. let delta_after_undo = new_delta.compose(&undo).unwrap();
  414. assert_eq!(delta_after_undo, delta);
  415. }
  416. #[test]
  417. fn delta_invert_no_attribute_delta2() {
  418. let ops = vec![
  419. Insert(0, "123", 0),
  420. Insert(1, "4567", 0),
  421. Invert(0, 1),
  422. AssertOpsJson(0, r#"[{"insert":"123"}]"#),
  423. ];
  424. OpTester::new().run_script(ops);
  425. }
  426. #[test]
  427. fn delta_invert_attribute_delta_with_no_attribute_delta() {
  428. let ops = vec![
  429. Insert(0, "123", 0),
  430. Bold(0, Interval::new(0, 3), true),
  431. AssertOpsJson(0, r#"[{"insert":"123","attributes":{"bold":"true"}}]"#),
  432. Insert(1, "4567", 0),
  433. Invert(0, 1),
  434. AssertOpsJson(0, r#"[{"insert":"123","attributes":{"bold":"true"}}]"#),
  435. ];
  436. OpTester::new().run_script(ops);
  437. }
  438. #[test]
  439. fn delta_invert_attribute_delta_with_no_attribute_delta2() {
  440. let ops = vec![
  441. Insert(0, "123", 0),
  442. Bold(0, Interval::new(0, 3), true),
  443. Insert(0, "456", 3),
  444. AssertOpsJson(
  445. 0,
  446. r#"[
  447. {"insert":"123456","attributes":{"bold":"true"}}]
  448. "#,
  449. ),
  450. Italic(0, Interval::new(2, 4), true),
  451. AssertOpsJson(
  452. 0,
  453. r#"[
  454. {"insert":"12","attributes":{"bold":"true"}},
  455. {"insert":"34","attributes":{"bold":"true","italic":"true"}},
  456. {"insert":"56","attributes":{"bold":"true"}}
  457. ]"#,
  458. ),
  459. Insert(1, "abc", 0),
  460. Invert(0, 1),
  461. AssertOpsJson(
  462. 0,
  463. r#"[
  464. {"insert":"12","attributes":{"bold":"true"}},
  465. {"insert":"34","attributes":{"bold":"true","italic":"true"}},
  466. {"insert":"56","attributes":{"bold":"true"}}
  467. ]"#,
  468. ),
  469. ];
  470. OpTester::new().run_script(ops);
  471. }
  472. #[test]
  473. fn delta_invert_no_attribute_delta_with_attribute_delta() {
  474. let ops = vec![
  475. Insert(0, "123", 0),
  476. Insert(1, "4567", 0),
  477. Bold(1, Interval::new(0, 3), true),
  478. AssertOpsJson(
  479. 1,
  480. r#"[{"insert":"456","attributes":{"bold":"true"}},{"insert":"7"}]"#,
  481. ),
  482. Invert(0, 1),
  483. AssertOpsJson(0, r#"[{"insert":"123"}]"#),
  484. ];
  485. OpTester::new().run_script(ops);
  486. }
  487. #[test]
  488. fn delta_invert_no_attribute_delta_with_attribute_delta2() {
  489. let ops = vec![
  490. Insert(0, "123", 0),
  491. AssertOpsJson(0, r#"[{"insert":"123"}]"#),
  492. Insert(1, "abc", 0),
  493. Bold(1, Interval::new(0, 3), true),
  494. Insert(1, "d", 3),
  495. Italic(1, Interval::new(1, 3), true),
  496. AssertOpsJson(
  497. 1,
  498. r#"[{"insert":"a","attributes":{"bold":"true"}},{"insert":"bc","attributes":
  499. {"bold":"true","italic":"true"}},{"insert":"d","attributes":{"bold":"true"
  500. }}]"#,
  501. ),
  502. Invert(0, 1),
  503. AssertOpsJson(0, r#"[{"insert":"123"}]"#),
  504. ];
  505. OpTester::new().run_script(ops);
  506. }
  507. #[test]
  508. fn delta_invert_attribute_delta_with_attribute_delta() {
  509. let ops = vec![
  510. Insert(0, "123", 0),
  511. Bold(0, Interval::new(0, 3), true),
  512. Insert(0, "456", 3),
  513. AssertOpsJson(0, r#"[{"insert":"123456","attributes":{"bold":"true"}}]"#),
  514. Italic(0, Interval::new(2, 4), true),
  515. AssertOpsJson(
  516. 0,
  517. r#"[
  518. {"insert":"12","attributes":{"bold":"true"}},
  519. {"insert":"34","attributes":{"bold":"true","italic":"true"}},
  520. {"insert":"56","attributes":{"bold":"true"}}
  521. ]"#,
  522. ),
  523. Insert(1, "abc", 0),
  524. Bold(1, Interval::new(0, 3), true),
  525. Insert(1, "d", 3),
  526. Italic(1, Interval::new(1, 3), true),
  527. AssertOpsJson(
  528. 1,
  529. r#"[
  530. {"insert":"a","attributes":{"bold":"true"}},
  531. {"insert":"bc","attributes":{"bold":"true","italic":"true"}},
  532. {"insert":"d","attributes":{"bold":"true"}}
  533. ]"#,
  534. ),
  535. Invert(0, 1),
  536. AssertOpsJson(
  537. 0,
  538. r#"[
  539. {"insert":"12","attributes":{"bold":"true"}},
  540. {"insert":"34","attributes":{"bold":"true","italic":"true"}},
  541. {"insert":"56","attributes":{"bold":"true"}}
  542. ]"#,
  543. ),
  544. ];
  545. OpTester::new().run_script(ops);
  546. }