tests: snapshot some editor contents in test_describe_author()

This commit is contained in:
Yuya Nishihara 2024-09-23 08:26:34 +09:00
parent 69d1600d82
commit 49e5585130

View file

@ -489,14 +489,34 @@ fn test_describe_default_description() {
#[test] #[test]
fn test_describe_author() { fn test_describe_author() {
let test_env = TestEnvironment::default(); let mut test_env = TestEnvironment::default();
test_env.jj_cmd_ok(test_env.env_root(), &["git", "init", "repo"]); test_env.jj_cmd_ok(test_env.env_root(), &["git", "init", "repo"]);
let repo_path = test_env.env_root().join("repo"); let repo_path = test_env.env_root().join("repo");
test_env.add_config( let edit_script = test_env.set_up_fake_editor();
r#"[template-aliases] std::fs::write(edit_script, ["dump editor"].join("\0")).unwrap();
'format_signature(signature)' = 'signature.name() ++ " " ++ signature.email() ++ " " ++ signature.timestamp()'"#,
); test_env.add_config(indoc! {r#"
[template-aliases]
'format_signature(signature)' = 'signature.name() ++ " " ++ signature.email() ++ " " ++ signature.timestamp()'
[templates]
draft_commit_description = '''
concat(
description,
"\n",
indent(
"JJ: ",
concat(
"Author: " ++ format_detailed_signature(author) ++ "\n",
"Committer: " ++ format_detailed_signature(committer) ++ "\n",
"\n",
diff.stat(76),
),
),
)
'''
"#});
let get_signatures = || { let get_signatures = || {
test_env.jj_cmd_success( test_env.jj_cmd_success(
&repo_path, &repo_path,
@ -530,7 +550,6 @@ fn test_describe_author() {
&repo_path, &repo_path,
&[ &[
"describe", "describe",
"--no-edit",
"--author", "--author",
"Super Seeder <super.seeder@example.com>", "Super Seeder <super.seeder@example.com>",
], ],
@ -546,6 +565,16 @@ fn test_describe_author() {
Test User test.user@example.com 2001-02-03 04:05:07.000 +07:00 Test User test.user@example.com 2001-02-03 04:05:07.000 +07:00
~ ~
"#); "#);
insta::assert_snapshot!(
std::fs::read_to_string(test_env.env_root().join("editor")).unwrap(), @r#"
JJ: Author: Super Seeder <super.seeder@example.com> (2001-02-03 08:05:10)
JJ: Committer: Test User <test.user@example.com> (2001-02-03 08:05:12)
JJ: 0 files changed, 0 insertions(+), 0 deletions(-)
JJ: Lines starting with "JJ: " (like this one) will be removed.
"#);
// Change the author for multiple commits (the committer is always reset) // Change the author for multiple commits (the committer is always reset)
test_env.jj_cmd_ok( test_env.jj_cmd_ok(
@ -605,7 +634,6 @@ fn test_describe_author() {
"--config-toml", "--config-toml",
r#"user.name = "Ove Ridder" r#"user.name = "Ove Ridder"
user.email = "ove.ridder@example.com""#, user.email = "ove.ridder@example.com""#,
"--no-edit",
"--reset-author", "--reset-author",
], ],
); );
@ -620,6 +648,29 @@ fn test_describe_author() {
Ove Ridder ove.ridder@example.com 2001-02-03 04:05:18.000 +07:00 Ove Ridder ove.ridder@example.com 2001-02-03 04:05:18.000 +07:00
~ ~
"#); "#);
insta::assert_snapshot!(
std::fs::read_to_string(test_env.env_root().join("editor")).unwrap(), @r#"
JJ: Enter or edit commit descriptions after the `JJ: describe` lines.
JJ: Warning:
JJ: - The text you enter will be lost on a syntax error.
JJ: - The syntax of the separator lines may change in the future.
JJ: describe eae86afaa20c -------
JJ: Author: Ove Ridder <ove.ridder@example.com> (2001-02-03 08:05:18)
JJ: Committer: Ove Ridder <ove.ridder@example.com> (2001-02-03 08:05:18)
JJ: 0 files changed, 0 insertions(+), 0 deletions(-)
JJ: describe ba485659f76a -------
JJ: Author: Ove Ridder <ove.ridder@example.com> (2001-02-03 08:05:18)
JJ: Committer: Ove Ridder <ove.ridder@example.com> (2001-02-03 08:05:18)
JJ: 0 files changed, 0 insertions(+), 0 deletions(-)
JJ: Lines starting with "JJ: " (like this one) will be removed.
"#);
} }
#[test] #[test]