2022-11-26 23:57:50 +00:00
|
|
|
// Copyright 2022 The Jujutsu Authors
|
2022-04-09 22:53:32 +00:00
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// https://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
|
2022-04-09 22:53:32 +00:00
|
|
|
use crate::common::{get_stderr_string, TestEnvironment};
|
2022-04-09 22:53:32 +00:00
|
|
|
|
|
|
|
pub mod common;
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_describe() {
|
|
|
|
let mut 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");
|
|
|
|
|
|
|
|
let edit_script = test_env.set_up_fake_editor();
|
|
|
|
|
|
|
|
// Set a description using `-m` flag
|
|
|
|
let stdout = test_env.jj_cmd_success(&repo_path, &["describe", "-m", "description from CLI"]);
|
2022-04-28 23:32:18 +00:00
|
|
|
insta::assert_snapshot!(stdout, @r###"
|
2022-12-21 04:47:10 +00:00
|
|
|
Working copy now at: cf3e86731c67 description from CLI
|
|
|
|
"###);
|
|
|
|
|
|
|
|
// Set the same description using `-m` flag, but with explicit newline
|
|
|
|
let stdout = test_env.jj_cmd_success(&repo_path, &["describe", "-m", "description from CLI\n"]);
|
|
|
|
insta::assert_snapshot!(stdout, @r###"
|
|
|
|
Nothing changed.
|
2022-04-28 23:32:18 +00:00
|
|
|
"###);
|
2022-04-09 22:53:32 +00:00
|
|
|
|
2022-08-28 17:28:53 +00:00
|
|
|
// Check that the text file gets initialized with the current description and
|
|
|
|
// make no changes
|
2022-12-22 07:58:23 +00:00
|
|
|
std::fs::write(&edit_script, "dump editor0").unwrap();
|
2022-04-09 22:53:32 +00:00
|
|
|
let stdout = test_env.jj_cmd_success(&repo_path, &["describe"]);
|
2022-04-28 23:32:18 +00:00
|
|
|
insta::assert_snapshot!(stdout, @r###"
|
2022-12-21 04:47:10 +00:00
|
|
|
Nothing changed.
|
2022-04-28 23:32:18 +00:00
|
|
|
"###);
|
2022-12-22 07:58:23 +00:00
|
|
|
insta::assert_snapshot!(
|
|
|
|
std::fs::read_to_string(test_env.env_root().join("editor0")).unwrap(), @r###"
|
|
|
|
description from CLI
|
|
|
|
|
|
|
|
JJ: Lines starting with "JJ: " (like this one) will be removed.
|
|
|
|
"###);
|
2022-04-09 22:53:32 +00:00
|
|
|
|
|
|
|
// Set a description in editor
|
|
|
|
std::fs::write(&edit_script, "write\ndescription from editor").unwrap();
|
|
|
|
let stdout = test_env.jj_cmd_success(&repo_path, &["describe"]);
|
2022-04-28 23:32:18 +00:00
|
|
|
insta::assert_snapshot!(stdout, @r###"
|
2022-12-21 01:51:44 +00:00
|
|
|
Working copy now at: 100943aeee3f description from editor
|
2022-04-28 23:32:18 +00:00
|
|
|
"###);
|
2022-04-09 22:53:32 +00:00
|
|
|
|
|
|
|
// Lines in editor starting with "JJ: " are ignored
|
2022-04-09 22:53:32 +00:00
|
|
|
std::fs::write(
|
|
|
|
&edit_script,
|
|
|
|
"write\nJJ: ignored\ndescription among comment\nJJ: ignored",
|
|
|
|
)
|
|
|
|
.unwrap();
|
2022-04-09 22:53:32 +00:00
|
|
|
let stdout = test_env.jj_cmd_success(&repo_path, &["describe"]);
|
2022-04-28 23:32:18 +00:00
|
|
|
insta::assert_snapshot!(stdout, @r###"
|
2022-12-21 04:47:10 +00:00
|
|
|
Working copy now at: ccefa58bef47 description among comment
|
2022-04-28 23:32:18 +00:00
|
|
|
"###);
|
2022-04-09 22:53:32 +00:00
|
|
|
|
2022-12-21 01:51:44 +00:00
|
|
|
// Multi-line description
|
|
|
|
std::fs::write(&edit_script, "write\nline1\nline2\n\nline4\n\n").unwrap();
|
|
|
|
let stdout = test_env.jj_cmd_success(&repo_path, &["describe"]);
|
|
|
|
insta::assert_snapshot!(stdout, @r###"
|
|
|
|
Working copy now at: e932ba42cef0 line1
|
|
|
|
"###);
|
|
|
|
let stdout =
|
|
|
|
test_env.jj_cmd_success(&repo_path, &["log", "--no-graph", "-r@", "-Tdescription"]);
|
|
|
|
insta::assert_snapshot!(stdout, @r###"
|
|
|
|
line1
|
|
|
|
line2
|
|
|
|
|
|
|
|
line4
|
|
|
|
"###);
|
|
|
|
|
|
|
|
// Multi-line description again with CRLF, which should make no changes
|
|
|
|
std::fs::write(&edit_script, "write\nline1\r\nline2\r\n\r\nline4\r\n\r\n").unwrap();
|
|
|
|
let stdout = test_env.jj_cmd_success(&repo_path, &["describe"]);
|
|
|
|
insta::assert_snapshot!(stdout, @r###"
|
|
|
|
Nothing changed.
|
|
|
|
"###);
|
|
|
|
|
|
|
|
// Clear description
|
|
|
|
let stdout = test_env.jj_cmd_success(&repo_path, &["describe", "-m", ""]);
|
|
|
|
insta::assert_snapshot!(stdout, @r###"
|
|
|
|
Working copy now at: d6957294acdc (no description set)
|
|
|
|
"###);
|
|
|
|
std::fs::write(&edit_script, "write\n").unwrap();
|
|
|
|
let stdout = test_env.jj_cmd_success(&repo_path, &["describe"]);
|
|
|
|
insta::assert_snapshot!(stdout, @r###"
|
|
|
|
Nothing changed.
|
|
|
|
"###);
|
|
|
|
|
2022-04-09 22:53:32 +00:00
|
|
|
// Fails if the editor fails
|
|
|
|
std::fs::write(&edit_script, "fail").unwrap();
|
|
|
|
let stderr = test_env.jj_cmd_failure(&repo_path, &["describe"]);
|
|
|
|
assert!(stderr.contains("exited with an error"));
|
|
|
|
|
|
|
|
// Fails if the editor doesn't exist
|
|
|
|
std::fs::write(&edit_script, "").unwrap();
|
|
|
|
let assert = test_env
|
|
|
|
.jj_cmd(&repo_path, &["describe"])
|
|
|
|
.env("EDITOR", "this-editor-does-not-exist")
|
|
|
|
.assert()
|
|
|
|
.failure();
|
|
|
|
assert!(get_stderr_string(&assert).contains("Failed to run"));
|
2022-04-10 05:42:27 +00:00
|
|
|
|
2022-05-10 17:04:10 +00:00
|
|
|
// `$VISUAL` overrides `$EDITOR`
|
|
|
|
let assert = test_env
|
|
|
|
.jj_cmd(&repo_path, &["describe"])
|
|
|
|
.env("VISUAL", "bad-editor-from-visual-env")
|
|
|
|
.env("EDITOR", "bad-editor-from-editor-env")
|
|
|
|
.assert()
|
|
|
|
.failure();
|
|
|
|
assert!(get_stderr_string(&assert).contains("bad-editor-from-visual-env"));
|
|
|
|
|
|
|
|
// `ui.editor` config overrides `$VISUAL`
|
2022-04-10 05:42:27 +00:00
|
|
|
test_env.add_config(
|
|
|
|
br#"[ui]
|
|
|
|
editor = "bad-editor-from-config""#,
|
|
|
|
);
|
|
|
|
let assert = test_env
|
|
|
|
.jj_cmd(&repo_path, &["describe"])
|
2022-05-10 17:04:10 +00:00
|
|
|
.env("VISUAL", "bad-editor-from-visual-env")
|
2022-04-10 05:42:27 +00:00
|
|
|
.assert()
|
|
|
|
.failure();
|
|
|
|
assert!(get_stderr_string(&assert).contains("bad-editor-from-config"));
|
2022-04-10 06:20:36 +00:00
|
|
|
|
|
|
|
// `$JJ_EDITOR` overrides `ui.editor` config
|
|
|
|
let assert = test_env
|
|
|
|
.jj_cmd(&repo_path, &["describe"])
|
2022-05-10 17:04:10 +00:00
|
|
|
.env("JJ_EDITOR", "bad-jj-editor-from-jj-editor-env")
|
2022-04-10 06:20:36 +00:00
|
|
|
.assert()
|
|
|
|
.failure();
|
2022-05-10 17:04:10 +00:00
|
|
|
assert!(get_stderr_string(&assert).contains("bad-jj-editor-from-jj-editor-env"));
|
2022-04-09 22:53:32 +00:00
|
|
|
}
|