2023-10-31 09:59:24 +00:00
|
|
|
use loro_common::LoroResult;
|
|
|
|
use loro_internal::{LoroDoc, ToJson};
|
|
|
|
use serde_json::json;
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_forward_interleaving() -> LoroResult<()> {
|
|
|
|
let a = LoroDoc::new_auto_commit();
|
|
|
|
a.set_peer_id(0)?;
|
2023-11-28 08:22:43 +00:00
|
|
|
a.get_text("text").insert(0, "Hello")?;
|
2023-10-31 09:59:24 +00:00
|
|
|
let b = LoroDoc::new_auto_commit();
|
|
|
|
b.set_peer_id(1)?;
|
2023-11-28 08:22:43 +00:00
|
|
|
b.get_text("text").insert(0, " World!")?;
|
2023-10-31 09:59:24 +00:00
|
|
|
a.merge(&b)?;
|
|
|
|
assert_eq!(
|
|
|
|
a.get_deep_value().to_json_value(),
|
|
|
|
json!({"text": "Hello World!"})
|
|
|
|
);
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_backward_interleaving() -> LoroResult<()> {
|
|
|
|
let a = LoroDoc::new_auto_commit();
|
|
|
|
a.set_peer_id(0)?;
|
2023-11-28 08:22:43 +00:00
|
|
|
a.get_text("text").insert(0, "o")?;
|
|
|
|
a.get_text("text").insert(0, "l")?;
|
|
|
|
a.get_text("text").insert(0, "l")?;
|
|
|
|
a.get_text("text").insert(0, "e")?;
|
|
|
|
a.get_text("text").insert(0, "H")?;
|
2023-10-31 09:59:24 +00:00
|
|
|
dbg!(a.get_deep_value());
|
|
|
|
let b = LoroDoc::new_auto_commit();
|
|
|
|
b.set_peer_id(1)?;
|
2023-11-28 08:22:43 +00:00
|
|
|
b.get_text("text").insert(0, "!")?;
|
|
|
|
b.get_text("text").insert(0, "d")?;
|
|
|
|
b.get_text("text").insert(0, "l")?;
|
|
|
|
b.get_text("text").insert(0, "r")?;
|
|
|
|
b.get_text("text").insert(0, "o")?;
|
|
|
|
b.get_text("text").insert(0, "W")?;
|
|
|
|
b.get_text("text").insert(0, " ")?;
|
2023-10-31 09:59:24 +00:00
|
|
|
dbg!(b.get_deep_value());
|
|
|
|
a.merge(&b)?;
|
|
|
|
assert_eq!(
|
|
|
|
a.get_deep_value().to_json_value(),
|
|
|
|
json!({"text": "Hello World!"})
|
|
|
|
);
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_forward_backward() -> LoroResult<()> {
|
|
|
|
let a = LoroDoc::new_auto_commit();
|
|
|
|
a.set_peer_id(0)?;
|
2023-11-28 08:22:43 +00:00
|
|
|
a.get_text("text").insert(0, "ll")?;
|
|
|
|
a.get_text("text").insert(0, "He")?;
|
|
|
|
a.get_text("text").insert(4, "o")?;
|
2023-10-31 09:59:24 +00:00
|
|
|
let b = LoroDoc::new_auto_commit();
|
|
|
|
b.set_peer_id(1)?;
|
2023-11-28 08:22:43 +00:00
|
|
|
b.get_text("text").insert(0, " !")?;
|
|
|
|
b.get_text("text").insert(1, "W")?;
|
|
|
|
b.get_text("text").insert(2, "d")?;
|
|
|
|
b.get_text("text").insert(2, "l")?;
|
|
|
|
b.get_text("text").insert(2, "r")?;
|
|
|
|
b.get_text("text").insert(2, "o")?;
|
2023-10-31 09:59:24 +00:00
|
|
|
a.merge(&b)?;
|
|
|
|
assert_eq!(
|
|
|
|
a.get_deep_value().to_json_value(),
|
|
|
|
json!({"text": "Hello World!"})
|
|
|
|
);
|
|
|
|
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_yjs_interleave() -> LoroResult<()> {
|
|
|
|
// As stated in the Fugue paper, Yjs has a interleaving anomaly in the following case:
|
|
|
|
let a = LoroDoc::new_auto_commit();
|
|
|
|
a.set_peer_id(0)?;
|
|
|
|
let b = LoroDoc::new_auto_commit();
|
|
|
|
b.set_peer_id(1)?;
|
|
|
|
let c = LoroDoc::new_auto_commit();
|
|
|
|
c.set_peer_id(2)?;
|
2023-11-28 08:22:43 +00:00
|
|
|
c.get_text("text").insert(0, "2")?;
|
2023-10-31 09:59:24 +00:00
|
|
|
a.merge(&c)?;
|
2023-11-28 08:22:43 +00:00
|
|
|
a.get_text("text").insert(0, "1")?;
|
2023-10-31 09:59:24 +00:00
|
|
|
// b should not be between a and c
|
2023-11-28 08:22:43 +00:00
|
|
|
b.get_text("text").insert(0, "b")?;
|
2023-10-31 09:59:24 +00:00
|
|
|
a.merge(&b)?;
|
|
|
|
assert_eq!(a.get_deep_value().to_json_value(), json!({"text": "b12"}));
|
|
|
|
Ok(())
|
|
|
|
}
|