2022-11-26 23:57:50 +00:00
// Copyright 2022 The Jujutsu Authors
2022-03-28 09:12:08 +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-11-18 23:41:35 +00:00
use common ::{ get_stderr_string , get_stdout_string , TestEnvironment } ;
2022-03-30 17:47:11 +00:00
pub mod common ;
2022-03-28 09:12:08 +00:00
2022-11-28 14:32:44 +00:00
#[ test ]
fn test_log_with_empty_revision ( ) {
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 " ) ;
let stderr = test_env . jj_cmd_cli_error ( & repo_path , & [ " log " , " -r= " ] ) ;
insta ::assert_snapshot! ( stderr , @ r ###"
error : The argument ' - - revisions < REVISIONS > ' requires a value but none was supplied
For more information try ' - - help '
" ###);
}
2022-03-28 09:12:08 +00:00
#[ test ]
fn test_log_with_or_without_diff ( ) {
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 ( " file1 " ) , " foo \n " ) . unwrap ( ) ;
test_env . jj_cmd_success ( & repo_path , & [ " describe " , " -m " , " add a file " ] ) ;
test_env . jj_cmd_success ( & repo_path , & [ " new " , " -m " , " a new commit " ] ) ;
std ::fs ::write ( repo_path . join ( " file1 " ) , " foo \n bar \n " ) . unwrap ( ) ;
let stdout = test_env . jj_cmd_success ( & repo_path , & [ " log " , " -T " , " description " ] ) ;
insta ::assert_snapshot! ( stdout , @ r ###"
@ a new commit
o add a file
2023-01-31 09:17:46 +00:00
o
2022-03-28 09:12:08 +00:00
" ###);
let stdout = test_env . jj_cmd_success ( & repo_path , & [ " log " , " -T " , " description " , " -p " ] ) ;
insta ::assert_snapshot! ( stdout , @ r ###"
@ a new commit
| Modified regular file file1 :
| 1 1 : foo
| 2 : bar
o add a file
| Added regular file file1 :
| 1 : foo
2023-01-31 09:17:46 +00:00
o
2022-03-28 09:12:08 +00:00
" ###);
let stdout = test_env . jj_cmd_success ( & repo_path , & [ " log " , " -T " , " description " , " --no-graph " ] ) ;
insta ::assert_snapshot! ( stdout , @ r ###"
a new commit
add a file
" ###);
2022-12-13 12:24:24 +00:00
// `-p` for default diff output, `-s` for summary
let stdout = test_env . jj_cmd_success ( & repo_path , & [ " log " , " -T " , " description " , " -p " , " -s " ] ) ;
insta ::assert_snapshot! ( stdout , @ r ###"
@ a new commit
| M file1
| Modified regular file file1 :
| 1 1 : foo
| 2 : bar
o add a file
| A file1
| Added regular file file1 :
| 1 : foo
2023-01-31 09:17:46 +00:00
o
2022-12-13 12:24:24 +00:00
" ###);
// `-s` for summary, `--git` for git diff (which implies `-p`)
let stdout = test_env . jj_cmd_success ( & repo_path , & [ " log " , " -T " , " description " , " -s " , " --git " ] ) ;
insta ::assert_snapshot! ( stdout , @ r ###"
@ a new commit
| M file1
| diff - - git a / file1 b / file1
| index 257 cc5642c .. . 3 bd1f0e297 100644
| - - - a / file1
| + + + b / file1
| @ @ - 1 , 1 + 1 , 2 @ @
| foo
| + bar
o add a file
| A file1
| diff - - git a / file1 b / file1
| new file mode 100644
| index 0000000000 .. 257 cc5642c
| - - - / dev / null
| + + + b / file1
| @ @ - 1 , 0 + 1 , 1 @ @
| + foo
2023-01-31 09:17:46 +00:00
o
2022-12-13 12:24:24 +00:00
" ###);
// `-p` enables default "summary" output, so `-s` is noop
let stdout = test_env . jj_cmd_success (
& repo_path ,
& [
" log " ,
" -T " ,
" description " ,
" -p " ,
" -s " ,
" --config-toml=diff.format='summary' " ,
] ,
) ;
insta ::assert_snapshot! ( stdout , @ r ###"
@ a new commit
| M file1
o add a file
| A file1
2023-01-31 09:17:46 +00:00
o
2022-12-13 12:24:24 +00:00
" ###);
// `-p` enables default "color-words" diff output, so `--color-words` is noop
let stdout = test_env . jj_cmd_success (
& repo_path ,
& [ " log " , " -T " , " description " , " -p " , " --color-words " ] ,
) ;
insta ::assert_snapshot! ( stdout , @ r ###"
@ a new commit
| Modified regular file file1 :
| 1 1 : foo
| 2 : bar
o add a file
| Added regular file file1 :
| 1 : foo
2023-01-31 09:17:46 +00:00
o
2022-12-13 12:24:24 +00:00
" ###);
// `--git` enables git diff, so `-p` is noop
2022-03-28 09:12:08 +00:00
let stdout = test_env . jj_cmd_success (
& repo_path ,
& [ " log " , " -T " , " description " , " --no-graph " , " -p " , " --git " ] ,
) ;
insta ::assert_snapshot! ( stdout , @ r ###"
a new commit
diff - - git a / file1 b / file1
index 257 cc5642c .. . 3 bd1f0e297 100644
- - - a / file1
+ + + b / file1
@ @ - 1 , 1 + 1 , 2 @ @
foo
+ bar
add a file
diff - - git a / file1 b / file1
new file mode 100644
index 0000000000 .. 257 cc5642c
- - - / dev / null
+ + + b / file1
@ @ - 1 , 0 + 1 , 1 @ @
+ foo
" ###);
2022-05-13 05:20:10 +00:00
2022-12-13 12:24:24 +00:00
// Both formats enabled if `--git` and `--color-words` are explicitly specified
let stdout = test_env . jj_cmd_success (
& repo_path ,
& [
" log " ,
" -T " ,
" description " ,
" --no-graph " ,
" -p " ,
" --git " ,
" --color-words " ,
] ,
) ;
insta ::assert_snapshot! ( stdout , @ r ###"
a new commit
diff - - git a / file1 b / file1
index 257 cc5642c .. . 3 bd1f0e297 100644
- - - a / file1
+ + + b / file1
@ @ - 1 , 1 + 1 , 2 @ @
foo
+ bar
Modified regular file file1 :
1 1 : foo
2 : bar
add a file
diff - - git a / file1 b / file1
new file mode 100644
index 0000000000 .. 257 cc5642c
- - - / dev / null
+ + + b / file1
@ @ - 1 , 0 + 1 , 1 @ @
+ foo
Added regular file file1 :
1 : foo
" ###);
// `-s` with or without graph
2022-05-13 05:20:10 +00:00
let stdout = test_env . jj_cmd_success ( & repo_path , & [ " log " , " -T " , " description " , " -s " ] ) ;
insta ::assert_snapshot! ( stdout , @ r ###"
@ a new commit
| M file1
o add a file
| A file1
2023-01-31 09:17:46 +00:00
o
2022-05-13 05:20:10 +00:00
" ###);
let stdout = test_env . jj_cmd_success (
& repo_path ,
& [ " log " , " -T " , " description " , " --no-graph " , " -s " ] ,
) ;
insta ::assert_snapshot! ( stdout , @ r ###"
a new commit
M file1
add a file
A file1
" ###);
// `--git` implies `-p`, with or without graph
let stdout = test_env . jj_cmd_success (
& repo_path ,
& [ " log " , " -T " , " description " , " -r " , " @ " , " --git " ] ,
) ;
insta ::assert_snapshot! ( stdout , @ r ###"
@ a new commit
~ diff - - git a / file1 b / file1
index 257 cc5642c .. . 3 bd1f0e297 100644
- - - a / file1
+ + + b / file1
@ @ - 1 , 1 + 1 , 2 @ @
foo
+ bar
" ###);
let stdout = test_env . jj_cmd_success (
& repo_path ,
& [ " log " , " -T " , " description " , " -r " , " @ " , " --no-graph " , " --git " ] ,
) ;
insta ::assert_snapshot! ( stdout , @ r ###"
a new commit
diff - - git a / file1 b / file1
index 257 cc5642c .. . 3 bd1f0e297 100644
- - - a / file1
+ + + b / file1
@ @ - 1 , 1 + 1 , 2 @ @
foo
+ bar
" ###);
2022-12-14 10:48:53 +00:00
// `--color-words` implies `-p`, with or without graph
let stdout = test_env . jj_cmd_success (
& repo_path ,
& [ " log " , " -T " , " description " , " -r " , " @ " , " --color-words " ] ,
) ;
insta ::assert_snapshot! ( stdout , @ r ###"
@ a new commit
~ Modified regular file file1 :
1 1 : foo
2 : bar
" ###);
let stdout = test_env . jj_cmd_success (
& repo_path ,
& [
" log " ,
" -T " ,
" description " ,
" -r " ,
" @ " ,
" --no-graph " ,
" --color-words " ,
] ,
) ;
insta ::assert_snapshot! ( stdout , @ r ###"
a new commit
Modified regular file file1 :
1 1 : foo
2 : bar
" ###);
2022-03-28 09:12:08 +00:00
}
2022-05-09 17:38:23 +00:00
2023-01-03 00:24:00 +00:00
#[ test ]
2023-01-21 04:56:34 +00:00
fn test_log_prefix_highlight_brackets ( ) {
2023-01-03 00:24:00 +00:00
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 " ) ;
2023-01-21 04:56:34 +00:00
fn prefix_format ( len : Option < usize > ) -> String {
format! (
r #"
" Change " change_id . shortest_prefix_and_brackets ( { 0 } ) " " description . first_line ( )
" " commit_id . shortest_prefix_and_brackets ( { 0 } ) " " branches
" #,
len . map ( | l | l . to_string ( ) ) . unwrap_or ( String ::default ( ) )
)
}
2023-01-03 00:24:00 +00:00
std ::fs ::write ( repo_path . join ( " file " ) , " original file \n " ) . unwrap ( ) ;
test_env . jj_cmd_success ( & repo_path , & [ " describe " , " -m " , " initial " ] ) ;
test_env . jj_cmd_success ( & repo_path , & [ " branch " , " c " , " original " ] ) ;
insta ::assert_snapshot! (
2023-02-06 05:38:54 +00:00
test_env . jj_cmd_success ( & repo_path , & [ " log " , " -r " , " original " , " -T " , & prefix_format ( Some ( 12 ) ) ] ) ,
2023-01-03 00:24:00 +00:00
@ r ###"
2023-01-21 04:56:34 +00:00
@ Change 9 [ a45c67d3e96 ] initial b [ a1a30916d29 ] original
2023-01-03 00:24:00 +00:00
~
" ###
) ;
for i in 1 .. 50 {
test_env . jj_cmd_success ( & repo_path , & [ " new " , " -m " , & format! ( " commit {i} " ) ] ) ;
std ::fs ::write ( repo_path . join ( " file " ) , format! ( " file {i} \n " ) ) . unwrap ( ) ;
}
insta ::assert_snapshot! (
2023-02-06 05:38:54 +00:00
test_env . jj_cmd_success ( & repo_path , & [ " log " , " -r " , " original " , " -T " , & prefix_format ( Some ( 12 ) ) ] ) ,
2023-01-21 04:56:34 +00:00
@ r ###"
o Change 9 a4 [ 5 c67d3e96 ] initial ba1 [ a30916d29 ] original
~
" ###
) ;
insta ::assert_snapshot! (
2023-02-06 05:38:54 +00:00
test_env . jj_cmd_success ( & repo_path , & [ " log " , " -r " , " @-----------..@ " , " -T " , & prefix_format ( Some ( 12 ) ) ] ) ,
2023-01-03 00:24:00 +00:00
@ r ###"
2023-01-21 04:56:34 +00:00
@ Change 4 c9 [ 32 da80131 ] commit49 d8 [ 3437 a2ceff ]
o Change 0 d [ 58 f15eaba6 ] commit48 f3 [ abb4ea0ac3 ]
o Change fc [ e6c2c59123 ] commit47 38 e [ 891 bea27b ]
o Change d5 [ 1 defcac305 ] commit46 1 c [ 04 d947707a ]
o Change 4 f [ 13 b1391d68 ] commit45 747 [ 24 ae22b1e ]
o Change 6 a [ de2950a042 ] commit44 c7a [ a67cf7bbd ]
o Change 06 c [ 482e452 d3 ] commit43 8 e [ c99dfcb6c7 ]
o Change 392 [ beeb018eb ] commit42 8 f0 [ e60411b78 ]
o Change a1 [ b73d3ff916 ] commit41 71 [ d6937a66c3 ]
o Change 708 [ 8 f461291f ] commit40 db [ 5720490266 ]
o Change c49 [ f7f006c77 ] commit39 d94 [ 54 fec8a69 ]
2023-01-03 00:24:00 +00:00
~
" ###
) ;
insta ::assert_snapshot! (
2023-01-21 04:56:34 +00:00
test_env . jj_cmd_success ( & repo_path , & [ " log " , " -r " , " @-----------..@ " , " -T " , & prefix_format ( Some ( 3 ) ) ] ) ,
@ r ###"
@ Change 4 c9 commit49 d8 [ 3 ]
o Change 0 d [ 5 ] commit48 f3 [ a ]
o Change fc [ e ] commit47 38 e
o Change d5 [ 1 ] commit46 1 c [ 0 ]
o Change 4 f [ 1 ] commit45 747
o Change 6 a [ d ] commit44 c7a
o Change 06 c commit43 8 e [ c ]
o Change 392 commit42 8 f0
o Change a1 [ b ] commit41 71 [ d ]
o Change 708 commit40 db [ 5 ]
o Change c49 commit39 d94
~
" ###
) ;
insta ::assert_snapshot! (
2023-02-06 05:38:54 +00:00
test_env . jj_cmd_success ( & repo_path , & [ " log " , " -r " , " @-----------..@ " , " -T " , & prefix_format ( None ) ] ) ,
2023-01-21 04:56:34 +00:00
@ r ###"
@ Change 4 c9 commit49 d8
o Change 0 d commit48 f3
o Change fc commit47 38 e
o Change d5 commit46 1 c
o Change 4 f commit45 747
o Change 6 a commit44 c7a
o Change 06 c commit43 8 e
o Change 392 commit42 8 f0
o Change a1 commit41 71
o Change 708 commit40 db
o Change c49 commit39 d94
~
" ###
) ;
}
#[ test ]
fn test_log_prefix_highlight_styled ( ) {
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 " ) ;
fn prefix_format ( len : Option < usize > ) -> String {
format! (
r #"
" Change " change_id . shortest_styled_prefix ( { 0 } ) " " description . first_line ( )
" " commit_id . shortest_styled_prefix ( { 0 } ) " " branches
" #,
len . map ( | l | l . to_string ( ) ) . unwrap_or ( String ::default ( ) )
)
}
std ::fs ::write ( repo_path . join ( " file " ) , " original file \n " ) . unwrap ( ) ;
test_env . jj_cmd_success ( & repo_path , & [ " describe " , " -m " , " initial " ] ) ;
test_env . jj_cmd_success ( & repo_path , & [ " branch " , " c " , " original " ] ) ;
insta ::assert_snapshot! (
2023-02-06 05:38:54 +00:00
test_env . jj_cmd_success ( & repo_path , & [ " log " , " -r " , " original " , " -T " , & prefix_format ( Some ( 12 ) ) ] ) ,
2023-01-21 04:56:34 +00:00
@ r ###"
@ Change 9 a45c67d3e96 initial ba1a30916d29 original
~
" ###
) ;
for i in 1 .. 50 {
test_env . jj_cmd_success ( & repo_path , & [ " new " , " -m " , & format! ( " commit {i} " ) ] ) ;
std ::fs ::write ( repo_path . join ( " file " ) , format! ( " file {i} \n " ) ) . unwrap ( ) ;
}
insta ::assert_snapshot! (
2023-02-06 05:38:54 +00:00
test_env . jj_cmd_success ( & repo_path , & [ " log " , " -r " , " original " , " -T " , & prefix_format ( Some ( 12 ) ) ] ) ,
2023-01-21 04:56:34 +00:00
@ r ###"
o Change 9 a45c67d3e96 initial ba1a30916d29 original
~
" ###
) ;
let stdout = test_env . jj_cmd_success (
& repo_path ,
& [
" --color=always " ,
" log " ,
" -r " ,
" @-----------..@ " ,
" -T " ,
2023-02-06 05:38:54 +00:00
& prefix_format ( Some ( 12 ) ) ,
2023-01-21 04:56:34 +00:00
] ,
) ;
insta ::assert_snapshot! ( stdout ,
@ r ###"
@ Change [ 1 m [ 38 ; 5 ; 5 m4c9 [ 0 m [ 38 ; 5 ; 8 m32da80131 [ 39 m commit49 [ 1 m [ 38 ; 5 ; 4 md8 [ 0 m [ 38 ; 5 ; 8 m3437a2ceff [ 39 m
o Change [ 1 m [ 38 ; 5 ; 5 m0d [ 0 m [ 38 ; 5 ; 8 m58f15eaba6 [ 39 m commit48 [ 1 m [ 38 ; 5 ; 4 mf3 [ 0 m [ 38 ; 5 ; 8 mabb4ea0ac3 [ 39 m
o Change [ 1 m [ 38 ; 5 ; 5 mfc [ 0 m [ 38 ; 5 ; 8 me6c2c59123 [ 39 m commit47 [ 1 m [ 38 ; 5 ; 4 m38e [ 0 m [ 38 ; 5 ; 8 m891bea27b [ 39 m
o Change [ 1 m [ 38 ; 5 ; 5 md5 [ 0 m [ 38 ; 5 ; 8 m1defcac305 [ 39 m commit46 [ 1 m [ 38 ; 5 ; 4 m1c [ 0 m [ 38 ; 5 ; 8 m04d947707a [ 39 m
o Change [ 1 m [ 38 ; 5 ; 5 m4f [ 0 m [ 38 ; 5 ; 8 m13b1391d68 [ 39 m commit45 [ 1 m [ 38 ; 5 ; 4 m747 [ 0 m [ 38 ; 5 ; 8 m24ae22b1e [ 39 m
o Change [ 1 m [ 38 ; 5 ; 5 m6a [ 0 m [ 38 ; 5 ; 8 mde2950a042 [ 39 m commit44 [ 1 m [ 38 ; 5 ; 4 mc7a [ 0 m [ 38 ; 5 ; 8 ma67cf7bbd [ 39 m
o Change [ 1 m [ 38 ; 5 ; 5 m06c [ 0 m [ 38 ; 5 ; 8 m482e452d3 [ 39 m commit43 [ 1 m [ 38 ; 5 ; 4 m8e [ 0 m [ 38 ; 5 ; 8 mc99dfcb6c7 [ 39 m
o Change [ 1 m [ 38 ; 5 ; 5 m392 [ 0 m [ 38 ; 5 ; 8 mbeeb018eb [ 39 m commit42 [ 1 m [ 38 ; 5 ; 4 m8f0 [ 0 m [ 38 ; 5 ; 8 me60411b78 [ 39 m
o Change [ 1 m [ 38 ; 5 ; 5 ma1 [ 0 m [ 38 ; 5 ; 8 mb73d3ff916 [ 39 m commit41 [ 1 m [ 38 ; 5 ; 4 m71 [ 0 m [ 38 ; 5 ; 8 md6937a66c3 [ 39 m
o Change [ 1 m [ 38 ; 5 ; 5 m708 [ 0 m [ 38 ; 5 ; 8 m8f461291f [ 39 m commit40 [ 1 m [ 38 ; 5 ; 4 mdb [ 0 m [ 38 ; 5 ; 8 m5720490266 [ 39 m
o Change [ 1 m [ 38 ; 5 ; 5 mc49 [ 0 m [ 38 ; 5 ; 8 mf7f006c77 [ 39 m commit39 [ 1 m [ 38 ; 5 ; 4 md94 [ 0 m [ 38 ; 5 ; 8 m54fec8a69 [ 39 m
~
" ###
) ;
let stdout = test_env . jj_cmd_success (
& repo_path ,
& [
" --color=always " ,
" log " ,
" -r " ,
" @-----------..@ " ,
" -T " ,
& prefix_format ( Some ( 3 ) ) ,
] ,
) ;
insta ::assert_snapshot! ( stdout ,
@ r ###"
@ Change [ 1 m [ 38 ; 5 ; 5 m4c9 [ 0 m commit49 [ 1 m [ 38 ; 5 ; 4 md8 [ 0 m [ 38 ; 5 ; 8 m3 [ 39 m
o Change [ 1 m [ 38 ; 5 ; 5 m0d [ 0 m [ 38 ; 5 ; 8 m5 [ 39 m commit48 [ 1 m [ 38 ; 5 ; 4 mf3 [ 0 m [ 38 ; 5 ; 8 ma [ 39 m
o Change [ 1 m [ 38 ; 5 ; 5 mfc [ 0 m [ 38 ; 5 ; 8 me [ 39 m commit47 [ 1 m [ 38 ; 5 ; 4 m38e [ 0 m
o Change [ 1 m [ 38 ; 5 ; 5 md5 [ 0 m [ 38 ; 5 ; 8 m1 [ 39 m commit46 [ 1 m [ 38 ; 5 ; 4 m1c [ 0 m [ 38 ; 5 ; 8 m0 [ 39 m
o Change [ 1 m [ 38 ; 5 ; 5 m4f [ 0 m [ 38 ; 5 ; 8 m1 [ 39 m commit45 [ 1 m [ 38 ; 5 ; 4 m747 [ 0 m
o Change [ 1 m [ 38 ; 5 ; 5 m6a [ 0 m [ 38 ; 5 ; 8 md [ 39 m commit44 [ 1 m [ 38 ; 5 ; 4 mc7a [ 0 m
o Change [ 1 m [ 38 ; 5 ; 5 m06c [ 0 m commit43 [ 1 m [ 38 ; 5 ; 4 m8e [ 0 m [ 38 ; 5 ; 8 mc [ 39 m
o Change [ 1 m [ 38 ; 5 ; 5 m392 [ 0 m commit42 [ 1 m [ 38 ; 5 ; 4 m8f0 [ 0 m
o Change [ 1 m [ 38 ; 5 ; 5 ma1 [ 0 m [ 38 ; 5 ; 8 mb [ 39 m commit41 [ 1 m [ 38 ; 5 ; 4 m71 [ 0 m [ 38 ; 5 ; 8 md [ 39 m
o Change [ 1 m [ 38 ; 5 ; 5 m708 [ 0 m commit40 [ 1 m [ 38 ; 5 ; 4 mdb [ 0 m [ 38 ; 5 ; 8 m5 [ 39 m
o Change [ 1 m [ 38 ; 5 ; 5 mc49 [ 0 m commit39 [ 1 m [ 38 ; 5 ; 4 md94 [ 0 m
~
" ###
) ;
let stdout = test_env . jj_cmd_success (
& repo_path ,
& [
" --color=always " ,
" log " ,
" -r " ,
" @-----------..@ " ,
" -T " ,
2023-02-06 05:38:54 +00:00
& prefix_format ( None ) ,
2023-01-21 04:56:34 +00:00
] ,
) ;
insta ::assert_snapshot! ( stdout ,
2023-01-03 00:24:00 +00:00
@ r ###"
2023-01-21 04:56:34 +00:00
@ Change [ 1 m [ 38 ; 5 ; 5 m4c9 [ 0 m commit49 [ 1 m [ 38 ; 5 ; 4 md8 [ 0 m
o Change [ 1 m [ 38 ; 5 ; 5 m0d [ 0 m commit48 [ 1 m [ 38 ; 5 ; 4 mf3 [ 0 m
o Change [ 1 m [ 38 ; 5 ; 5 mfc [ 0 m commit47 [ 1 m [ 38 ; 5 ; 4 m38e [ 0 m
o Change [ 1 m [ 38 ; 5 ; 5 md5 [ 0 m commit46 [ 1 m [ 38 ; 5 ; 4 m1c [ 0 m
o Change [ 1 m [ 38 ; 5 ; 5 m4f [ 0 m commit45 [ 1 m [ 38 ; 5 ; 4 m747 [ 0 m
o Change [ 1 m [ 38 ; 5 ; 5 m6a [ 0 m commit44 [ 1 m [ 38 ; 5 ; 4 mc7a [ 0 m
o Change [ 1 m [ 38 ; 5 ; 5 m06c [ 0 m commit43 [ 1 m [ 38 ; 5 ; 4 m8e [ 0 m
o Change [ 1 m [ 38 ; 5 ; 5 m392 [ 0 m commit42 [ 1 m [ 38 ; 5 ; 4 m8f0 [ 0 m
o Change [ 1 m [ 38 ; 5 ; 5 ma1 [ 0 m commit41 [ 1 m [ 38 ; 5 ; 4 m71 [ 0 m
o Change [ 1 m [ 38 ; 5 ; 5 m708 [ 0 m commit40 [ 1 m [ 38 ; 5 ; 4 mdb [ 0 m
o Change [ 1 m [ 38 ; 5 ; 5 mc49 [ 0 m commit39 [ 1 m [ 38 ; 5 ; 4 md94 [ 0 m
2023-01-03 00:24:00 +00:00
~
" ###
) ;
}
#[ test ]
fn test_log_prefix_highlight_counts_hidden_commits ( ) {
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 " ) ;
let prefix_format = r #"
2023-02-06 05:38:54 +00:00
" Change " change_id . shortest_prefix_and_brackets ( 12 ) " " description . first_line ( )
" " commit_id . shortest_prefix_and_brackets ( 12 ) " " branches
2023-01-03 00:24:00 +00:00
" #;
std ::fs ::write ( repo_path . join ( " file " ) , " original file \n " ) . unwrap ( ) ;
test_env . jj_cmd_success ( & repo_path , & [ " describe " , " -m " , " initial " ] ) ;
test_env . jj_cmd_success ( & repo_path , & [ " branch " , " c " , " original " ] ) ;
insta ::assert_snapshot! (
test_env . jj_cmd_success ( & repo_path , & [ " log " , " -r " , " all() " , " -T " , prefix_format ] ) ,
@ r ###"
2023-01-21 04:56:34 +00:00
@ Change 9 [ a45c67d3e96 ] initial b [ a1a30916d29 ] original
o Change 0 [ 00000000000 ] 0 [ 00000000000 ]
2023-01-03 00:24:00 +00:00
" ###
) ;
for i in 1 .. 100 {
test_env . jj_cmd_success ( & repo_path , & [ " describe " , " -m " , & format! ( " commit {i} " ) ] ) ;
std ::fs ::write ( repo_path . join ( " file " ) , format! ( " file {i} \n " ) ) . unwrap ( ) ;
}
// The first commit still exists. Its unique prefix became longer.
insta ::assert_snapshot! (
test_env . jj_cmd_success ( & repo_path , & [ " log " , " -r " , " ba1 " , " -T " , prefix_format ] ) ,
@ r ###"
2023-01-21 04:56:34 +00:00
o Change 9 a4 [ 5 c67d3e96 ] initial ba1 [ a30916d29 ]
2023-01-03 00:24:00 +00:00
~
" ###
) ;
// The first commit is no longer visible
insta ::assert_snapshot! (
test_env . jj_cmd_success ( & repo_path , & [ " log " , " -r " , " all() " , " -T " , prefix_format ] ) ,
@ r ###"
2023-01-21 04:56:34 +00:00
@ Change 9 a4 [ 5 c67d3e96 ] commit99 de [ 3177 d2acf2 ] original
o Change 000 [ 000000000 ] 000 [ 000000000 ]
2023-01-03 00:24:00 +00:00
" ###
) ;
insta ::assert_snapshot! (
test_env . jj_cmd_failure ( & repo_path , & [ " log " , " -r " , " d " , " -T " , prefix_format ] ) ,
@ r ###"
Error : Commit or change id prefix " d " is ambiguous
" ###
) ;
insta ::assert_snapshot! (
test_env . jj_cmd_success ( & repo_path , & [ " log " , " -r " , " de " , " -T " , prefix_format ] ) ,
@ r ###"
2023-01-21 04:56:34 +00:00
@ Change 9 a4 [ 5 c67d3e96 ] commit99 de [ 3177 d2acf2 ] original
2023-01-03 00:24:00 +00:00
~
" ###
) ;
}
2023-01-02 07:09:38 +00:00
#[ 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
2023-01-31 09:17:46 +00:00
o
2023-01-02 07:09:38 +00:00
" ###);
// 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 !
| /
2023-01-31 09:17:46 +00:00
o
2023-01-02 07:09:38 +00:00
" ###);
}
2022-05-09 17:38:23 +00:00
#[ test ]
fn test_log_reversed ( ) {
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 " ) ;
test_env . jj_cmd_success ( & repo_path , & [ " describe " , " -m " , " first " ] ) ;
test_env . jj_cmd_success ( & repo_path , & [ " new " , " -m " , " second " ] ) ;
let stdout = test_env . jj_cmd_success ( & repo_path , & [ " log " , " -T " , " description " , " --reversed " ] ) ;
insta ::assert_snapshot! ( stdout , @ r ###"
2023-01-31 09:17:46 +00:00
o
2022-05-09 17:38:23 +00:00
o first
@ second
" ###);
let stdout = test_env . jj_cmd_success (
& repo_path ,
& [ " log " , " -T " , " description " , " --reversed " , " --no-graph " ] ,
) ;
insta ::assert_snapshot! ( stdout , @ r ###"
first
second
" ###);
}
2022-09-13 07:26:23 +00:00
#[ test ]
fn test_log_filtered_by_path ( ) {
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 ( " file1 " ) , " foo \n " ) . unwrap ( ) ;
test_env . jj_cmd_success ( & repo_path , & [ " describe " , " -m " , " first " ] ) ;
test_env . jj_cmd_success ( & repo_path , & [ " new " , " -m " , " second " ] ) ;
std ::fs ::write ( repo_path . join ( " file1 " ) , " foo \n bar \n " ) . unwrap ( ) ;
std ::fs ::write ( repo_path . join ( " file2 " ) , " baz \n " ) . unwrap ( ) ;
let stdout = test_env . jj_cmd_success ( & repo_path , & [ " log " , " -T " , " description " , " file1 " ] ) ;
insta ::assert_snapshot! ( stdout , @ r ###"
@ second
o first
~
" ###);
let stdout = test_env . jj_cmd_success ( & repo_path , & [ " log " , " -T " , " description " , " file2 " ] ) ;
insta ::assert_snapshot! ( stdout , @ r ###"
@ second
~
" ###);
let stdout = test_env . jj_cmd_success ( & repo_path , & [ " log " , " -T " , " description " , " -s " , " file1 " ] ) ;
insta ::assert_snapshot! ( stdout , @ r ###"
@ second
| M file1
o first
~ A file1
" ###);
let stdout = test_env . jj_cmd_success (
& repo_path ,
& [ " log " , " -T " , " description " , " -s " , " file2 " , " --no-graph " ] ,
) ;
insta ::assert_snapshot! ( stdout , @ r ###"
second
A file2
" ###);
2022-10-23 04:14:00 +00:00
// file() revset doesn't filter the diff.
let stdout = test_env . jj_cmd_success (
& repo_path ,
& [
" log " ,
" -T " ,
" description " ,
" -s " ,
" -rfile(file2) " ,
" --no-graph " ,
] ,
) ;
insta ::assert_snapshot! ( stdout , @ r ###"
second
M file1
A file2
" ###);
2022-09-13 07:26:23 +00:00
}
2022-10-01 15:09:32 +00:00
2022-11-18 23:41:35 +00:00
#[ test ]
fn test_log_warn_path_might_be_revset ( ) {
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 ( " file1 " ) , " foo \n " ) . unwrap ( ) ;
// Don't warn if the file actually exists.
let assert = test_env
. jj_cmd ( & repo_path , & [ " log " , " file1 " , " -T " , " description " ] )
. assert ( )
. success ( ) ;
insta ::assert_snapshot! ( get_stdout_string ( & assert ) , @ r ###"
2023-01-31 09:17:46 +00:00
@
2022-11-18 23:41:35 +00:00
~
" ###);
insta ::assert_snapshot! ( get_stderr_string ( & assert ) , @ " " ) ;
// Warn for `jj log .` specifically, for former Mercurial users.
let assert = test_env
. jj_cmd ( & repo_path , & [ " log " , " . " , " -T " , " description " ] )
. assert ( )
. success ( ) ;
insta ::assert_snapshot! ( get_stdout_string ( & assert ) , @ r ###"
2023-01-31 09:17:46 +00:00
@
2022-11-18 23:41:35 +00:00
~
" ###);
insta ::assert_snapshot! ( get_stderr_string ( & assert ) , @ r ### "warning: The argument "." is being interpreted as a path, but this is often not useful because all non-empty commits touch '.'. If you meant to show the working copy commit, pass -r '@' instead."### ) ;
// ...but checking `jj log .` makes sense in a subdirectory.
let subdir = repo_path . join ( " dir " ) ;
std ::fs ::create_dir_all ( & subdir ) . unwrap ( ) ;
let assert = test_env . jj_cmd ( & subdir , & [ " log " , " . " ] ) . assert ( ) . success ( ) ;
insta ::assert_snapshot! ( get_stdout_string ( & assert ) , @ " " ) ;
insta ::assert_snapshot! ( get_stderr_string ( & assert ) , @ " " ) ;
// Warn for `jj log @` instead of `jj log -r @`.
let assert = test_env
. jj_cmd ( & repo_path , & [ " log " , " @ " , " -T " , " description " ] )
. assert ( )
. success ( ) ;
insta ::assert_snapshot! ( get_stdout_string ( & assert ) , @ " " ) ;
insta ::assert_snapshot! ( get_stderr_string ( & assert ) , @ r ###"
warning : The argument " @ " is being interpreted as a path . To specify a revset , pass - r " @ " instead .
" ###);
// Warn when there's no path with the provided name.
let assert = test_env
. jj_cmd ( & repo_path , & [ " log " , " file2 " , " -T " , " description " ] )
. assert ( )
. success ( ) ;
insta ::assert_snapshot! ( get_stdout_string ( & assert ) , @ " " ) ;
insta ::assert_snapshot! ( get_stderr_string ( & assert ) , @ r ###"
warning : The argument " file2 " is being interpreted as a path . To specify a revset , pass - r " file2 " instead .
" ###);
// If an explicit revision is provided, then suppress the warning.
let assert = test_env
. jj_cmd ( & repo_path , & [ " log " , " @ " , " -r " , " @ " , " -T " , " description " ] )
. assert ( )
. success ( ) ;
insta ::assert_snapshot! ( get_stdout_string ( & assert ) , @ " " ) ;
insta ::assert_snapshot! ( get_stderr_string ( & assert ) , @ r ###"
" ###);
}
2022-10-01 15:09:32 +00:00
#[ test ]
fn test_default_revset ( ) {
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 ( " file1 " ) , " foo \n " ) . unwrap ( ) ;
test_env . jj_cmd_success ( & repo_path , & [ " describe " , " -m " , " add a file " ] ) ;
// Set configuration to only show the root commit.
2023-01-26 19:26:18 +00:00
test_env . add_config ( r # "ui.default-revset = "root""# ) ;
2022-10-01 15:09:32 +00:00
// Log should only contain one line (for the root commit), and not show the
// commit created above.
assert_eq! (
1 ,
test_env
. jj_cmd_success ( & repo_path , & [ " log " , " -T " , " commit_id " ] )
. lines ( )
. count ( )
) ;
}
2022-11-26 01:33:24 +00:00
2023-01-02 05:18:38 +00:00
#[ test ]
fn test_default_revset_per_repo ( ) {
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 ( " file1 " ) , " foo \n " ) . unwrap ( ) ;
test_env . jj_cmd_success ( & repo_path , & [ " describe " , " -m " , " add a file " ] ) ;
// Set configuration to only show the root commit.
std ::fs ::write (
repo_path . join ( " .jj/repo/config.toml " ) ,
r # "ui.default-revset = "root""# ,
)
. unwrap ( ) ;
// Log should only contain one line (for the root commit), and not show the
// commit created above.
assert_eq! (
1 ,
test_env
. jj_cmd_success ( & repo_path , & [ " log " , " -T " , " commit_id " ] )
. lines ( )
. count ( )
) ;
}
2023-01-13 07:55:52 +00:00
#[ test ]
fn test_graph_template_color ( ) {
// Test that color codes from a multi-line template don't span the graph lines.
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 " ) ;
test_env . jj_cmd_success (
& repo_path ,
& [ " describe " , " -m " , " first line \n second line \n third line " ] ,
) ;
test_env . jj_cmd_success ( & repo_path , & [ " new " , " -m " , " single line " ] ) ;
test_env . add_config (
2023-01-26 19:26:18 +00:00
r #" [colors]
2023-01-13 07:55:52 +00:00
description = " red "
" working_copy description " = " green "
" #,
) ;
// First test without color for comparison
2023-02-03 03:49:40 +00:00
let template = r # "label(if(current_working_copy, "working_copy"), description)"# ;
let stdout = test_env . jj_cmd_success ( & repo_path , & [ " log " , " -T " , template ] ) ;
2023-01-13 07:55:52 +00:00
insta ::assert_snapshot! ( stdout , @ r ###"
@ single line
o first line
| second line
| third line
2023-01-31 09:17:46 +00:00
o
2023-01-13 07:55:52 +00:00
" ###);
2023-02-03 03:49:40 +00:00
let stdout = test_env . jj_cmd_success ( & repo_path , & [ " --color=always " , " log " , " -T " , template ] ) ;
2023-01-13 07:55:52 +00:00
insta ::assert_snapshot! ( stdout , @ r ###"
2023-01-13 18:09:09 +00:00
@ [ 1 m [ 38 ; 5 ; 2 msingle line [ 0 m
o [ 38 ; 5 ; 1 mfirst line [ 39 m
| [ 38 ; 5 ; 1 msecond line [ 39 m
| [ 38 ; 5 ; 1 mthird line [ 39 m
2023-01-31 09:17:46 +00:00
o
2023-01-13 07:55:52 +00:00
" ###);
}
2023-01-27 06:33:24 +00:00
#[ test ]
fn test_graph_styles ( ) {
// Test that different graph styles are available.
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 " ) ;
test_env . jj_cmd_success ( & repo_path , & [ " commit " , " -m " , " initial " ] ) ;
test_env . jj_cmd_success ( & repo_path , & [ " commit " , " -m " , " main branch 1 " ] ) ;
test_env . jj_cmd_success ( & repo_path , & [ " describe " , " -m " , " main branch 2 " ] ) ;
test_env . jj_cmd_success (
& repo_path ,
& [ " new " , " -m " , " side branch \n with \n long \n description " ] ,
) ;
test_env . jj_cmd_success (
& repo_path ,
& [ " new " , " -m " , " merge " , r # "description("main branch 1")"# , " @ " ] ,
) ;
// Default (legacy) style
let stdout = test_env . jj_cmd_success ( & repo_path , & [ " log " , " -T=description " ] ) ;
insta ::assert_snapshot! ( stdout , @ r ###"
@ merge
| \
o | side branch
| | with
| | long
| | description
o | main branch 2
| /
o main branch 1
o initial
2023-01-31 09:17:46 +00:00
o
2023-01-27 06:33:24 +00:00
" ###);
// ASCII style
2023-01-27 18:15:51 +00:00
test_env . add_config ( r # "ui.graph.style = "ascii""# ) ;
2023-01-27 06:33:24 +00:00
let stdout = test_env . jj_cmd_success ( & repo_path , & [ " log " , " -T=description " ] ) ;
insta ::assert_snapshot! ( stdout , @ r ###"
@ merge
| \
o | side branch
| | with
| | long
| | description
o | main branch 2
| /
o main branch 1
o initial
2023-01-31 09:17:46 +00:00
o
2023-01-27 06:33:24 +00:00
" ###);
// Large ASCII style
2023-01-27 18:15:51 +00:00
test_env . add_config ( r # "ui.graph.style = "ascii-large""# ) ;
2023-01-27 06:33:24 +00:00
let stdout = test_env . jj_cmd_success ( & repo_path , & [ " log " , " -T=description " ] ) ;
insta ::assert_snapshot! ( stdout , @ r ###"
@ merge
| \
| \
o | side branch
| | with
| | long
| | description
o | main branch 2
| /
| /
o main branch 1
o initial
2023-01-31 09:17:46 +00:00
o
2023-01-27 06:33:24 +00:00
" ###);
// Curved style
2023-01-27 18:15:51 +00:00
test_env . add_config ( r # "ui.graph.style = "curved""# ) ;
2023-01-27 06:33:24 +00:00
let stdout = test_env . jj_cmd_success ( & repo_path , & [ " log " , " -T=description " ] ) ;
insta ::assert_snapshot! ( stdout , @ r ###"
@ merge
├ ─ ╮
o │ side branch
│ │ with
│ │ long
│ │ description
o │ main branch 2
├ ─ ╯
o main branch 1
o initial
2023-01-31 09:17:46 +00:00
o
2023-01-27 06:33:24 +00:00
" ###);
// Square style
2023-01-27 18:15:51 +00:00
test_env . add_config ( r # "ui.graph.style = "square""# ) ;
2023-01-27 06:33:24 +00:00
let stdout = test_env . jj_cmd_success ( & repo_path , & [ " log " , " -T=description " ] ) ;
insta ::assert_snapshot! ( stdout , @ r ###"
@ merge
├ ─ ┐
o │ side branch
│ │ with
│ │ long
│ │ description
o │ main branch 2
├ ─ ┘
o main branch 1
o initial
2023-01-31 09:17:46 +00:00
o
2023-01-27 06:33:24 +00:00
" ###);
}