forked from mirrors/jj
a3d3947499
Suppose "template" is a sequence of "term"s, it makes more sense to handle an empty sequence there. It might be even better to disallow empty template other than the top-level one.
135 lines
4.4 KiB
Rust
135 lines
4.4 KiB
Rust
// Copyright 2022 The Jujutsu Authors
|
|
//
|
|
// 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.
|
|
|
|
use crate::common::TestEnvironment;
|
|
|
|
pub mod common;
|
|
|
|
#[test]
|
|
fn test_templater_branches() {
|
|
let test_env = TestEnvironment::default();
|
|
|
|
test_env.jj_cmd_success(test_env.env_root(), &["init", "--git", "origin"]);
|
|
let origin_path = test_env.env_root().join("origin");
|
|
let origin_git_repo_path = origin_path
|
|
.join(".jj")
|
|
.join("repo")
|
|
.join("store")
|
|
.join("git");
|
|
|
|
// Created some branches on the remote
|
|
test_env.jj_cmd_success(&origin_path, &["describe", "-m=description 1"]);
|
|
test_env.jj_cmd_success(&origin_path, &["branch", "create", "branch1"]);
|
|
test_env.jj_cmd_success(&origin_path, &["new", "root", "-m=description 2"]);
|
|
test_env.jj_cmd_success(&origin_path, &["branch", "create", "branch2"]);
|
|
test_env.jj_cmd_success(&origin_path, &["new", "root", "-m=description 3"]);
|
|
test_env.jj_cmd_success(&origin_path, &["branch", "create", "branch3"]);
|
|
test_env.jj_cmd_success(&origin_path, &["git", "export"]);
|
|
test_env.jj_cmd_success(
|
|
test_env.env_root(),
|
|
&[
|
|
"git",
|
|
"clone",
|
|
origin_git_repo_path.to_str().unwrap(),
|
|
"local",
|
|
],
|
|
);
|
|
let workspace_root = test_env.env_root().join("local");
|
|
|
|
// Rewrite branch1, move branch2 forward, create conflict in branch3, add
|
|
// new-branch
|
|
test_env.jj_cmd_success(
|
|
&workspace_root,
|
|
&["describe", "branch1", "-m", "modified branch1 commit"],
|
|
);
|
|
test_env.jj_cmd_success(&workspace_root, &["new", "branch2"]);
|
|
test_env.jj_cmd_success(&workspace_root, &["branch", "set", "branch2"]);
|
|
test_env.jj_cmd_success(&workspace_root, &["branch", "create", "new-branch"]);
|
|
test_env.jj_cmd_success(&workspace_root, &["describe", "branch3", "-m=local"]);
|
|
test_env.jj_cmd_success(&origin_path, &["describe", "branch3", "-m=origin"]);
|
|
test_env.jj_cmd_success(&origin_path, &["git", "export"]);
|
|
test_env.jj_cmd_success(&workspace_root, &["git", "fetch"]);
|
|
|
|
let output = test_env.jj_cmd_success(
|
|
&workspace_root,
|
|
&["log", "-T", r#"commit_id.short() " " branches"#],
|
|
);
|
|
insta::assert_snapshot!(output, @r###"
|
|
o b1bb3766d584 branch3??
|
|
| @ a5b4d15489cc branch2* new-branch
|
|
| | o 21c33875443e branch1*
|
|
| |/
|
|
|/|
|
|
| o 8476341eb395 branch2@origin
|
|
|/
|
|
o 000000000000
|
|
"###);
|
|
}
|
|
|
|
#[test]
|
|
fn test_templater_parsed_tree() {
|
|
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");
|
|
|
|
// Empty
|
|
let stdout = test_env.jj_cmd_success(&repo_path, &["log", "--no-graph", "-r@-", "-T", r#" "#]);
|
|
insta::assert_snapshot!(stdout, @"");
|
|
|
|
// Single term with whitespace
|
|
let stdout = test_env.jj_cmd_success(
|
|
&repo_path,
|
|
&[
|
|
"log",
|
|
"--no-graph",
|
|
"-r@-",
|
|
"-T",
|
|
r#" commit_id.short() "#,
|
|
],
|
|
);
|
|
insta::assert_snapshot!(stdout, @"000000000000");
|
|
|
|
// Multiple terms
|
|
let stdout = test_env.jj_cmd_success(
|
|
&repo_path,
|
|
&[
|
|
"log",
|
|
"--no-graph",
|
|
"-r@-",
|
|
"-T",
|
|
r#" commit_id.short() empty "#,
|
|
],
|
|
);
|
|
insta::assert_snapshot!(stdout, @"000000000000true");
|
|
|
|
// Parenthesized single term
|
|
let stdout = test_env.jj_cmd_success(
|
|
&repo_path,
|
|
&["log", "--no-graph", "-r@-", "-T", r#"(commit_id.short())"#],
|
|
);
|
|
insta::assert_snapshot!(stdout, @"000000000000");
|
|
|
|
// Parenthesized multiple terms and concatenation
|
|
let stdout = test_env.jj_cmd_success(
|
|
&repo_path,
|
|
&[
|
|
"log",
|
|
"--no-graph",
|
|
"-r@-",
|
|
"-T",
|
|
r#"(commit_id.short() " ") empty"#,
|
|
],
|
|
);
|
|
insta::assert_snapshot!(stdout, @"000000000000 true");
|
|
}
|