Test jj log for divergent commits

It turns out we did not have tests that would catch `jj log` failing
to mark divergent commits.
This commit is contained in:
Ilya Grigoriev 2023-01-01 23:09:38 -08:00
parent 265fa7f7c7
commit 9974d67da2

View file

@ -288,6 +288,50 @@ fn test_log_with_or_without_diff() {
"###); "###);
} }
#[test]
fn test_log_divergence() {
let test_env = TestEnvironment::default();
test_env.jj_cmd_success(test_env.env_root(), &["init", "repo", "--git"]);
let repo_path = test_env.env_root().join("repo");
std::fs::write(repo_path.join("file"), "foo\n").unwrap();
test_env.jj_cmd_success(&repo_path, &["describe", "-m", "description 1"]);
let stdout = test_env.jj_cmd_success(
&repo_path,
&[
"log",
"-T",
r#"description.first_line() if(divergent, " !divergence!")"#,
],
);
// No divergence
insta::assert_snapshot!(stdout, @r###"
@ description 1
o (no description set)
"###);
// Create divergence
test_env.jj_cmd_success(
&repo_path,
&["describe", "-m", "description 2", "--at-operation", "@-"],
);
let stdout = test_env.jj_cmd_success(
&repo_path,
&[
"log",
"-T",
r#"description.first_line() if(divergent, " !divergence!")"#,
],
);
insta::assert_snapshot!(stdout, @r###"
Concurrent modification detected, resolving automatically.
o description 2 !divergence!
| @ description 1 !divergence!
|/
o (no description set)
"###);
}
#[test] #[test]
fn test_log_reversed() { fn test_log_reversed() {
let test_env = TestEnvironment::default(); let test_env = TestEnvironment::default();