2022-11-26 23:57:50 +00:00
|
|
|
|
// Copyright 2022 The Jujutsu Authors
|
2022-11-04 16:39:46 +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.
|
|
|
|
|
|
2023-01-31 09:41:15 +00:00
|
|
|
|
use std::path::Path;
|
|
|
|
|
|
2024-09-19 10:06:01 +00:00
|
|
|
|
use indoc::indoc;
|
|
|
|
|
|
2023-07-03 10:04:31 +00:00
|
|
|
|
use crate::common::TestEnvironment;
|
2022-11-04 16:39:46 +00:00
|
|
|
|
|
2023-02-02 08:57:55 +00:00
|
|
|
|
#[test]
|
|
|
|
|
fn test_templater_parse_error() {
|
|
|
|
|
let test_env = TestEnvironment::default();
|
2024-05-17 19:49:25 +00:00
|
|
|
|
test_env.jj_cmd_ok(test_env.env_root(), &["git", "init", "repo"]);
|
2023-02-02 08:57:55 +00:00
|
|
|
|
let repo_path = test_env.env_root().join("repo");
|
|
|
|
|
let render_err = |template| test_env.jj_cmd_failure(&repo_path, &["log", "-T", template]);
|
|
|
|
|
|
2024-12-11 07:08:32 +00:00
|
|
|
|
insta::assert_snapshot!(render_err(r#"description ()"#), @r#"
|
2024-03-26 11:28:50 +00:00
|
|
|
|
Error: Failed to parse template: Syntax error
|
2024-03-25 15:54:39 +00:00
|
|
|
|
Caused by: --> 1:13
|
2023-02-02 08:57:55 +00:00
|
|
|
|
|
|
|
|
|
|
1 | description ()
|
2023-02-28 11:30:57 +00:00
|
|
|
|
| ^---
|
2023-02-02 08:57:55 +00:00
|
|
|
|
|
|
2024-12-11 07:08:32 +00:00
|
|
|
|
= expected <EOI>, `++`, `||`, `&&`, `==`, `!=`, `>=`, `>`, `<=`, or `<`
|
|
|
|
|
"#);
|
2024-02-26 05:49:46 +00:00
|
|
|
|
|
|
|
|
|
// Typo
|
|
|
|
|
test_env.add_config(
|
|
|
|
|
r###"
|
|
|
|
|
[template-aliases]
|
2024-02-26 07:06:51 +00:00
|
|
|
|
'conflicting' = ''
|
|
|
|
|
'shorted()' = ''
|
2024-03-14 10:42:08 +00:00
|
|
|
|
'socat(x)' = 'x'
|
2024-02-26 05:49:46 +00:00
|
|
|
|
'format_id(id)' = 'id.sort()'
|
|
|
|
|
"###,
|
|
|
|
|
);
|
|
|
|
|
insta::assert_snapshot!(render_err(r#"conflicts"#), @r###"
|
2024-03-26 11:28:50 +00:00
|
|
|
|
Error: Failed to parse template: Keyword "conflicts" doesn't exist
|
2024-03-25 15:54:39 +00:00
|
|
|
|
Caused by: --> 1:1
|
2024-02-26 05:49:46 +00:00
|
|
|
|
|
|
|
|
|
|
1 | conflicts
|
|
|
|
|
| ^-------^
|
|
|
|
|
|
|
|
|
|
|
= Keyword "conflicts" doesn't exist
|
2024-02-26 07:06:51 +00:00
|
|
|
|
Hint: Did you mean "conflict", "conflicting"?
|
2024-02-26 05:49:46 +00:00
|
|
|
|
"###);
|
|
|
|
|
insta::assert_snapshot!(render_err(r#"commit_id.shorter()"#), @r###"
|
2024-03-26 11:28:50 +00:00
|
|
|
|
Error: Failed to parse template: Method "shorter" doesn't exist for type "CommitOrChangeId"
|
2024-03-25 15:54:39 +00:00
|
|
|
|
Caused by: --> 1:11
|
2024-02-26 05:49:46 +00:00
|
|
|
|
|
|
|
|
|
|
1 | commit_id.shorter()
|
|
|
|
|
| ^-----^
|
|
|
|
|
|
|
|
|
|
|
= Method "shorter" doesn't exist for type "CommitOrChangeId"
|
|
|
|
|
Hint: Did you mean "short", "shortest"?
|
|
|
|
|
"###);
|
2024-03-14 10:42:08 +00:00
|
|
|
|
insta::assert_snapshot!(render_err(r#"oncat()"#), @r###"
|
2024-03-26 11:28:50 +00:00
|
|
|
|
Error: Failed to parse template: Function "oncat" doesn't exist
|
2024-03-25 15:54:39 +00:00
|
|
|
|
Caused by: --> 1:1
|
2024-02-26 05:49:46 +00:00
|
|
|
|
|
|
2024-03-14 10:42:08 +00:00
|
|
|
|
1 | oncat()
|
|
|
|
|
| ^---^
|
2024-02-26 05:49:46 +00:00
|
|
|
|
|
|
2024-03-14 10:42:08 +00:00
|
|
|
|
= Function "oncat" doesn't exist
|
|
|
|
|
Hint: Did you mean "concat", "socat"?
|
2024-02-26 05:49:46 +00:00
|
|
|
|
"###);
|
|
|
|
|
insta::assert_snapshot!(render_err(r#""".lines().map(|s| se)"#), @r###"
|
2024-03-26 11:28:50 +00:00
|
|
|
|
Error: Failed to parse template: Keyword "se" doesn't exist
|
2024-03-25 15:54:39 +00:00
|
|
|
|
Caused by: --> 1:20
|
2024-02-26 05:49:46 +00:00
|
|
|
|
|
|
|
|
|
|
1 | "".lines().map(|s| se)
|
|
|
|
|
| ^^
|
|
|
|
|
|
|
|
|
|
|
= Keyword "se" doesn't exist
|
|
|
|
|
Hint: Did you mean "s", "self"?
|
|
|
|
|
"###);
|
2024-09-21 01:18:18 +00:00
|
|
|
|
insta::assert_snapshot!(render_err(r#"format_id(commit_id)"#), @r#"
|
|
|
|
|
Error: Failed to parse template: In alias "format_id(id)"
|
2024-03-25 15:54:39 +00:00
|
|
|
|
Caused by:
|
|
|
|
|
1: --> 1:1
|
2024-02-26 05:49:46 +00:00
|
|
|
|
|
|
|
|
|
|
1 | format_id(commit_id)
|
|
|
|
|
| ^------------------^
|
|
|
|
|
|
|
2024-09-21 01:18:18 +00:00
|
|
|
|
= In alias "format_id(id)"
|
2024-03-25 15:54:39 +00:00
|
|
|
|
2: --> 1:4
|
2024-02-26 05:49:46 +00:00
|
|
|
|
|
|
|
|
|
|
1 | id.sort()
|
|
|
|
|
| ^--^
|
|
|
|
|
|
|
|
|
|
|
= Method "sort" doesn't exist for type "CommitOrChangeId"
|
|
|
|
|
Hint: Did you mean "short", "shortest"?
|
2024-09-21 01:18:18 +00:00
|
|
|
|
"#);
|
2024-02-26 07:06:51 +00:00
|
|
|
|
|
|
|
|
|
// -Tbuiltin shows the predefined builtin_* aliases. This isn't 100%
|
|
|
|
|
// guaranteed, but is nice.
|
2024-09-12 14:20:57 +00:00
|
|
|
|
insta::assert_snapshot!(render_err(r#"builtin"#), @r#"
|
2024-03-26 11:28:50 +00:00
|
|
|
|
Error: Failed to parse template: Keyword "builtin" doesn't exist
|
2024-03-25 15:54:39 +00:00
|
|
|
|
Caused by: --> 1:1
|
2024-02-26 07:06:51 +00:00
|
|
|
|
|
|
|
|
|
|
1 | builtin
|
|
|
|
|
| ^-----^
|
|
|
|
|
|
|
|
|
|
|
= Keyword "builtin" doesn't exist
|
2024-10-13 19:10:00 +00:00
|
|
|
|
Hint: Did you mean "builtin_log_comfortable", "builtin_log_compact", "builtin_log_compact_full_description", "builtin_log_detailed", "builtin_log_node", "builtin_log_node_ascii", "builtin_log_oneline", "builtin_op_log_comfortable", "builtin_op_log_compact", "builtin_op_log_node", "builtin_op_log_node_ascii"?
|
2024-09-12 14:20:57 +00:00
|
|
|
|
"#);
|
2023-02-03 05:36:01 +00:00
|
|
|
|
}
|
|
|
|
|
|
2024-09-19 10:06:01 +00:00
|
|
|
|
#[test]
|
|
|
|
|
fn test_template_parse_warning() {
|
|
|
|
|
let test_env = TestEnvironment::default();
|
|
|
|
|
test_env.jj_cmd_ok(test_env.env_root(), &["git", "init", "repo"]);
|
|
|
|
|
let repo_path = test_env.env_root().join("repo");
|
|
|
|
|
|
|
|
|
|
let template = indoc! {r#"
|
|
|
|
|
separate(' ',
|
|
|
|
|
branches,
|
|
|
|
|
local_branches,
|
|
|
|
|
remote_branches,
|
|
|
|
|
self.contained_in('branches()'),
|
|
|
|
|
)
|
|
|
|
|
"#};
|
|
|
|
|
let (stdout, stderr) = test_env.jj_cmd_ok(&repo_path, &["log", "-r@", "-T", template]);
|
|
|
|
|
insta::assert_snapshot!(stdout, @r#"
|
|
|
|
|
@ false
|
|
|
|
|
│
|
|
|
|
|
~
|
|
|
|
|
"#);
|
|
|
|
|
insta::assert_snapshot!(stderr, @r#"
|
|
|
|
|
Warning: In template expression
|
|
|
|
|
--> 2:3
|
|
|
|
|
|
|
|
|
|
|
2 | branches,
|
|
|
|
|
| ^------^
|
|
|
|
|
|
|
|
|
|
|
= branches() is deprecated; use bookmarks() instead
|
|
|
|
|
Warning: In template expression
|
|
|
|
|
--> 3:3
|
|
|
|
|
|
|
|
|
|
|
3 | local_branches,
|
|
|
|
|
| ^------------^
|
|
|
|
|
|
|
|
|
|
|
= local_branches() is deprecated; use local_bookmarks() instead
|
|
|
|
|
Warning: In template expression
|
|
|
|
|
--> 4:3
|
|
|
|
|
|
|
|
|
|
|
4 | remote_branches,
|
|
|
|
|
| ^-------------^
|
|
|
|
|
|
|
|
|
|
|
= remote_branches() is deprecated; use remote_bookmarks() instead
|
|
|
|
|
Warning: In template expression
|
|
|
|
|
--> 5:21
|
|
|
|
|
|
|
|
|
|
|
5 | self.contained_in('branches()'),
|
|
|
|
|
| ^----------^
|
|
|
|
|
|
|
|
|
|
|
= In revset expression
|
|
|
|
|
--> 1:1
|
|
|
|
|
|
|
|
|
|
|
1 | branches()
|
|
|
|
|
| ^------^
|
|
|
|
|
|
|
|
|
|
|
= branches() is deprecated; use bookmarks() instead
|
|
|
|
|
"#);
|
|
|
|
|
}
|
|
|
|
|
|
2023-02-21 04:38:52 +00:00
|
|
|
|
#[test]
|
|
|
|
|
fn test_templater_upper_lower() {
|
|
|
|
|
let test_env = TestEnvironment::default();
|
2024-05-17 19:49:25 +00:00
|
|
|
|
test_env.jj_cmd_ok(test_env.env_root(), &["git", "init", "repo"]);
|
2023-02-21 04:38:52 +00:00
|
|
|
|
let repo_path = test_env.env_root().join("repo");
|
|
|
|
|
let render = |template| get_colored_template_output(&test_env, &repo_path, "@-", template);
|
|
|
|
|
|
|
|
|
|
insta::assert_snapshot!(
|
2023-02-28 11:30:57 +00:00
|
|
|
|
render(r#"change_id.shortest(4).upper() ++ change_id.shortest(4).upper().lower()"#),
|
2024-04-16 07:38:38 +00:00
|
|
|
|
@"[1m[38;5;5mZ[0m[38;5;8mZZZ[1m[38;5;5mz[0m[38;5;8mzzz[39m");
|
2023-02-21 04:38:52 +00:00
|
|
|
|
insta::assert_snapshot!(
|
2023-02-28 11:30:57 +00:00
|
|
|
|
render(r#""Hello".upper() ++ "Hello".lower()"#), @"HELLOhello");
|
2023-02-21 04:38:52 +00:00
|
|
|
|
}
|
|
|
|
|
|
2023-02-12 09:41:53 +00:00
|
|
|
|
#[test]
|
|
|
|
|
fn test_templater_alias() {
|
|
|
|
|
let test_env = TestEnvironment::default();
|
2024-05-17 19:49:25 +00:00
|
|
|
|
test_env.jj_cmd_ok(test_env.env_root(), &["git", "init", "repo"]);
|
2023-02-12 09:41:53 +00:00
|
|
|
|
let repo_path = test_env.env_root().join("repo");
|
|
|
|
|
let render = |template| get_template_output(&test_env, &repo_path, "@-", template);
|
|
|
|
|
let render_err = |template| test_env.jj_cmd_failure(&repo_path, &["log", "-T", template]);
|
|
|
|
|
|
|
|
|
|
test_env.add_config(
|
|
|
|
|
r###"
|
|
|
|
|
[template-aliases]
|
|
|
|
|
'my_commit_id' = 'commit_id.short()'
|
|
|
|
|
'syntax_error' = 'foo.'
|
|
|
|
|
'name_error' = 'unknown_id'
|
|
|
|
|
'recurse' = 'recurse1'
|
|
|
|
|
'recurse1' = 'recurse2()'
|
|
|
|
|
'recurse2()' = 'recurse'
|
|
|
|
|
'identity(x)' = 'x'
|
|
|
|
|
'coalesce(x, y)' = 'if(x, x, y)'
|
2024-09-19 10:06:01 +00:00
|
|
|
|
'deprecated()' = 'branches ++ self.contained_in("branches()")'
|
2024-07-15 22:20:10 +00:00
|
|
|
|
'builtin_log_node' = '"#"'
|
|
|
|
|
'builtin_op_log_node' = '"#"'
|
2023-02-12 09:41:53 +00:00
|
|
|
|
"###,
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
insta::assert_snapshot!(render("my_commit_id"), @"000000000000");
|
|
|
|
|
insta::assert_snapshot!(render("identity(my_commit_id)"), @"000000000000");
|
|
|
|
|
|
2024-09-21 01:18:18 +00:00
|
|
|
|
insta::assert_snapshot!(render_err("commit_id ++ syntax_error"), @r#"
|
|
|
|
|
Error: Failed to parse template: In alias "syntax_error"
|
2024-03-25 15:54:39 +00:00
|
|
|
|
Caused by:
|
|
|
|
|
1: --> 1:14
|
2023-02-12 09:41:53 +00:00
|
|
|
|
|
|
2023-02-28 11:30:57 +00:00
|
|
|
|
1 | commit_id ++ syntax_error
|
|
|
|
|
| ^----------^
|
2023-02-12 09:41:53 +00:00
|
|
|
|
|
|
2024-09-21 01:18:18 +00:00
|
|
|
|
= In alias "syntax_error"
|
2024-03-25 15:54:39 +00:00
|
|
|
|
2: --> 1:5
|
2023-02-12 09:41:53 +00:00
|
|
|
|
|
|
|
|
|
|
1 | foo.
|
|
|
|
|
| ^---
|
|
|
|
|
|
|
2024-02-07 03:08:03 +00:00
|
|
|
|
= expected <identifier>
|
2024-09-21 01:18:18 +00:00
|
|
|
|
"#);
|
2023-02-12 09:41:53 +00:00
|
|
|
|
|
2024-09-21 01:18:18 +00:00
|
|
|
|
insta::assert_snapshot!(render_err("commit_id ++ name_error"), @r#"
|
|
|
|
|
Error: Failed to parse template: In alias "name_error"
|
2024-03-25 15:54:39 +00:00
|
|
|
|
Caused by:
|
|
|
|
|
1: --> 1:14
|
2023-02-12 12:44:33 +00:00
|
|
|
|
|
|
2023-02-28 11:30:57 +00:00
|
|
|
|
1 | commit_id ++ name_error
|
|
|
|
|
| ^--------^
|
2023-02-12 12:44:33 +00:00
|
|
|
|
|
|
2024-09-21 01:18:18 +00:00
|
|
|
|
= In alias "name_error"
|
2024-03-25 15:54:39 +00:00
|
|
|
|
2: --> 1:1
|
2023-02-12 09:41:53 +00:00
|
|
|
|
|
|
|
|
|
|
1 | unknown_id
|
|
|
|
|
| ^--------^
|
|
|
|
|
|
|
|
|
|
|
= Keyword "unknown_id" doesn't exist
|
2024-09-21 01:18:18 +00:00
|
|
|
|
"#);
|
2023-02-12 09:41:53 +00:00
|
|
|
|
|
2024-09-21 01:18:18 +00:00
|
|
|
|
insta::assert_snapshot!(render_err(r#"identity(identity(commit_id.short("")))"#), @r#"
|
|
|
|
|
Error: Failed to parse template: In alias "identity(x)"
|
2024-03-25 15:54:39 +00:00
|
|
|
|
Caused by:
|
|
|
|
|
1: --> 1:1
|
2023-02-12 12:44:33 +00:00
|
|
|
|
|
|
|
|
|
|
1 | identity(identity(commit_id.short("")))
|
|
|
|
|
| ^-------------------------------------^
|
|
|
|
|
|
|
2024-09-21 01:18:18 +00:00
|
|
|
|
= In alias "identity(x)"
|
2024-05-15 07:18:16 +00:00
|
|
|
|
2: --> 1:1
|
|
|
|
|
|
|
|
|
|
|
1 | x
|
|
|
|
|
| ^
|
|
|
|
|
|
|
2024-09-21 01:18:18 +00:00
|
|
|
|
= In function parameter "x"
|
2024-05-15 07:18:16 +00:00
|
|
|
|
3: --> 1:10
|
2023-02-12 12:44:33 +00:00
|
|
|
|
|
|
|
|
|
|
1 | identity(identity(commit_id.short("")))
|
|
|
|
|
| ^---------------------------^
|
|
|
|
|
|
|
2024-09-21 01:18:18 +00:00
|
|
|
|
= In alias "identity(x)"
|
2024-05-15 07:18:16 +00:00
|
|
|
|
4: --> 1:1
|
|
|
|
|
|
|
|
|
|
|
1 | x
|
|
|
|
|
| ^
|
|
|
|
|
|
|
2024-09-21 01:18:18 +00:00
|
|
|
|
= In function parameter "x"
|
2024-05-15 07:18:16 +00:00
|
|
|
|
5: --> 1:35
|
2023-02-12 12:44:33 +00:00
|
|
|
|
|
|
|
|
|
|
1 | identity(identity(commit_id.short("")))
|
|
|
|
|
| ^^
|
|
|
|
|
|
|
2024-04-24 11:02:50 +00:00
|
|
|
|
= Expected expression of type "Integer", but actual type is "String"
|
2024-09-21 01:18:18 +00:00
|
|
|
|
"#);
|
2023-02-12 12:44:33 +00:00
|
|
|
|
|
2024-09-21 01:18:18 +00:00
|
|
|
|
insta::assert_snapshot!(render_err("commit_id ++ recurse"), @r#"
|
|
|
|
|
Error: Failed to parse template: In alias "recurse"
|
2024-03-25 15:54:39 +00:00
|
|
|
|
Caused by:
|
|
|
|
|
1: --> 1:14
|
2023-02-12 09:41:53 +00:00
|
|
|
|
|
|
2023-02-28 11:30:57 +00:00
|
|
|
|
1 | commit_id ++ recurse
|
|
|
|
|
| ^-----^
|
2023-02-12 09:41:53 +00:00
|
|
|
|
|
|
2024-09-21 01:18:18 +00:00
|
|
|
|
= In alias "recurse"
|
2024-03-25 15:54:39 +00:00
|
|
|
|
2: --> 1:1
|
2023-02-12 09:41:53 +00:00
|
|
|
|
|
|
|
|
|
|
1 | recurse1
|
|
|
|
|
| ^------^
|
|
|
|
|
|
|
2024-09-21 01:18:18 +00:00
|
|
|
|
= In alias "recurse1"
|
2024-03-25 15:54:39 +00:00
|
|
|
|
3: --> 1:1
|
2023-02-12 09:41:53 +00:00
|
|
|
|
|
|
|
|
|
|
1 | recurse2()
|
|
|
|
|
| ^--------^
|
|
|
|
|
|
|
2024-09-21 01:18:18 +00:00
|
|
|
|
= In alias "recurse2()"
|
2024-03-25 15:54:39 +00:00
|
|
|
|
4: --> 1:1
|
2023-02-12 09:41:53 +00:00
|
|
|
|
|
|
|
|
|
|
1 | recurse
|
|
|
|
|
| ^-----^
|
|
|
|
|
|
|
|
|
|
|
= Alias "recurse" expanded recursively
|
2024-09-21 01:18:18 +00:00
|
|
|
|
"#);
|
2023-02-12 09:41:53 +00:00
|
|
|
|
|
|
|
|
|
insta::assert_snapshot!(render_err("identity()"), @r###"
|
2024-03-26 11:28:50 +00:00
|
|
|
|
Error: Failed to parse template: Function "identity": Expected 1 arguments
|
2024-03-25 15:54:39 +00:00
|
|
|
|
Caused by: --> 1:10
|
2023-02-12 09:41:53 +00:00
|
|
|
|
|
|
|
|
|
|
1 | identity()
|
|
|
|
|
| ^
|
|
|
|
|
|
|
2023-03-15 03:22:41 +00:00
|
|
|
|
= Function "identity": Expected 1 arguments
|
2023-02-12 09:41:53 +00:00
|
|
|
|
"###);
|
|
|
|
|
insta::assert_snapshot!(render_err("identity(commit_id, commit_id)"), @r###"
|
2024-03-26 11:28:50 +00:00
|
|
|
|
Error: Failed to parse template: Function "identity": Expected 1 arguments
|
2024-03-25 15:54:39 +00:00
|
|
|
|
Caused by: --> 1:10
|
2023-02-12 09:41:53 +00:00
|
|
|
|
|
|
|
|
|
|
1 | identity(commit_id, commit_id)
|
|
|
|
|
| ^------------------^
|
|
|
|
|
|
|
2023-03-15 03:22:41 +00:00
|
|
|
|
= Function "identity": Expected 1 arguments
|
2023-02-12 09:41:53 +00:00
|
|
|
|
"###);
|
|
|
|
|
|
2024-09-21 01:18:18 +00:00
|
|
|
|
insta::assert_snapshot!(render_err(r#"coalesce(label("x", "not boolean"), "")"#), @r#"
|
|
|
|
|
Error: Failed to parse template: In alias "coalesce(x, y)"
|
2024-03-25 15:54:39 +00:00
|
|
|
|
Caused by:
|
|
|
|
|
1: --> 1:1
|
2023-02-12 12:44:33 +00:00
|
|
|
|
|
|
|
|
|
|
1 | coalesce(label("x", "not boolean"), "")
|
|
|
|
|
| ^-------------------------------------^
|
|
|
|
|
|
|
2024-09-21 01:18:18 +00:00
|
|
|
|
= In alias "coalesce(x, y)"
|
2024-05-15 07:18:16 +00:00
|
|
|
|
2: --> 1:4
|
|
|
|
|
|
|
|
|
|
|
1 | if(x, x, y)
|
|
|
|
|
| ^
|
|
|
|
|
|
|
2024-09-21 01:18:18 +00:00
|
|
|
|
= In function parameter "x"
|
2024-05-15 07:18:16 +00:00
|
|
|
|
3: --> 1:10
|
2023-02-12 09:41:53 +00:00
|
|
|
|
|
|
|
|
|
|
1 | coalesce(label("x", "not boolean"), "")
|
|
|
|
|
| ^-----------------------^
|
|
|
|
|
|
|
2024-04-24 11:02:50 +00:00
|
|
|
|
= Expected expression of type "Boolean", but actual type is "Template"
|
2024-09-21 01:18:18 +00:00
|
|
|
|
"#);
|
2024-05-16 13:57:01 +00:00
|
|
|
|
|
2024-09-21 01:18:18 +00:00
|
|
|
|
insta::assert_snapshot!(render_err("(-my_commit_id)"), @r#"
|
|
|
|
|
Error: Failed to parse template: In alias "my_commit_id"
|
2024-05-16 13:57:01 +00:00
|
|
|
|
Caused by:
|
|
|
|
|
1: --> 1:3
|
|
|
|
|
|
|
|
|
|
|
1 | (-my_commit_id)
|
|
|
|
|
| ^----------^
|
|
|
|
|
|
|
2024-09-21 01:18:18 +00:00
|
|
|
|
= In alias "my_commit_id"
|
2024-05-16 13:57:01 +00:00
|
|
|
|
2: --> 1:1
|
|
|
|
|
|
|
|
|
|
|
1 | commit_id.short()
|
|
|
|
|
| ^---------------^
|
|
|
|
|
|
|
|
|
|
|
= Expected expression of type "Integer", but actual type is "String"
|
2024-09-21 01:18:18 +00:00
|
|
|
|
"#);
|
2024-09-19 10:06:01 +00:00
|
|
|
|
|
|
|
|
|
let (stdout, stderr) = test_env.jj_cmd_ok(&repo_path, &["log", "-r@", "-Tdeprecated()"]);
|
|
|
|
|
insta::assert_snapshot!(stdout, @r##"
|
|
|
|
|
# false
|
|
|
|
|
│
|
|
|
|
|
~
|
|
|
|
|
"##);
|
|
|
|
|
insta::assert_snapshot!(stderr, @r#"
|
|
|
|
|
Warning: In template expression
|
|
|
|
|
--> 1:1
|
|
|
|
|
|
|
|
|
|
|
1 | deprecated()
|
|
|
|
|
| ^----------^
|
|
|
|
|
|
|
|
|
|
|
= In alias "deprecated()"
|
|
|
|
|
--> 1:1
|
|
|
|
|
|
|
|
|
|
|
1 | branches ++ self.contained_in("branches()")
|
|
|
|
|
| ^------^
|
|
|
|
|
|
|
|
|
|
|
= branches() is deprecated; use bookmarks() instead
|
|
|
|
|
Warning: In template expression
|
|
|
|
|
--> 1:1
|
|
|
|
|
|
|
|
|
|
|
1 | deprecated()
|
|
|
|
|
| ^----------^
|
|
|
|
|
|
|
|
|
|
|
= In alias "deprecated()"
|
|
|
|
|
--> 1:31
|
|
|
|
|
|
|
|
|
|
|
1 | branches ++ self.contained_in("branches()")
|
|
|
|
|
| ^----------^
|
|
|
|
|
|
|
|
|
|
|
= In revset expression
|
|
|
|
|
--> 1:1
|
|
|
|
|
|
|
|
|
|
|
1 | branches()
|
|
|
|
|
| ^------^
|
|
|
|
|
|
|
|
|
|
|
= branches() is deprecated; use bookmarks() instead
|
|
|
|
|
"#);
|
2023-02-12 09:41:53 +00:00
|
|
|
|
}
|
|
|
|
|
|
2023-05-23 03:45:11 +00:00
|
|
|
|
#[test]
|
|
|
|
|
fn test_templater_alias_override() {
|
|
|
|
|
let test_env = TestEnvironment::default();
|
2024-05-17 19:49:25 +00:00
|
|
|
|
test_env.jj_cmd_ok(test_env.env_root(), &["git", "init", "repo"]);
|
2023-05-23 03:45:11 +00:00
|
|
|
|
let repo_path = test_env.env_root().join("repo");
|
|
|
|
|
|
|
|
|
|
test_env.add_config(
|
2023-08-15 03:18:52 +00:00
|
|
|
|
r#"
|
2023-05-23 03:45:11 +00:00
|
|
|
|
[template-aliases]
|
|
|
|
|
'f(x)' = '"user"'
|
2023-08-15 03:18:52 +00:00
|
|
|
|
"#,
|
2023-05-23 03:45:11 +00:00
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
// 'f(x)' should be overridden by --config-toml 'f(a)'. If aliases were sorted
|
|
|
|
|
// purely by name, 'f(a)' would come first.
|
|
|
|
|
let stdout = test_env.jj_cmd_success(
|
|
|
|
|
&repo_path,
|
|
|
|
|
&[
|
|
|
|
|
"log",
|
|
|
|
|
"--no-graph",
|
|
|
|
|
"-r@",
|
|
|
|
|
"-T",
|
|
|
|
|
r#"f(_)"#,
|
|
|
|
|
"--config-toml",
|
|
|
|
|
r#"template-aliases.'f(a)' = '"arg"'"#,
|
|
|
|
|
],
|
|
|
|
|
);
|
|
|
|
|
insta::assert_snapshot!(stdout, @"arg");
|
|
|
|
|
}
|
|
|
|
|
|
2023-02-12 08:53:09 +00:00
|
|
|
|
#[test]
|
|
|
|
|
fn test_templater_bad_alias_decl() {
|
|
|
|
|
let test_env = TestEnvironment::default();
|
2024-05-17 19:49:25 +00:00
|
|
|
|
test_env.jj_cmd_ok(test_env.env_root(), &["git", "init", "repo"]);
|
2023-02-12 08:53:09 +00:00
|
|
|
|
let repo_path = test_env.env_root().join("repo");
|
|
|
|
|
|
|
|
|
|
test_env.add_config(
|
|
|
|
|
r###"
|
|
|
|
|
[template-aliases]
|
|
|
|
|
'badfn(a, a)' = 'a'
|
2023-02-12 09:41:53 +00:00
|
|
|
|
'my_commit_id' = 'commit_id.short()'
|
2023-02-12 08:53:09 +00:00
|
|
|
|
"###,
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
// Invalid declaration should be warned and ignored.
|
2023-07-03 10:04:31 +00:00
|
|
|
|
let (stdout, stderr) =
|
|
|
|
|
test_env.jj_cmd_ok(&repo_path, &["log", "--no-graph", "-r@-", "-Tmy_commit_id"]);
|
|
|
|
|
insta::assert_snapshot!(stdout, @"000000000000");
|
|
|
|
|
insta::assert_snapshot!(stderr, @r###"
|
2024-03-24 06:47:47 +00:00
|
|
|
|
Warning: Failed to load "template-aliases.badfn(a, a)": --> 1:7
|
2023-02-12 08:53:09 +00:00
|
|
|
|
|
|
|
|
|
|
1 | badfn(a, a)
|
|
|
|
|
| ^--^
|
|
|
|
|
|
|
|
|
|
|
= Redefinition of function parameter
|
|
|
|
|
"###);
|
|
|
|
|
}
|
|
|
|
|
|
2023-01-31 09:41:15 +00:00
|
|
|
|
fn get_template_output(
|
|
|
|
|
test_env: &TestEnvironment,
|
|
|
|
|
repo_path: &Path,
|
|
|
|
|
rev: &str,
|
|
|
|
|
template: &str,
|
|
|
|
|
) -> String {
|
|
|
|
|
test_env.jj_cmd_success(repo_path, &["log", "--no-graph", "-r", rev, "-T", template])
|
2023-01-28 10:23:39 +00:00
|
|
|
|
}
|
2023-02-03 13:13:56 +00:00
|
|
|
|
|
|
|
|
|
fn get_colored_template_output(
|
|
|
|
|
test_env: &TestEnvironment,
|
|
|
|
|
repo_path: &Path,
|
|
|
|
|
rev: &str,
|
|
|
|
|
template: &str,
|
|
|
|
|
) -> String {
|
|
|
|
|
test_env.jj_cmd_success(
|
|
|
|
|
repo_path,
|
|
|
|
|
&[
|
|
|
|
|
"log",
|
|
|
|
|
"--color=always",
|
|
|
|
|
"--no-graph",
|
|
|
|
|
"-r",
|
|
|
|
|
rev,
|
|
|
|
|
"-T",
|
|
|
|
|
template,
|
|
|
|
|
],
|
|
|
|
|
)
|
|
|
|
|
}
|