3 # Copyright (c) 2007 Johannes E. Schindelin
6 test_description
='git status'
10 test_expect_success
'setup' '
24 git commit -m initial &&
28 echo 1 >dir1/modified &&
29 echo 2 >dir2/modified &&
34 test_expect_success
'status (1)' '
36 grep "use \"git rm --cached <file>\.\.\.\" to unstage" output
42 # Changes to be committed:
43 # (use "git reset HEAD <file>..." to unstage)
45 # new file: dir2/added
47 # Changed but not updated:
48 # (use "git add <file>..." to update what will be committed)
49 # (use "git checkout -- <file>..." to discard changes in working directory)
51 # modified: dir1/modified
54 # (use "git add <file>..." to include in what will be committed)
64 test_expect_success
'status (2)' '
67 test_cmp expect output
73 # Changes to be committed:
74 # new file: dir2/added
76 # Changed but not updated:
77 # modified: dir1/modified
88 git config advice.statusHints false
90 test_expect_success
'status (advice.statusHints false)' '
93 test_cmp expect output
97 git config
--unset advice.statusHints
110 test_expect_success
'status -s' '
112 git status -s >output &&
113 test_cmp expect output
129 test_expect_success
'status -s -b' '
131 git status -s -b >output &&
132 test_cmp expect output
138 # Changes to be committed:
139 # (use "git reset HEAD <file>..." to unstage)
141 # new file: dir2/added
143 # Changed but not updated:
144 # (use "git add <file>..." to update what will be committed)
145 # (use "git checkout -- <file>..." to discard changes in working directory)
147 # modified: dir1/modified
149 # Untracked files not listed (use -u option to show untracked files)
151 test_expect_success
'status -uno' '
153 : >dir3/untracked1 &&
154 : >dir3/untracked2 &&
155 git status -uno >output &&
156 test_cmp expect output
159 test_expect_success
'status (status.showUntrackedFiles no)' '
160 git config status.showuntrackedfiles no
161 git status >output &&
162 test_cmp expect output
167 # Changes to be committed:
168 # new file: dir2/added
170 # Changed but not updated:
171 # modified: dir1/modified
173 # Untracked files not listed
175 git config advice.statusHints false
176 test_expect_success
'status -uno (advice.statusHints false)' '
177 git status -uno >output &&
178 test_cmp expect output
180 git config
--unset advice.statusHints
186 test_expect_success
'status -s -uno' '
187 git config --unset status.showuntrackedfiles
188 git status -s -uno >output &&
189 test_cmp expect output
192 test_expect_success
'status -s (status.showUntrackedFiles no)' '
193 git config status.showuntrackedfiles no
194 git status -s >output &&
195 test_cmp expect output
200 # Changes to be committed:
201 # (use "git reset HEAD <file>..." to unstage)
203 # new file: dir2/added
205 # Changed but not updated:
206 # (use "git add <file>..." to update what will be committed)
207 # (use "git checkout -- <file>..." to discard changes in working directory)
209 # modified: dir1/modified
212 # (use "git add <file>..." to include in what will be committed)
222 test_expect_success
'status -unormal' '
223 git status -unormal >output &&
224 test_cmp expect output
227 test_expect_success
'status (status.showUntrackedFiles normal)' '
228 git config status.showuntrackedfiles normal
229 git status >output &&
230 test_cmp expect output
244 test_expect_success
'status -s -unormal' '
245 git config --unset status.showuntrackedfiles
246 git status -s -unormal >output &&
247 test_cmp expect output
250 test_expect_success
'status -s (status.showUntrackedFiles normal)' '
251 git config status.showuntrackedfiles normal
252 git status -s >output &&
253 test_cmp expect output
258 # Changes to be committed:
259 # (use "git reset HEAD <file>..." to unstage)
261 # new file: dir2/added
263 # Changed but not updated:
264 # (use "git add <file>..." to update what will be committed)
265 # (use "git checkout -- <file>..." to discard changes in working directory)
267 # modified: dir1/modified
270 # (use "git add <file>..." to include in what will be committed)
281 test_expect_success
'status -uall' '
282 git status -uall >output &&
283 test_cmp expect output
285 test_expect_success
'status (status.showUntrackedFiles all)' '
286 git config status.showuntrackedfiles all
287 git status >output &&
289 git config --unset status.showuntrackedfiles &&
290 test_cmp expect output
303 test_expect_success
'status -s -uall' '
304 git config --unset status.showuntrackedfiles
305 git status -s -uall >output &&
306 test_cmp expect output
308 test_expect_success
'status -s (status.showUntrackedFiles all)' '
309 git config status.showuntrackedfiles all
310 git status -s >output &&
312 git config --unset status.showuntrackedfiles &&
313 test_cmp expect output
318 # Changes to be committed:
319 # (use "git reset HEAD <file>..." to unstage)
321 # new file: ../dir2/added
323 # Changed but not updated:
324 # (use "git add <file>..." to update what will be committed)
325 # (use "git checkout -- <file>..." to discard changes in working directory)
330 # (use "git add <file>..." to include in what will be committed)
340 test_expect_success
'status with relative paths' '
342 (cd dir1 && git status) >output &&
343 test_cmp expect output
357 test_expect_success
'status -s with relative paths' '
359 (cd dir1 && git status -s) >output &&
360 test_cmp expect output
375 test_expect_success
'status --porcelain ignores relative paths setting' '
377 (cd dir1 && git status --porcelain) >output &&
378 test_cmp expect output
382 test_expect_success
'setup unique colors' '
384 git config status.color.untracked blue
390 # Changes to be committed:
391 # (use "git reset HEAD <file>..." to unstage)
393 # <GREEN>new file: dir2/added<RESET>
395 # Changed but not updated:
396 # (use "git add <file>..." to update what will be committed)
397 # (use "git checkout -- <file>..." to discard changes in working directory)
399 # <RED>modified: dir1/modified<RESET>
402 # (use "git add <file>..." to include in what will be committed)
404 # <BLUE>dir1/untracked<RESET>
405 # <BLUE>dir2/modified<RESET>
406 # <BLUE>dir2/untracked<RESET>
407 # <BLUE>expect<RESET>
408 # <BLUE>output<RESET>
409 # <BLUE>untracked<RESET>
412 test_expect_success
'status with color.ui' '
414 git config color.ui always &&
415 git status | test_decode_color >output &&
416 test_cmp expect output
420 test_expect_success
'status with color.status' '
422 git config --unset color.ui &&
423 git config color.status always &&
424 git status | test_decode_color >output &&
425 test_cmp expect output
430 <RED
>M
<RESET
> dir
1/modified
431 <GREEN
>A
<RESET
> dir
2/added
432 <BLUE
>??
<RESET
> dir
1/untracked
433 <BLUE
>??
<RESET
> dir
2/modified
434 <BLUE
>??
<RESET
> dir
2/untracked
435 <BLUE
>??
<RESET
> expect
436 <BLUE
>??
<RESET
> output
437 <BLUE
>??
<RESET
> untracked
440 test_expect_success
'status -s with color.ui' '
442 git config --unset color.status &&
443 git config color.ui always &&
444 git status -s | test_decode_color >output &&
445 test_cmp expect output
449 test_expect_success
'status -s with color.status' '
451 git config --unset color.ui &&
452 git config color.status always &&
453 git status -s | test_decode_color >output &&
454 test_cmp expect output
459 ## <GREEN>master<RESET>
460 <RED
>M
<RESET
> dir
1/modified
461 <GREEN
>A
<RESET
> dir
2/added
462 <BLUE
>??
<RESET
> dir
1/untracked
463 <BLUE
>??
<RESET
> dir
2/modified
464 <BLUE
>??
<RESET
> dir
2/untracked
465 <BLUE
>??
<RESET
> expect
466 <BLUE
>??
<RESET
> output
467 <BLUE
>??
<RESET
> untracked
470 test_expect_success
'status -s -b with color.status' '
472 git status -s -b | test_decode_color >output &&
473 test_cmp expect output
488 test_expect_success
'status --porcelain ignores color.ui' '
490 git config --unset color.status &&
491 git config color.ui always &&
492 git status --porcelain | test_decode_color >output &&
493 test_cmp expect output
497 test_expect_success
'status --porcelain ignores color.status' '
499 git config --unset color.ui &&
500 git config color.status always &&
501 git status --porcelain | test_decode_color >output &&
502 test_cmp expect output
506 # recover unconditionally from color tests
507 git config
--unset color.status
508 git config
--unset color.ui
510 test_expect_success
'status --porcelain ignores -b' '
512 git status --porcelain -b >output &&
513 test_cmp expect output
519 # Changes to be committed:
520 # (use "git reset HEAD <file>..." to unstage)
522 # new file: dir2/added
524 # Changed but not updated:
525 # (use "git add <file>..." to update what will be committed)
526 # (use "git checkout -- <file>..." to discard changes in working directory)
528 # modified: dir1/modified
531 # (use "git add <file>..." to include in what will be committed)
542 test_expect_success
'status without relative paths' '
544 git config status.relativePaths false
545 (cd dir1 && git status) >output &&
546 test_cmp expect output
561 test_expect_success
'status -s without relative paths' '
563 (cd dir1 && git status -s) >output &&
564 test_cmp expect output
570 # Changes to be committed:
571 # (use "git reset HEAD <file>..." to unstage)
573 # modified: dir1/modified
576 # (use "git add <file>..." to include in what will be committed)
584 test_expect_success
'dry-run of partial commit excluding new file in index' '
585 git commit --dry-run dir1/modified >output &&
586 test_cmp expect output
590 :100644 100644 e69de29bb2d1d6434b8b29ae775ad8c2e48c5391 0000000000000000000000000000000000000000 M dir1/modified
592 test_expect_success
'status refreshes the index' '
595 git diff-files >output &&
596 test_cmp expect output
599 test_expect_success
'setup status submodule summary' '
600 test_create_repo sm && (
604 git commit -m "Add foo"
611 # Changes to be committed:
612 # (use "git reset HEAD <file>..." to unstage)
614 # new file: dir2/added
617 # Changed but not updated:
618 # (use "git add <file>..." to update what will be committed)
619 # (use "git checkout -- <file>..." to discard changes in working directory)
621 # modified: dir1/modified
624 # (use "git add <file>..." to include in what will be committed)
633 test_expect_success
'status submodule summary is disabled by default' '
634 git status >output &&
635 test_cmp expect output
638 # we expect the same as the previous test
639 test_expect_success
'status --untracked-files=all does not show submodule' '
640 git status --untracked-files=all >output &&
641 test_cmp expect output
655 test_expect_success
'status -s submodule summary is disabled by default' '
656 git status -s >output &&
657 test_cmp expect output
660 # we expect the same as the previous test
661 test_expect_success
'status -s --untracked-files=all does not show submodule' '
662 git status -s --untracked-files=all >output &&
663 test_cmp expect output
666 head=$
(cd sm
&& git rev-parse
--short=7 --verify HEAD
)
670 # Changes to be committed:
671 # (use "git reset HEAD <file>..." to unstage)
673 # new file: dir2/added
676 # Changed but not updated:
677 # (use "git add <file>..." to update what will be committed)
678 # (use "git checkout -- <file>..." to discard changes in working directory)
680 # modified: dir1/modified
682 # Submodule changes to be committed:
684 # * sm 0000000...$head (1):
688 # (use "git add <file>..." to include in what will be committed)
697 test_expect_success
'status submodule summary' '
698 git config status.submodulesummary 10 &&
699 git status >output &&
700 if test_have_prereq MINGW
704 test_cmp expect output
718 test_expect_success
'status -s submodule summary' '
719 git status -s >output &&
720 if test_have_prereq MINGW
724 test_cmp expect output
729 # Changed but not updated:
730 # (use "git add <file>..." to update what will be committed)
731 # (use "git checkout -- <file>..." to discard changes in working directory)
733 # modified: dir1/modified
736 # (use "git add <file>..." to include in what will be committed)
744 no changes added to commit (use "git add" and/or "git commit -a")
746 test_expect_success
'status submodule summary (clean submodule)' '
747 git commit -m "commit submodule" &&
748 git config status.submodulesummary 10 &&
749 test_must_fail git commit --dry-run >output &&
750 if test_have_prereq MINGW
754 test_cmp expect output &&
755 git status >output &&
756 if test_have_prereq MINGW
760 test_cmp expect output
772 test_expect_success
'status -s submodule summary (clean submodule)' '
773 git status -s >output &&
774 if test_have_prereq MINGW
778 test_cmp expect output
783 # Changes to be committed:
784 # (use "git reset HEAD^1 <file>..." to unstage)
786 # new file: dir2/added
789 # Changed but not updated:
790 # (use "git add <file>..." to update what will be committed)
791 # (use "git checkout -- <file>..." to discard changes in working directory)
793 # modified: dir1/modified
795 # Submodule changes to be committed:
797 # * sm 0000000...$head (1):
801 # (use "git add <file>..." to include in what will be committed)
810 test_expect_success
'commit --dry-run submodule summary (--amend)' '
811 git config status.submodulesummary 10 &&
812 git commit --dry-run --amend >output &&
813 if test_have_prereq MINGW
817 test_cmp expect output
820 test_expect_success POSIXPERM
,SANITY
'status succeeds in a read-only repository' '
823 # make dir1/tracked stat-dirty
824 >dir1/tracked1 && mv -f dir1/tracked1 dir1/tracked &&
825 git status -s >output &&
826 ! grep dir1/tracked output &&
827 # make sure "status" succeeded without writing index out
828 git diff-files | grep dir1/tracked
835 (cd sm
&& echo > bar
&& git add bar
&& git commit
-q -m 'Add bar') && git add sm
836 new_head
=$
(cd sm
&& git rev-parse
--short=7 --verify HEAD
)
841 # Changes to be committed:
842 # (use "git reset HEAD <file>..." to unstage)
846 # Changed but not updated:
847 # (use "git add <file>..." to update what will be committed)
848 # (use "git checkout -- <file>..." to discard changes in working directory)
850 # modified: dir1/modified
852 # Submodule changes to be committed:
854 # * sm $head...$new_head (1):
858 # (use "git add <file>..." to include in what will be committed)
869 test_expect_success
'--ignore-submodules=untracked suppresses submodules with untracked content' '
870 echo modified > sm/untracked &&
871 git status --ignore-submodules=untracked > output &&
872 test_cmp expect output
875 test_expect_success
'.gitmodules ignore=untracked suppresses submodules with untracked content' '
876 git config diff.ignoreSubmodules dirty &&
877 git status >output &&
878 test_cmp expect output &&
879 git config --add -f .gitmodules submodule.subname.ignore untracked &&
880 git config --add -f .gitmodules submodule.subname.path sm &&
881 git status > output &&
882 test_cmp expect output &&
883 git config -f .gitmodules --remove-section submodule.subname &&
884 git config --unset diff.ignoreSubmodules
887 test_expect_success
'.git/config ignore=untracked suppresses submodules with untracked content' '
888 git config --add -f .gitmodules submodule.subname.ignore none &&
889 git config --add -f .gitmodules submodule.subname.path sm &&
890 git config --add submodule.subname.ignore untracked &&
891 git config --add submodule.subname.path sm &&
892 git status > output &&
893 test_cmp expect output &&
894 git config --remove-section submodule.subname &&
895 git config --remove-section -f .gitmodules submodule.subname
898 test_expect_success
'--ignore-submodules=dirty suppresses submodules with untracked content' '
899 git status --ignore-submodules=dirty > output &&
900 test_cmp expect output
903 test_expect_success
'.gitmodules ignore=dirty suppresses submodules with untracked content' '
904 git config diff.ignoreSubmodules dirty &&
905 git status >output &&
907 git config --add -f .gitmodules submodule.subname.ignore dirty &&
908 git config --add -f .gitmodules submodule.subname.path sm &&
909 git status > output &&
910 test_cmp expect output &&
911 git config -f .gitmodules --remove-section submodule.subname &&
912 git config --unset diff.ignoreSubmodules
915 test_expect_success
'.git/config ignore=dirty suppresses submodules with untracked content' '
916 git config --add -f .gitmodules submodule.subname.ignore none &&
917 git config --add -f .gitmodules submodule.subname.path sm &&
918 git config --add submodule.subname.ignore dirty &&
919 git config --add submodule.subname.path sm &&
920 git status > output &&
921 test_cmp expect output &&
922 git config --remove-section submodule.subname &&
923 git config -f .gitmodules --remove-section submodule.subname
926 test_expect_success
'--ignore-submodules=dirty suppresses submodules with modified content' '
927 echo modified > sm/foo &&
928 git status --ignore-submodules=dirty > output &&
929 test_cmp expect output
932 test_expect_success
'.gitmodules ignore=dirty suppresses submodules with modified content' '
933 git config --add -f .gitmodules submodule.subname.ignore dirty &&
934 git config --add -f .gitmodules submodule.subname.path sm &&
935 git status > output &&
936 test_cmp expect output &&
937 git config -f .gitmodules --remove-section submodule.subname
940 test_expect_success
'.git/config ignore=dirty suppresses submodules with modified content' '
941 git config --add -f .gitmodules submodule.subname.ignore none &&
942 git config --add -f .gitmodules submodule.subname.path sm &&
943 git config --add submodule.subname.ignore dirty &&
944 git config --add submodule.subname.path sm &&
945 git status > output &&
946 test_cmp expect output &&
947 git config --remove-section submodule.subname &&
948 git config -f .gitmodules --remove-section submodule.subname
953 # Changes to be committed:
954 # (use "git reset HEAD <file>..." to unstage)
958 # Changed but not updated:
959 # (use "git add <file>..." to update what will be committed)
960 # (use "git checkout -- <file>..." to discard changes in working directory)
961 # (commit or discard the untracked or modified content in submodules)
963 # modified: dir1/modified
964 # modified: sm (modified content)
966 # Submodule changes to be committed:
968 # * sm $head...$new_head (1):
972 # (use "git add <file>..." to include in what will be committed)
983 test_expect_success
"--ignore-submodules=untracked doesn't suppress submodules with modified content" '
984 git status --ignore-submodules=untracked > output &&
985 test_cmp expect output
988 test_expect_success
".gitmodules ignore=untracked doesn't suppress submodules with modified content" '
989 git config --add -f .gitmodules submodule.subname.ignore untracked &&
990 git config --add -f .gitmodules submodule.subname.path sm &&
991 git status > output &&
992 test_cmp expect output &&
993 git config -f .gitmodules --remove-section submodule.subname
996 test_expect_success
".git/config ignore=untracked doesn't suppress submodules with modified content" '
997 git config --add -f .gitmodules submodule.subname.ignore none &&
998 git config --add -f .gitmodules submodule.subname.path sm &&
999 git config --add submodule.subname.ignore untracked &&
1000 git config --add submodule.subname.path sm &&
1001 git status > output &&
1002 test_cmp expect output &&
1003 git config --remove-section submodule.subname &&
1004 git config -f .gitmodules --remove-section submodule.subname
1007 head2
=$
(cd sm
&& git commit
-q -m "2nd commit" foo
&& git rev-parse
--short=7 --verify HEAD
)
1011 # Changes to be committed:
1012 # (use "git reset HEAD <file>..." to unstage)
1016 # Changed but not updated:
1017 # (use "git add <file>..." to update what will be committed)
1018 # (use "git checkout -- <file>..." to discard changes in working directory)
1020 # modified: dir1/modified
1021 # modified: sm (new commits)
1023 # Submodule changes to be committed:
1025 # * sm $head...$new_head (1):
1028 # Submodules changed but not updated:
1030 # * sm $new_head...$head2 (1):
1034 # (use "git add <file>..." to include in what will be committed)
1045 test_expect_success
"--ignore-submodules=untracked doesn't suppress submodule summary" '
1046 git status --ignore-submodules=untracked > output &&
1047 test_cmp expect output
1050 test_expect_success
".gitmodules ignore=untracked doesn't suppress submodule summary" '
1051 git config --add -f .gitmodules submodule.subname.ignore untracked &&
1052 git config --add -f .gitmodules submodule.subname.path sm &&
1053 git status > output &&
1054 test_cmp expect output &&
1055 git config -f .gitmodules --remove-section submodule.subname
1058 test_expect_success
".git/config ignore=untracked doesn't suppress submodule summary" '
1059 git config --add -f .gitmodules submodule.subname.ignore none &&
1060 git config --add -f .gitmodules submodule.subname.path sm &&
1061 git config --add submodule.subname.ignore untracked &&
1062 git config --add submodule.subname.path sm &&
1063 git status > output &&
1064 test_cmp expect output &&
1065 git config --remove-section submodule.subname &&
1066 git config -f .gitmodules --remove-section submodule.subname
1069 test_expect_success
"--ignore-submodules=dirty doesn't suppress submodule summary" '
1070 git status --ignore-submodules=dirty > output &&
1071 test_cmp expect output
1073 test_expect_success
".gitmodules ignore=dirty doesn't suppress submodule summary" '
1074 git config --add -f .gitmodules submodule.subname.ignore dirty &&
1075 git config --add -f .gitmodules submodule.subname.path sm &&
1076 git status > output &&
1077 test_cmp expect output &&
1078 git config -f .gitmodules --remove-section submodule.subname
1081 test_expect_success
".git/config ignore=dirty doesn't suppress submodule summary" '
1082 git config --add -f .gitmodules submodule.subname.ignore none &&
1083 git config --add -f .gitmodules submodule.subname.path sm &&
1084 git config --add submodule.subname.ignore dirty &&
1085 git config --add submodule.subname.path sm &&
1086 git status > output &&
1087 test_cmp expect output &&
1088 git config --remove-section submodule.subname &&
1089 git config -f .gitmodules --remove-section submodule.subname
1094 # Changed but not updated:
1095 # (use "git add <file>..." to update what will be committed)
1096 # (use "git checkout -- <file>..." to discard changes in working directory)
1098 # modified: dir1/modified
1101 # (use "git add <file>..." to include in what will be committed)
1110 no changes added to commit (use "git add" and/or "git commit -a")
1113 test_expect_success
"--ignore-submodules=all suppresses submodule summary" '
1114 git status --ignore-submodules=all > output &&
1115 test_cmp expect output
1118 test_expect_failure
'.gitmodules ignore=all suppresses submodule summary' '
1119 git config --add -f .gitmodules submodule.subname.ignore all &&
1120 git config --add -f .gitmodules submodule.subname.path sm &&
1121 git status > output &&
1122 test_cmp expect output &&
1123 git config -f .gitmodules --remove-section submodule.subname
1126 test_expect_failure
'.git/config ignore=all suppresses submodule summary' '
1127 git config --add -f .gitmodules submodule.subname.ignore none &&
1128 git config --add -f .gitmodules submodule.subname.path sm &&
1129 git config --add submodule.subname.ignore all &&
1130 git config --add submodule.subname.path sm &&
1131 git status > output &&
1132 test_cmp expect output &&
1133 git config --remove-section submodule.subname &&
1134 git config -f .gitmodules --remove-section submodule.subname