Junio C Hamano | b468f0c | 2007-11-22 16:21:49 -0800 | [diff] [blame] | 1 | #!/bin/sh |
| 2 | |
| 3 | test_description='git commit porcelain-ish' |
| 4 | |
| 5 | . ./test-lib.sh |
| 6 | |
Ralf Thielow | 51fb3a3 | 2013-01-10 18:45:59 +0100 | [diff] [blame] | 7 | commit_msg_is () { |
| 8 | expect=commit_msg_is.expect |
| 9 | actual=commit_msg_is.actual |
| 10 | |
| 11 | printf "%s" "$(git log --pretty=format:%s%b -1)" >$actual && |
| 12 | printf "%s" "$1" >$expect && |
| 13 | test_i18ncmp $expect $actual |
| 14 | } |
| 15 | |
Tay Ray Chuan | cee9f2b | 2010-05-27 23:34:51 +0800 | [diff] [blame] | 16 | # Arguments: [<prefix] [<commit message>] [<commit options>] |
Tay Ray Chuan | fc6fa0d | 2010-05-27 23:34:50 +0800 | [diff] [blame] | 17 | check_summary_oneline() { |
| 18 | test_tick && |
Tay Ray Chuan | cee9f2b | 2010-05-27 23:34:51 +0800 | [diff] [blame] | 19 | git commit ${3+"$3"} -m "$2" | head -1 > act && |
Tay Ray Chuan | fc6fa0d | 2010-05-27 23:34:50 +0800 | [diff] [blame] | 20 | |
| 21 | # branch name |
| 22 | SUMMARY_PREFIX="$(git name-rev --name-only HEAD)" && |
| 23 | |
| 24 | # append the "special" prefix, like "root-commit", "detached HEAD" |
| 25 | if test -n "$1" |
| 26 | then |
| 27 | SUMMARY_PREFIX="$SUMMARY_PREFIX ($1)" |
| 28 | fi |
| 29 | |
| 30 | # abbrev SHA-1 |
| 31 | SUMMARY_POSTFIX="$(git log -1 --pretty='format:%h')" |
| 32 | echo "[$SUMMARY_PREFIX $SUMMARY_POSTFIX] $2" >exp && |
| 33 | |
Junio C Hamano | f79ce8d | 2011-04-13 16:17:50 -0700 | [diff] [blame] | 34 | test_i18ncmp exp act |
Tay Ray Chuan | fc6fa0d | 2010-05-27 23:34:50 +0800 | [diff] [blame] | 35 | } |
| 36 | |
| 37 | test_expect_success 'output summary format' ' |
| 38 | |
| 39 | echo new >file1 && |
| 40 | git add file1 && |
| 41 | check_summary_oneline "root-commit" "initial" && |
| 42 | |
| 43 | echo change >>file1 && |
Ævar Arnfjörð Bjarmason | 7f5673d | 2011-02-22 23:41:47 +0000 | [diff] [blame] | 44 | git add file1 |
| 45 | ' |
| 46 | |
| 47 | test_expect_success 'output summary format: root-commit' ' |
Tay Ray Chuan | fc6fa0d | 2010-05-27 23:34:50 +0800 | [diff] [blame] | 48 | check_summary_oneline "" "a change" |
| 49 | ' |
| 50 | |
Tay Ray Chuan | a45e1a8 | 2010-06-12 22:15:39 +0800 | [diff] [blame] | 51 | test_expect_success 'output summary format for commit with an empty diff' ' |
Tay Ray Chuan | cee9f2b | 2010-05-27 23:34:51 +0800 | [diff] [blame] | 52 | |
| 53 | check_summary_oneline "" "empty" "--allow-empty" |
| 54 | ' |
| 55 | |
Tay Ray Chuan | a45e1a8 | 2010-06-12 22:15:39 +0800 | [diff] [blame] | 56 | test_expect_success 'output summary format for merges' ' |
Tay Ray Chuan | cee9f2b | 2010-05-27 23:34:51 +0800 | [diff] [blame] | 57 | |
| 58 | git checkout -b recursive-base && |
| 59 | test_commit base file1 && |
| 60 | |
| 61 | git checkout -b recursive-a recursive-base && |
| 62 | test_commit commit-a file1 && |
| 63 | |
| 64 | git checkout -b recursive-b recursive-base && |
| 65 | test_commit commit-b file1 && |
| 66 | |
| 67 | # conflict |
| 68 | git checkout recursive-a && |
| 69 | test_must_fail git merge recursive-b && |
| 70 | # resolve the conflict |
| 71 | echo commit-a > file1 && |
| 72 | git add file1 && |
| 73 | check_summary_oneline "" "Merge" |
| 74 | ' |
| 75 | |
Tay Ray Chuan | fc6fa0d | 2010-05-27 23:34:50 +0800 | [diff] [blame] | 76 | output_tests_cleanup() { |
| 77 | # this is needed for "do not fire editor in the presence of conflicts" |
| 78 | git checkout master && |
| 79 | |
| 80 | # this is needed for the "partial removal" test to pass |
| 81 | git rm file1 && |
| 82 | git commit -m "cleanup" |
| 83 | } |
| 84 | |
Junio C Hamano | b468f0c | 2007-11-22 16:21:49 -0800 | [diff] [blame] | 85 | test_expect_success 'the basics' ' |
| 86 | |
Tay Ray Chuan | fc6fa0d | 2010-05-27 23:34:50 +0800 | [diff] [blame] | 87 | output_tests_cleanup && |
| 88 | |
Junio C Hamano | b468f0c | 2007-11-22 16:21:49 -0800 | [diff] [blame] | 89 | echo doing partial >"commit is" && |
| 90 | mkdir not && |
| 91 | echo very much encouraged but we should >not/forbid && |
| 92 | git add "commit is" not && |
| 93 | echo update added "commit is" file >"commit is" && |
| 94 | echo also update another >not/forbid && |
| 95 | test_tick && |
| 96 | git commit -a -m "initial with -a" && |
| 97 | |
| 98 | git cat-file blob HEAD:"commit is" >current.1 && |
| 99 | git cat-file blob HEAD:not/forbid >current.2 && |
| 100 | |
| 101 | cmp current.1 "commit is" && |
| 102 | cmp current.2 not/forbid |
| 103 | |
| 104 | ' |
| 105 | |
| 106 | test_expect_success 'partial' ' |
| 107 | |
| 108 | echo another >"commit is" && |
| 109 | echo another >not/forbid && |
| 110 | test_tick && |
| 111 | git commit -m "partial commit to handle a file" "commit is" && |
| 112 | |
| 113 | changed=$(git diff-tree --name-only HEAD^ HEAD) && |
| 114 | test "$changed" = "commit is" |
| 115 | |
| 116 | ' |
| 117 | |
Tay Ray Chuan | e8f3016 | 2010-05-24 16:51:17 +0800 | [diff] [blame] | 118 | test_expect_success 'partial modification in a subdirectory' ' |
Junio C Hamano | b468f0c | 2007-11-22 16:21:49 -0800 | [diff] [blame] | 119 | |
| 120 | test_tick && |
| 121 | git commit -m "partial commit to subdirectory" not && |
| 122 | |
| 123 | changed=$(git diff-tree -r --name-only HEAD^ HEAD) && |
| 124 | test "$changed" = "not/forbid" |
| 125 | |
| 126 | ' |
| 127 | |
| 128 | test_expect_success 'partial removal' ' |
| 129 | |
| 130 | git rm not/forbid && |
| 131 | git commit -m "partial commit to remove not/forbid" not && |
| 132 | |
| 133 | changed=$(git diff-tree -r --name-only HEAD^ HEAD) && |
| 134 | test "$changed" = "not/forbid" && |
| 135 | remain=$(git ls-tree -r --name-only HEAD) && |
| 136 | test "$remain" = "commit is" |
| 137 | |
| 138 | ' |
| 139 | |
| 140 | test_expect_success 'sign off' ' |
| 141 | |
| 142 | >positive && |
| 143 | git add positive && |
| 144 | git commit -s -m "thank you" && |
| 145 | actual=$(git cat-file commit HEAD | sed -ne "s/Signed-off-by: //p") && |
| 146 | expected=$(git var GIT_COMMITTER_IDENT | sed -e "s/>.*/>/") && |
| 147 | test "z$actual" = "z$expected" |
| 148 | |
| 149 | ' |
| 150 | |
| 151 | test_expect_success 'multiple -m' ' |
| 152 | |
| 153 | >negative && |
| 154 | git add negative && |
| 155 | git commit -m "one" -m "two" -m "three" && |
| 156 | actual=$(git cat-file commit HEAD | sed -e "1,/^\$/d") && |
| 157 | expected=$(echo one; echo; echo two; echo; echo three) && |
| 158 | test "z$actual" = "z$expected" |
| 159 | |
| 160 | ' |
| 161 | |
| 162 | test_expect_success 'verbose' ' |
| 163 | |
| 164 | echo minus >negative && |
| 165 | git add negative && |
| 166 | git status -v | sed -ne "/^diff --git /p" >actual && |
| 167 | echo "diff --git a/negative b/negative" >expect && |
Jeff King | 82ebb0b | 2008-03-12 17:36:36 -0400 | [diff] [blame] | 168 | test_cmp expect actual |
Junio C Hamano | b468f0c | 2007-11-22 16:21:49 -0800 | [diff] [blame] | 169 | |
| 170 | ' |
| 171 | |
Jeff King | 4f672ad | 2008-10-26 00:49:35 -0400 | [diff] [blame] | 172 | test_expect_success 'verbose respects diff config' ' |
| 173 | |
Jeff King | 0fcf760 | 2017-10-03 09:43:47 -0400 | [diff] [blame] | 174 | test_config diff.noprefix true && |
Jeff King | 4f672ad | 2008-10-26 00:49:35 -0400 | [diff] [blame] | 175 | git status -v >actual && |
Jeff King | 0fcf760 | 2017-10-03 09:43:47 -0400 | [diff] [blame] | 176 | grep "diff --git negative negative" actual |
Jeff King | 4f672ad | 2008-10-26 00:49:35 -0400 | [diff] [blame] | 177 | ' |
| 178 | |
Brandon Casey | 5b012c8 | 2013-02-18 20:17:05 -0800 | [diff] [blame] | 179 | mesg_with_comment_and_newlines=' |
| 180 | # text |
| 181 | |
| 182 | ' |
| 183 | |
| 184 | test_expect_success 'prepare file with comment line and trailing newlines' ' |
| 185 | printf "%s" "$mesg_with_comment_and_newlines" >expect |
| 186 | ' |
| 187 | |
Ralf Thielow | 51fb3a3 | 2013-01-10 18:45:59 +0100 | [diff] [blame] | 188 | test_expect_success 'cleanup commit messages (verbatim option,-t)' ' |
Alex Riesen | 5f06573 | 2007-12-22 19:46:24 +0100 | [diff] [blame] | 189 | |
| 190 | echo >>negative && |
Brandon Casey | 67dabab | 2013-02-18 20:17:04 -0800 | [diff] [blame] | 191 | git commit --cleanup=verbatim --no-status -t expect -a && |
| 192 | git cat-file -p HEAD |sed -e "1,/^\$/d" >actual && |
Jeff King | 82ebb0b | 2008-03-12 17:36:36 -0400 | [diff] [blame] | 193 | test_cmp expect actual |
Alex Riesen | 5f06573 | 2007-12-22 19:46:24 +0100 | [diff] [blame] | 194 | |
| 195 | ' |
| 196 | |
Ralf Thielow | 51fb3a3 | 2013-01-10 18:45:59 +0100 | [diff] [blame] | 197 | test_expect_success 'cleanup commit messages (verbatim option,-F)' ' |
Alex Riesen | 5f06573 | 2007-12-22 19:46:24 +0100 | [diff] [blame] | 198 | |
| 199 | echo >>negative && |
| 200 | git commit --cleanup=verbatim -F expect -a && |
| 201 | git cat-file -p HEAD |sed -e "1,/^\$/d">actual && |
Jeff King | 82ebb0b | 2008-03-12 17:36:36 -0400 | [diff] [blame] | 202 | test_cmp expect actual |
Alex Riesen | 5f06573 | 2007-12-22 19:46:24 +0100 | [diff] [blame] | 203 | |
| 204 | ' |
| 205 | |
Brandon Casey | a24a41e | 2013-02-18 20:17:06 -0800 | [diff] [blame] | 206 | test_expect_success 'cleanup commit messages (verbatim option,-m)' ' |
Alex Riesen | 5f06573 | 2007-12-22 19:46:24 +0100 | [diff] [blame] | 207 | |
| 208 | echo >>negative && |
Brandon Casey | 5b012c8 | 2013-02-18 20:17:05 -0800 | [diff] [blame] | 209 | git commit --cleanup=verbatim -m "$mesg_with_comment_and_newlines" -a && |
Alex Riesen | 5f06573 | 2007-12-22 19:46:24 +0100 | [diff] [blame] | 210 | git cat-file -p HEAD |sed -e "1,/^\$/d">actual && |
Jeff King | 82ebb0b | 2008-03-12 17:36:36 -0400 | [diff] [blame] | 211 | test_cmp expect actual |
Alex Riesen | 5f06573 | 2007-12-22 19:46:24 +0100 | [diff] [blame] | 212 | |
| 213 | ' |
| 214 | |
Ralf Thielow | 51fb3a3 | 2013-01-10 18:45:59 +0100 | [diff] [blame] | 215 | test_expect_success 'cleanup commit messages (whitespace option,-F)' ' |
Alex Riesen | 5f06573 | 2007-12-22 19:46:24 +0100 | [diff] [blame] | 216 | |
| 217 | echo >>negative && |
| 218 | { echo;echo "# text";echo; } >text && |
| 219 | echo "# text" >expect && |
| 220 | git commit --cleanup=whitespace -F text -a && |
| 221 | git cat-file -p HEAD |sed -e "1,/^\$/d">actual && |
Jeff King | 82ebb0b | 2008-03-12 17:36:36 -0400 | [diff] [blame] | 222 | test_cmp expect actual |
Alex Riesen | 5f06573 | 2007-12-22 19:46:24 +0100 | [diff] [blame] | 223 | |
| 224 | ' |
| 225 | |
Nguyễn Thái Ngọc Duy | 75df1f4 | 2014-02-17 19:15:32 +0700 | [diff] [blame] | 226 | test_expect_success 'cleanup commit messages (scissors option,-F,-e)' ' |
| 227 | |
| 228 | echo >>negative && |
| 229 | cat >text <<EOF && |
| 230 | |
| 231 | # to be kept |
SZEDER Gábor | fbfa097 | 2015-06-09 02:28:34 +0200 | [diff] [blame] | 232 | |
| 233 | # ------------------------ >8 ------------------------ |
| 234 | # to be kept, too |
Nguyễn Thái Ngọc Duy | 75df1f4 | 2014-02-17 19:15:32 +0700 | [diff] [blame] | 235 | # ------------------------ >8 ------------------------ |
| 236 | to be removed |
SZEDER Gábor | fbfa097 | 2015-06-09 02:28:34 +0200 | [diff] [blame] | 237 | # ------------------------ >8 ------------------------ |
| 238 | to be removed, too |
Nguyễn Thái Ngọc Duy | 75df1f4 | 2014-02-17 19:15:32 +0700 | [diff] [blame] | 239 | EOF |
SZEDER Gábor | fbfa097 | 2015-06-09 02:28:34 +0200 | [diff] [blame] | 240 | |
| 241 | cat >expect <<EOF && |
| 242 | # to be kept |
| 243 | |
| 244 | # ------------------------ >8 ------------------------ |
| 245 | # to be kept, too |
| 246 | EOF |
Nguyễn Thái Ngọc Duy | 75df1f4 | 2014-02-17 19:15:32 +0700 | [diff] [blame] | 247 | git commit --cleanup=scissors -e -F text -a && |
| 248 | git cat-file -p HEAD |sed -e "1,/^\$/d">actual && |
| 249 | test_cmp expect actual |
SZEDER Gábor | fbfa097 | 2015-06-09 02:28:34 +0200 | [diff] [blame] | 250 | ' |
Nguyễn Thái Ngọc Duy | 75df1f4 | 2014-02-17 19:15:32 +0700 | [diff] [blame] | 251 | |
SZEDER Gábor | fbfa097 | 2015-06-09 02:28:34 +0200 | [diff] [blame] | 252 | test_expect_success 'cleanup commit messages (scissors option,-F,-e, scissors on first line)' ' |
| 253 | |
| 254 | echo >>negative && |
| 255 | cat >text <<EOF && |
| 256 | # ------------------------ >8 ------------------------ |
| 257 | to be removed |
| 258 | EOF |
| 259 | git commit --cleanup=scissors -e -F text -a --allow-empty-message && |
| 260 | git cat-file -p HEAD |sed -e "1,/^\$/d">actual && |
| 261 | test_must_be_empty actual |
Nguyễn Thái Ngọc Duy | 75df1f4 | 2014-02-17 19:15:32 +0700 | [diff] [blame] | 262 | ' |
| 263 | |
Ralf Thielow | 51fb3a3 | 2013-01-10 18:45:59 +0100 | [diff] [blame] | 264 | test_expect_success 'cleanup commit messages (strip option,-F)' ' |
Alex Riesen | 5f06573 | 2007-12-22 19:46:24 +0100 | [diff] [blame] | 265 | |
| 266 | echo >>negative && |
| 267 | { echo;echo "# text";echo sample;echo; } >text && |
| 268 | echo sample >expect && |
| 269 | git commit --cleanup=strip -F text -a && |
| 270 | git cat-file -p HEAD |sed -e "1,/^\$/d">actual && |
Jeff King | 82ebb0b | 2008-03-12 17:36:36 -0400 | [diff] [blame] | 271 | test_cmp expect actual |
Alex Riesen | 5f06573 | 2007-12-22 19:46:24 +0100 | [diff] [blame] | 272 | |
| 273 | ' |
| 274 | |
Ralf Thielow | 51fb3a3 | 2013-01-10 18:45:59 +0100 | [diff] [blame] | 275 | test_expect_success 'cleanup commit messages (strip option,-F,-e)' ' |
Alex Riesen | 5f06573 | 2007-12-22 19:46:24 +0100 | [diff] [blame] | 276 | |
| 277 | echo >>negative && |
| 278 | { echo;echo sample;echo; } >text && |
| 279 | git commit -e -F text -a && |
Ævar Arnfjörð Bjarmason | 0b430a1 | 2011-02-22 23:41:48 +0000 | [diff] [blame] | 280 | head -n 4 .git/COMMIT_EDITMSG >actual |
| 281 | ' |
Alex Riesen | 5f06573 | 2007-12-22 19:46:24 +0100 | [diff] [blame] | 282 | |
Ævar Arnfjörð Bjarmason | 0b430a1 | 2011-02-22 23:41:48 +0000 | [diff] [blame] | 283 | echo "sample |
| 284 | |
| 285 | # Please enter the commit message for your changes. Lines starting |
| 286 | # with '#' will be ignored, and an empty message aborts the commit." >expect |
| 287 | |
Ralf Thielow | 51fb3a3 | 2013-01-10 18:45:59 +0100 | [diff] [blame] | 288 | test_expect_success 'cleanup commit messages (strip option,-F,-e): output' ' |
Junio C Hamano | f79ce8d | 2011-04-13 16:17:50 -0700 | [diff] [blame] | 289 | test_i18ncmp expect actual |
Alex Riesen | 5f06573 | 2007-12-22 19:46:24 +0100 | [diff] [blame] | 290 | ' |
| 291 | |
Ralf Thielow | 51fb3a3 | 2013-01-10 18:45:59 +0100 | [diff] [blame] | 292 | test_expect_success 'cleanup commit message (fail on invalid cleanup mode option)' ' |
| 293 | test_must_fail git commit --cleanup=non-existent |
| 294 | ' |
| 295 | |
| 296 | test_expect_success 'cleanup commit message (fail on invalid cleanup mode configuration)' ' |
| 297 | test_must_fail git -c commit.cleanup=non-existent commit |
| 298 | ' |
| 299 | |
| 300 | test_expect_success 'cleanup commit message (no config and no option uses default)' ' |
| 301 | echo content >>file && |
| 302 | git add file && |
Brandon Casey | 24e099f | 2013-02-22 15:13:00 -0800 | [diff] [blame] | 303 | ( |
| 304 | test_set_editor "$TEST_DIRECTORY"/t7500/add-content-and-comment && |
| 305 | git commit --no-status |
| 306 | ) && |
Ralf Thielow | 51fb3a3 | 2013-01-10 18:45:59 +0100 | [diff] [blame] | 307 | commit_msg_is "commit message" |
| 308 | ' |
| 309 | |
| 310 | test_expect_success 'cleanup commit message (option overrides default)' ' |
| 311 | echo content >>file && |
| 312 | git add file && |
Brandon Casey | 24e099f | 2013-02-22 15:13:00 -0800 | [diff] [blame] | 313 | ( |
| 314 | test_set_editor "$TEST_DIRECTORY"/t7500/add-content-and-comment && |
| 315 | git commit --cleanup=whitespace --no-status |
| 316 | ) && |
Ralf Thielow | 51fb3a3 | 2013-01-10 18:45:59 +0100 | [diff] [blame] | 317 | commit_msg_is "commit message # comment" |
| 318 | ' |
| 319 | |
| 320 | test_expect_success 'cleanup commit message (config overrides default)' ' |
| 321 | echo content >>file && |
| 322 | git add file && |
Brandon Casey | 24e099f | 2013-02-22 15:13:00 -0800 | [diff] [blame] | 323 | ( |
| 324 | test_set_editor "$TEST_DIRECTORY"/t7500/add-content-and-comment && |
| 325 | git -c commit.cleanup=whitespace commit --no-status |
| 326 | ) && |
Ralf Thielow | 51fb3a3 | 2013-01-10 18:45:59 +0100 | [diff] [blame] | 327 | commit_msg_is "commit message # comment" |
| 328 | ' |
| 329 | |
| 330 | test_expect_success 'cleanup commit message (option overrides config)' ' |
| 331 | echo content >>file && |
| 332 | git add file && |
Brandon Casey | 24e099f | 2013-02-22 15:13:00 -0800 | [diff] [blame] | 333 | ( |
| 334 | test_set_editor "$TEST_DIRECTORY"/t7500/add-content-and-comment && |
| 335 | git -c commit.cleanup=whitespace commit --cleanup=default |
| 336 | ) && |
Ralf Thielow | 51fb3a3 | 2013-01-10 18:45:59 +0100 | [diff] [blame] | 337 | commit_msg_is "commit message" |
| 338 | ' |
| 339 | |
| 340 | test_expect_success 'cleanup commit message (default, -m)' ' |
| 341 | echo content >>file && |
| 342 | git add file && |
| 343 | git commit -m "message #comment " && |
| 344 | commit_msg_is "message #comment" |
| 345 | ' |
| 346 | |
| 347 | test_expect_success 'cleanup commit message (whitespace option, -m)' ' |
| 348 | echo content >>file && |
| 349 | git add file && |
| 350 | git commit --cleanup=whitespace --no-status -m "message #comment " && |
| 351 | commit_msg_is "message #comment" |
| 352 | ' |
| 353 | |
| 354 | test_expect_success 'cleanup commit message (whitespace config, -m)' ' |
| 355 | echo content >>file && |
| 356 | git add file && |
| 357 | git -c commit.cleanup=whitespace commit --no-status -m "message #comment " && |
| 358 | commit_msg_is "message #comment" |
| 359 | ' |
| 360 | |
Jeff King | 1f4bf34 | 2012-07-26 16:30:29 -0400 | [diff] [blame] | 361 | test_expect_success 'message shows author when it is not equal to committer' ' |
Santi Béjar | e83dbe8 | 2008-05-04 18:04:50 +0200 | [diff] [blame] | 362 | echo >>negative && |
Jeff King | ceacd91 | 2012-07-26 16:31:15 -0400 | [diff] [blame] | 363 | git commit -e -m "sample" -a && |
Jeff King | 1f4bf34 | 2012-07-26 16:30:29 -0400 | [diff] [blame] | 364 | test_i18ngrep \ |
| 365 | "^# Author: *A U Thor <author@example.com>\$" \ |
| 366 | .git/COMMIT_EDITMSG |
Santi Béjar | e83dbe8 | 2008-05-04 18:04:50 +0200 | [diff] [blame] | 367 | ' |
| 368 | |
Jeff King | b7242b8 | 2014-05-01 21:10:01 -0400 | [diff] [blame] | 369 | test_expect_success 'message shows date when it is explicitly set' ' |
| 370 | git commit --allow-empty -e -m foo --date="2010-01-02T03:04:05" && |
| 371 | test_i18ngrep \ |
| 372 | "^# Date: *Sat Jan 2 03:04:05 2010 +0000" \ |
| 373 | .git/COMMIT_EDITMSG |
| 374 | ' |
| 375 | |
Jeff King | 1d7dc26 | 2012-07-26 16:32:31 -0400 | [diff] [blame] | 376 | test_expect_success AUTOIDENT 'message shows committer when it is automatic' ' |
Santi Béjar | bb1ae3f | 2008-05-04 18:04:51 +0200 | [diff] [blame] | 377 | |
| 378 | echo >>negative && |
Junio C Hamano | 7845944 | 2008-06-03 18:08:08 -0700 | [diff] [blame] | 379 | ( |
Elijah Newren | 00648ba | 2010-10-03 14:00:14 -0600 | [diff] [blame] | 380 | sane_unset GIT_COMMITTER_EMAIL && |
| 381 | sane_unset GIT_COMMITTER_NAME && |
Jeff King | 1d7dc26 | 2012-07-26 16:32:31 -0400 | [diff] [blame] | 382 | git commit -e -m "sample" -a |
Junio C Hamano | 7845944 | 2008-06-03 18:08:08 -0700 | [diff] [blame] | 383 | ) && |
Jeff King | 1f4bf34 | 2012-07-26 16:30:29 -0400 | [diff] [blame] | 384 | # the ident is calculated from the system, so we cannot |
| 385 | # check the actual value, only that it is there |
| 386 | test_i18ngrep "^# Committer: " .git/COMMIT_EDITMSG |
Santi Béjar | bb1ae3f | 2008-05-04 18:04:51 +0200 | [diff] [blame] | 387 | ' |
| 388 | |
Jeff King | a9ebc43 | 2012-07-26 16:27:55 -0400 | [diff] [blame] | 389 | write_script .git/FAKE_EDITOR <<EOF |
| 390 | echo editor started > "$(pwd)/.git/result" |
Paolo Bonzini | ec84bd0 | 2008-02-05 11:01:46 +0100 | [diff] [blame] | 391 | exit 0 |
| 392 | EOF |
Paolo Bonzini | ec84bd0 | 2008-02-05 11:01:46 +0100 | [diff] [blame] | 393 | |
Jeff King | 09feffb | 2012-11-14 16:33:40 -0800 | [diff] [blame] | 394 | test_expect_success !AUTOIDENT 'do not fire editor when committer is bogus' ' |
Ramsay Jones | f84df81 | 2015-04-28 13:04:44 +0100 | [diff] [blame] | 395 | >.git/result && |
Jeff King | 8c8b3bc | 2012-07-26 16:32:50 -0400 | [diff] [blame] | 396 | >expect && |
| 397 | |
| 398 | echo >>negative && |
| 399 | ( |
| 400 | sane_unset GIT_COMMITTER_EMAIL && |
| 401 | sane_unset GIT_COMMITTER_NAME && |
| 402 | GIT_EDITOR="\"$(pwd)/.git/FAKE_EDITOR\"" && |
| 403 | export GIT_EDITOR && |
| 404 | test_must_fail git commit -e -m sample -a |
| 405 | ) && |
| 406 | test_cmp expect .git/result |
| 407 | ' |
| 408 | |
René Scharfe | 2520677 | 2013-05-25 23:43:34 +0200 | [diff] [blame] | 409 | test_expect_success 'do not fire editor if -m <msg> was given' ' |
| 410 | echo tick >file && |
| 411 | git add file && |
| 412 | echo "editor not started" >.git/result && |
| 413 | (GIT_EDITOR="\"$(pwd)/.git/FAKE_EDITOR\"" git commit -m tick) && |
| 414 | test "$(cat .git/result)" = "editor not started" |
| 415 | ' |
| 416 | |
| 417 | test_expect_success 'do not fire editor if -m "" was given' ' |
| 418 | echo tock >file && |
| 419 | git add file && |
| 420 | echo "editor not started" >.git/result && |
| 421 | (GIT_EDITOR="\"$(pwd)/.git/FAKE_EDITOR\"" \ |
| 422 | git commit -m "" --allow-empty-message) && |
| 423 | test "$(cat .git/result)" = "editor not started" |
| 424 | ' |
| 425 | |
Paolo Bonzini | ec84bd0 | 2008-02-05 11:01:46 +0100 | [diff] [blame] | 426 | test_expect_success 'do not fire editor in the presence of conflicts' ' |
| 427 | |
Junio C Hamano | a3c91e0 | 2008-06-03 18:10:08 -0700 | [diff] [blame] | 428 | git clean -f && |
| 429 | echo f >g && |
| 430 | git add g && |
| 431 | git commit -m "add g" && |
| 432 | git branch second && |
| 433 | echo master >g && |
| 434 | echo g >h && |
| 435 | git add g h && |
| 436 | git commit -m "modify g and add h" && |
| 437 | git checkout second && |
| 438 | echo second >g && |
| 439 | git add g && |
| 440 | git commit -m second && |
| 441 | # Must fail due to conflict |
| 442 | test_must_fail git cherry-pick -n master && |
| 443 | echo "editor not started" >.git/result && |
Brandon Casey | e200783 | 2008-06-19 12:32:02 -0500 | [diff] [blame] | 444 | ( |
Jeff King | 34565f2 | 2012-07-26 16:28:00 -0400 | [diff] [blame] | 445 | GIT_EDITOR="\"$(pwd)/.git/FAKE_EDITOR\"" && |
Brandon Casey | e200783 | 2008-06-19 12:32:02 -0500 | [diff] [blame] | 446 | export GIT_EDITOR && |
| 447 | test_must_fail git commit |
| 448 | ) && |
Junio C Hamano | a3c91e0 | 2008-06-03 18:10:08 -0700 | [diff] [blame] | 449 | test "$(cat .git/result)" = "editor not started" |
Paolo Bonzini | ec84bd0 | 2008-02-05 11:01:46 +0100 | [diff] [blame] | 450 | ' |
| 451 | |
Jeff King | a9ebc43 | 2012-07-26 16:27:55 -0400 | [diff] [blame] | 452 | write_script .git/FAKE_EDITOR <<EOF |
Paolo Bonzini | ad5fa3c | 2008-05-29 16:55:53 +0200 | [diff] [blame] | 453 | # kill -TERM command added below. |
| 454 | EOF |
| 455 | |
Johannes Sixt | fb9a2be | 2009-03-25 13:21:15 +0100 | [diff] [blame] | 456 | test_expect_success EXECKEEPSPID 'a SIGTERM should break locks' ' |
Paolo Bonzini | ad5fa3c | 2008-05-29 16:55:53 +0200 | [diff] [blame] | 457 | echo >>negative && |
Brandon Casey | 09b78bc | 2008-07-22 16:21:10 -0500 | [diff] [blame] | 458 | ! "$SHELL_PATH" -c '\'' |
Paolo Bonzini | ad5fa3c | 2008-05-29 16:55:53 +0200 | [diff] [blame] | 459 | echo kill -TERM $$ >> .git/FAKE_EDITOR |
Brandon Casey | 09b78bc | 2008-07-22 16:21:10 -0500 | [diff] [blame] | 460 | GIT_EDITOR=.git/FAKE_EDITOR |
| 461 | export GIT_EDITOR |
| 462 | exec git commit -a'\'' && |
| 463 | test ! -f .git/index.lock |
Paolo Bonzini | ad5fa3c | 2008-05-29 16:55:53 +0200 | [diff] [blame] | 464 | ' |
| 465 | |
Junio C Hamano | 67bfc03 | 2008-06-02 22:17:42 -0700 | [diff] [blame] | 466 | rm -f .git/MERGE_MSG .git/COMMIT_EDITMSG |
| 467 | git reset -q --hard |
| 468 | |
| 469 | test_expect_success 'Hand committing of a redundant merge removes dups' ' |
| 470 | |
| 471 | git rev-parse second master >expect && |
| 472 | test_must_fail git merge second master && |
| 473 | git checkout master g && |
| 474 | EDITOR=: git commit -a && |
| 475 | git cat-file commit HEAD | sed -n -e "s/^parent //p" -e "/^$/q" >actual && |
| 476 | test_cmp expect actual |
| 477 | |
| 478 | ' |
| 479 | |
Junio C Hamano | e513843 | 2009-11-06 23:06:06 -0800 | [diff] [blame] | 480 | test_expect_success 'A single-liner subject with a token plus colon is not a footer' ' |
| 481 | |
| 482 | git reset --hard && |
| 483 | git commit -s -m "hello: kitty" --allow-empty && |
| 484 | git cat-file commit HEAD | sed -e "1,/^$/d" >actual && |
Stefano Lattarini | 3fb0459 | 2012-04-11 13:24:01 +0200 | [diff] [blame] | 485 | test_line_count = 3 actual |
Junio C Hamano | e513843 | 2009-11-06 23:06:06 -0800 | [diff] [blame] | 486 | |
| 487 | ' |
| 488 | |
Brandon Casey | 8c613fd | 2013-02-22 14:05:27 -0800 | [diff] [blame] | 489 | test_expect_success 'commit -s places sob on third line after two empty lines' ' |
| 490 | git commit -s --allow-empty --allow-empty-message && |
| 491 | cat <<-EOF >expect && |
| 492 | |
| 493 | |
| 494 | Signed-off-by: $GIT_COMMITTER_NAME <$GIT_COMMITTER_EMAIL> |
| 495 | |
| 496 | EOF |
| 497 | sed -e "/^#/d" -e "s/^:.*//" .git/COMMIT_EDITMSG >actual && |
| 498 | test_cmp expect actual |
| 499 | ' |
| 500 | |
Jeff King | a9ebc43 | 2012-07-26 16:27:55 -0400 | [diff] [blame] | 501 | write_script .git/FAKE_EDITOR <<\EOF |
| 502 | mv "$1" "$1.orig" |
Junio C Hamano | f9c0181 | 2010-01-13 00:12:54 -0800 | [diff] [blame] | 503 | ( |
| 504 | echo message |
Jeff King | a9ebc43 | 2012-07-26 16:27:55 -0400 | [diff] [blame] | 505 | cat "$1.orig" |
| 506 | ) >"$1" |
Junio C Hamano | f9c0181 | 2010-01-13 00:12:54 -0800 | [diff] [blame] | 507 | EOF |
| 508 | |
| 509 | echo '## Custom template' >template |
| 510 | |
Junio C Hamano | f9c0181 | 2010-01-13 00:12:54 -0800 | [diff] [blame] | 511 | try_commit () { |
| 512 | git reset --hard && |
| 513 | echo >>negative && |
| 514 | GIT_EDITOR=.git/FAKE_EDITOR git commit -a $* $use_template && |
| 515 | case "$use_template" in |
| 516 | '') |
Junio C Hamano | f79ce8d | 2011-04-13 16:17:50 -0700 | [diff] [blame] | 517 | test_i18ngrep ! "^## Custom template" .git/COMMIT_EDITMSG ;; |
Junio C Hamano | f9c0181 | 2010-01-13 00:12:54 -0800 | [diff] [blame] | 518 | *) |
Junio C Hamano | f79ce8d | 2011-04-13 16:17:50 -0700 | [diff] [blame] | 519 | test_i18ngrep "^## Custom template" .git/COMMIT_EDITMSG ;; |
Junio C Hamano | f9c0181 | 2010-01-13 00:12:54 -0800 | [diff] [blame] | 520 | esac |
| 521 | } |
| 522 | |
| 523 | try_commit_status_combo () { |
| 524 | |
Junio C Hamano | f79ce8d | 2011-04-13 16:17:50 -0700 | [diff] [blame] | 525 | test_expect_success 'commit' ' |
Junio C Hamano | f9c0181 | 2010-01-13 00:12:54 -0800 | [diff] [blame] | 526 | try_commit "" && |
Junio C Hamano | f79ce8d | 2011-04-13 16:17:50 -0700 | [diff] [blame] | 527 | test_i18ngrep "^# Changes to be committed:" .git/COMMIT_EDITMSG |
Junio C Hamano | f9c0181 | 2010-01-13 00:12:54 -0800 | [diff] [blame] | 528 | ' |
| 529 | |
Junio C Hamano | f79ce8d | 2011-04-13 16:17:50 -0700 | [diff] [blame] | 530 | test_expect_success 'commit --status' ' |
Junio C Hamano | f9c0181 | 2010-01-13 00:12:54 -0800 | [diff] [blame] | 531 | try_commit --status && |
Junio C Hamano | f79ce8d | 2011-04-13 16:17:50 -0700 | [diff] [blame] | 532 | test_i18ngrep "^# Changes to be committed:" .git/COMMIT_EDITMSG |
Junio C Hamano | f9c0181 | 2010-01-13 00:12:54 -0800 | [diff] [blame] | 533 | ' |
| 534 | |
Junio C Hamano | f79ce8d | 2011-04-13 16:17:50 -0700 | [diff] [blame] | 535 | test_expect_success 'commit --no-status' ' |
Jonathan Nieder | 2dec68c | 2010-10-31 02:30:58 -0500 | [diff] [blame] | 536 | try_commit --no-status && |
Junio C Hamano | f79ce8d | 2011-04-13 16:17:50 -0700 | [diff] [blame] | 537 | test_i18ngrep ! "^# Changes to be committed:" .git/COMMIT_EDITMSG |
Junio C Hamano | f9c0181 | 2010-01-13 00:12:54 -0800 | [diff] [blame] | 538 | ' |
| 539 | |
Junio C Hamano | f79ce8d | 2011-04-13 16:17:50 -0700 | [diff] [blame] | 540 | test_expect_success 'commit with commit.status = yes' ' |
Yann Droneaud | e023a31 | 2013-03-24 22:06:14 +0100 | [diff] [blame] | 541 | test_config commit.status yes && |
Junio C Hamano | f9c0181 | 2010-01-13 00:12:54 -0800 | [diff] [blame] | 542 | try_commit "" && |
Junio C Hamano | f79ce8d | 2011-04-13 16:17:50 -0700 | [diff] [blame] | 543 | test_i18ngrep "^# Changes to be committed:" .git/COMMIT_EDITMSG |
Junio C Hamano | f9c0181 | 2010-01-13 00:12:54 -0800 | [diff] [blame] | 544 | ' |
| 545 | |
Junio C Hamano | f79ce8d | 2011-04-13 16:17:50 -0700 | [diff] [blame] | 546 | test_expect_success 'commit with commit.status = no' ' |
Yann Droneaud | e023a31 | 2013-03-24 22:06:14 +0100 | [diff] [blame] | 547 | test_config commit.status no && |
Junio C Hamano | f9c0181 | 2010-01-13 00:12:54 -0800 | [diff] [blame] | 548 | try_commit "" && |
Junio C Hamano | f79ce8d | 2011-04-13 16:17:50 -0700 | [diff] [blame] | 549 | test_i18ngrep ! "^# Changes to be committed:" .git/COMMIT_EDITMSG |
Junio C Hamano | f9c0181 | 2010-01-13 00:12:54 -0800 | [diff] [blame] | 550 | ' |
| 551 | |
Junio C Hamano | f79ce8d | 2011-04-13 16:17:50 -0700 | [diff] [blame] | 552 | test_expect_success 'commit --status with commit.status = yes' ' |
Yann Droneaud | e023a31 | 2013-03-24 22:06:14 +0100 | [diff] [blame] | 553 | test_config commit.status yes && |
Junio C Hamano | f9c0181 | 2010-01-13 00:12:54 -0800 | [diff] [blame] | 554 | try_commit --status && |
Junio C Hamano | f79ce8d | 2011-04-13 16:17:50 -0700 | [diff] [blame] | 555 | test_i18ngrep "^# Changes to be committed:" .git/COMMIT_EDITMSG |
Junio C Hamano | f9c0181 | 2010-01-13 00:12:54 -0800 | [diff] [blame] | 556 | ' |
| 557 | |
Junio C Hamano | f79ce8d | 2011-04-13 16:17:50 -0700 | [diff] [blame] | 558 | test_expect_success 'commit --no-status with commit.status = yes' ' |
Yann Droneaud | e023a31 | 2013-03-24 22:06:14 +0100 | [diff] [blame] | 559 | test_config commit.status yes && |
Junio C Hamano | f9c0181 | 2010-01-13 00:12:54 -0800 | [diff] [blame] | 560 | try_commit --no-status && |
Junio C Hamano | f79ce8d | 2011-04-13 16:17:50 -0700 | [diff] [blame] | 561 | test_i18ngrep ! "^# Changes to be committed:" .git/COMMIT_EDITMSG |
Junio C Hamano | f9c0181 | 2010-01-13 00:12:54 -0800 | [diff] [blame] | 562 | ' |
| 563 | |
Junio C Hamano | f79ce8d | 2011-04-13 16:17:50 -0700 | [diff] [blame] | 564 | test_expect_success 'commit --status with commit.status = no' ' |
Yann Droneaud | e023a31 | 2013-03-24 22:06:14 +0100 | [diff] [blame] | 565 | test_config commit.status no && |
Junio C Hamano | f9c0181 | 2010-01-13 00:12:54 -0800 | [diff] [blame] | 566 | try_commit --status && |
Junio C Hamano | f79ce8d | 2011-04-13 16:17:50 -0700 | [diff] [blame] | 567 | test_i18ngrep "^# Changes to be committed:" .git/COMMIT_EDITMSG |
Junio C Hamano | f9c0181 | 2010-01-13 00:12:54 -0800 | [diff] [blame] | 568 | ' |
| 569 | |
Junio C Hamano | f79ce8d | 2011-04-13 16:17:50 -0700 | [diff] [blame] | 570 | test_expect_success 'commit --no-status with commit.status = no' ' |
Yann Droneaud | e023a31 | 2013-03-24 22:06:14 +0100 | [diff] [blame] | 571 | test_config commit.status no && |
Junio C Hamano | f9c0181 | 2010-01-13 00:12:54 -0800 | [diff] [blame] | 572 | try_commit --no-status && |
Junio C Hamano | f79ce8d | 2011-04-13 16:17:50 -0700 | [diff] [blame] | 573 | test_i18ngrep ! "^# Changes to be committed:" .git/COMMIT_EDITMSG |
Junio C Hamano | f9c0181 | 2010-01-13 00:12:54 -0800 | [diff] [blame] | 574 | ' |
| 575 | |
| 576 | } |
| 577 | |
| 578 | try_commit_status_combo |
| 579 | |
| 580 | use_template="-t template" |
| 581 | |
| 582 | try_commit_status_combo |
| 583 | |
Junio C Hamano | eff80a9 | 2013-01-16 20:18:48 +0100 | [diff] [blame] | 584 | test_expect_success 'commit --status with custom comment character' ' |
Yann Droneaud | 464be63 | 2013-03-24 22:06:10 +0100 | [diff] [blame] | 585 | test_config core.commentchar ";" && |
Junio C Hamano | eff80a9 | 2013-01-16 20:18:48 +0100 | [diff] [blame] | 586 | try_commit --status && |
| 587 | test_i18ngrep "^; Changes to be committed:" .git/COMMIT_EDITMSG |
| 588 | ' |
| 589 | |
Nguyễn Thái Ngọc Duy | 84c9dc2 | 2014-05-17 08:52:23 +0700 | [diff] [blame] | 590 | test_expect_success 'switch core.commentchar' ' |
| 591 | test_commit "#foo" foo && |
| 592 | GIT_EDITOR=.git/FAKE_EDITOR git -c core.commentChar=auto commit --amend && |
| 593 | test_i18ngrep "^; Changes to be committed:" .git/COMMIT_EDITMSG |
| 594 | ' |
| 595 | |
| 596 | test_expect_success 'switch core.commentchar but out of options' ' |
| 597 | cat >text <<\EOF && |
| 598 | # 1 |
| 599 | ; 2 |
| 600 | @ 3 |
| 601 | ! 4 |
| 602 | $ 5 |
| 603 | % 6 |
| 604 | ^ 7 |
| 605 | & 8 |
| 606 | | 9 |
| 607 | : 10 |
| 608 | EOF |
| 609 | git commit --amend -F text && |
| 610 | ( |
| 611 | test_set_editor .git/FAKE_EDITOR && |
| 612 | test_must_fail git -c core.commentChar=auto commit --amend |
| 613 | ) |
| 614 | ' |
| 615 | |
Junio C Hamano | b468f0c | 2007-11-22 16:21:49 -0800 | [diff] [blame] | 616 | test_done |