op_test.rs 17 KB

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