You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
696 lines
14 KiB
696 lines
14 KiB
#!/bin/sh |
|
# |
|
# Copyright (c) 2007 Johannes E. Schindelin |
|
# |
|
|
|
test_description='git status' |
|
|
|
. ./test-lib.sh |
|
|
|
test_expect_success 'setup' ' |
|
: >tracked && |
|
: >modified && |
|
mkdir dir1 && |
|
: >dir1/tracked && |
|
: >dir1/modified && |
|
mkdir dir2 && |
|
: >dir1/tracked && |
|
: >dir1/modified && |
|
git add . && |
|
|
|
git status >output && |
|
|
|
test_tick && |
|
git commit -m initial && |
|
: >untracked && |
|
: >dir1/untracked && |
|
: >dir2/untracked && |
|
echo 1 >dir1/modified && |
|
echo 2 >dir2/modified && |
|
echo 3 >dir2/added && |
|
git add dir2/added |
|
' |
|
|
|
test_expect_success 'status (1)' ' |
|
|
|
grep "use \"git rm --cached <file>\.\.\.\" to unstage" output |
|
|
|
' |
|
|
|
cat >expect <<\EOF |
|
# On branch master |
|
# Changes to be committed: |
|
# (use "git reset HEAD <file>..." to unstage) |
|
# |
|
# new file: dir2/added |
|
# |
|
# Changed but not updated: |
|
# (use "git add <file>..." to update what will be committed) |
|
# (use "git checkout -- <file>..." to discard changes in working directory) |
|
# |
|
# modified: dir1/modified |
|
# |
|
# Untracked files: |
|
# (use "git add <file>..." to include in what will be committed) |
|
# |
|
# dir1/untracked |
|
# dir2/modified |
|
# dir2/untracked |
|
# expect |
|
# output |
|
# untracked |
|
EOF |
|
|
|
test_expect_success 'status (2)' ' |
|
|
|
git status >output && |
|
test_cmp expect output |
|
|
|
' |
|
|
|
cat >expect <<\EOF |
|
M dir1/modified |
|
A dir2/added |
|
?? dir1/untracked |
|
?? dir2/modified |
|
?? dir2/untracked |
|
?? expect |
|
?? output |
|
?? untracked |
|
EOF |
|
|
|
test_expect_success 'status -s (2)' ' |
|
|
|
git status -s >output && |
|
test_cmp expect output |
|
|
|
' |
|
|
|
cat >expect <<EOF |
|
# On branch master |
|
# Changes to be committed: |
|
# (use "git reset HEAD <file>..." to unstage) |
|
# |
|
# new file: dir2/added |
|
# |
|
# Changed but not updated: |
|
# (use "git add <file>..." to update what will be committed) |
|
# (use "git checkout -- <file>..." to discard changes in working directory) |
|
# |
|
# modified: dir1/modified |
|
# |
|
# Untracked files not listed (use -u option to show untracked files) |
|
EOF |
|
test_expect_success 'status -uno' ' |
|
mkdir dir3 && |
|
: >dir3/untracked1 && |
|
: >dir3/untracked2 && |
|
git status -uno >output && |
|
test_cmp expect output |
|
' |
|
|
|
test_expect_success 'status (status.showUntrackedFiles no)' ' |
|
git config status.showuntrackedfiles no |
|
git status >output && |
|
test_cmp expect output |
|
' |
|
|
|
cat >expect << EOF |
|
M dir1/modified |
|
A dir2/added |
|
EOF |
|
test_expect_success 'status -s -uno' ' |
|
git config --unset status.showuntrackedfiles |
|
git status -s -uno >output && |
|
test_cmp expect output |
|
' |
|
|
|
test_expect_success 'status -s (status.showUntrackedFiles no)' ' |
|
git config status.showuntrackedfiles no |
|
git status -s >output && |
|
test_cmp expect output |
|
' |
|
|
|
cat >expect <<EOF |
|
# On branch master |
|
# Changes to be committed: |
|
# (use "git reset HEAD <file>..." to unstage) |
|
# |
|
# new file: dir2/added |
|
# |
|
# Changed but not updated: |
|
# (use "git add <file>..." to update what will be committed) |
|
# (use "git checkout -- <file>..." to discard changes in working directory) |
|
# |
|
# modified: dir1/modified |
|
# |
|
# Untracked files: |
|
# (use "git add <file>..." to include in what will be committed) |
|
# |
|
# dir1/untracked |
|
# dir2/modified |
|
# dir2/untracked |
|
# dir3/ |
|
# expect |
|
# output |
|
# untracked |
|
EOF |
|
test_expect_success 'status -unormal' ' |
|
git status -unormal >output && |
|
test_cmp expect output |
|
' |
|
|
|
test_expect_success 'status (status.showUntrackedFiles normal)' ' |
|
git config status.showuntrackedfiles normal |
|
git status >output && |
|
test_cmp expect output |
|
' |
|
|
|
cat >expect <<EOF |
|
M dir1/modified |
|
A dir2/added |
|
?? dir1/untracked |
|
?? dir2/modified |
|
?? dir2/untracked |
|
?? dir3/ |
|
?? expect |
|
?? output |
|
?? untracked |
|
EOF |
|
test_expect_success 'status -s -unormal' ' |
|
git config --unset status.showuntrackedfiles |
|
git status -s -unormal >output && |
|
test_cmp expect output |
|
' |
|
|
|
test_expect_success 'status -s (status.showUntrackedFiles normal)' ' |
|
git config status.showuntrackedfiles normal |
|
git status -s >output && |
|
test_cmp expect output |
|
' |
|
|
|
cat >expect <<EOF |
|
# On branch master |
|
# Changes to be committed: |
|
# (use "git reset HEAD <file>..." to unstage) |
|
# |
|
# new file: dir2/added |
|
# |
|
# Changed but not updated: |
|
# (use "git add <file>..." to update what will be committed) |
|
# (use "git checkout -- <file>..." to discard changes in working directory) |
|
# |
|
# modified: dir1/modified |
|
# |
|
# Untracked files: |
|
# (use "git add <file>..." to include in what will be committed) |
|
# |
|
# dir1/untracked |
|
# dir2/modified |
|
# dir2/untracked |
|
# dir3/untracked1 |
|
# dir3/untracked2 |
|
# expect |
|
# output |
|
# untracked |
|
EOF |
|
test_expect_success 'status -uall' ' |
|
git status -uall >output && |
|
test_cmp expect output |
|
' |
|
test_expect_success 'status (status.showUntrackedFiles all)' ' |
|
git config status.showuntrackedfiles all |
|
git status >output && |
|
rm -rf dir3 && |
|
git config --unset status.showuntrackedfiles && |
|
test_cmp expect output |
|
' |
|
|
|
cat >expect <<EOF |
|
M dir1/modified |
|
A dir2/added |
|
?? dir1/untracked |
|
?? dir2/modified |
|
?? dir2/untracked |
|
?? expect |
|
?? output |
|
?? untracked |
|
EOF |
|
test_expect_success 'status -s -uall' ' |
|
git config --unset status.showuntrackedfiles |
|
git status -s -uall >output && |
|
test_cmp expect output |
|
' |
|
test_expect_success 'status -s (status.showUntrackedFiles all)' ' |
|
git config status.showuntrackedfiles all |
|
git status -s >output && |
|
rm -rf dir3 && |
|
git config --unset status.showuntrackedfiles && |
|
test_cmp expect output |
|
' |
|
|
|
cat >expect <<\EOF |
|
# On branch master |
|
# Changes to be committed: |
|
# (use "git reset HEAD <file>..." to unstage) |
|
# |
|
# new file: ../dir2/added |
|
# |
|
# Changed but not updated: |
|
# (use "git add <file>..." to update what will be committed) |
|
# (use "git checkout -- <file>..." to discard changes in working directory) |
|
# |
|
# modified: modified |
|
# |
|
# Untracked files: |
|
# (use "git add <file>..." to include in what will be committed) |
|
# |
|
# untracked |
|
# ../dir2/modified |
|
# ../dir2/untracked |
|
# ../expect |
|
# ../output |
|
# ../untracked |
|
EOF |
|
|
|
test_expect_success 'status with relative paths' ' |
|
|
|
(cd dir1 && git status) >output && |
|
test_cmp expect output |
|
|
|
' |
|
|
|
cat >expect <<\EOF |
|
M modified |
|
A ../dir2/added |
|
?? untracked |
|
?? ../dir2/modified |
|
?? ../dir2/untracked |
|
?? ../expect |
|
?? ../output |
|
?? ../untracked |
|
EOF |
|
test_expect_success 'status -s with relative paths' ' |
|
|
|
(cd dir1 && git status -s) >output && |
|
test_cmp expect output |
|
|
|
' |
|
|
|
cat >expect <<\EOF |
|
M dir1/modified |
|
A dir2/added |
|
?? dir1/untracked |
|
?? dir2/modified |
|
?? dir2/untracked |
|
?? expect |
|
?? output |
|
?? untracked |
|
EOF |
|
|
|
test_expect_success 'status --porcelain ignores relative paths setting' ' |
|
|
|
(cd dir1 && git status --porcelain) >output && |
|
test_cmp expect output |
|
|
|
' |
|
|
|
test_expect_success 'setup unique colors' ' |
|
|
|
git config status.color.untracked blue |
|
|
|
' |
|
|
|
cat >expect <<\EOF |
|
# On branch master |
|
# Changes to be committed: |
|
# (use "git reset HEAD <file>..." to unstage) |
|
# |
|
# <GREEN>new file: dir2/added<RESET> |
|
# |
|
# Changed but not updated: |
|
# (use "git add <file>..." to update what will be committed) |
|
# (use "git checkout -- <file>..." to discard changes in working directory) |
|
# |
|
# <RED>modified: dir1/modified<RESET> |
|
# |
|
# Untracked files: |
|
# (use "git add <file>..." to include in what will be committed) |
|
# |
|
# <BLUE>dir1/untracked<RESET> |
|
# <BLUE>dir2/modified<RESET> |
|
# <BLUE>dir2/untracked<RESET> |
|
# <BLUE>expect<RESET> |
|
# <BLUE>output<RESET> |
|
# <BLUE>untracked<RESET> |
|
EOF |
|
|
|
test_expect_success 'status with color.ui' ' |
|
|
|
git config color.ui always && |
|
git status | test_decode_color >output && |
|
test_cmp expect output |
|
|
|
' |
|
|
|
test_expect_success 'status with color.status' ' |
|
|
|
git config --unset color.ui && |
|
git config color.status always && |
|
git status | test_decode_color >output && |
|
test_cmp expect output |
|
|
|
' |
|
|
|
cat >expect <<\EOF |
|
<RED>M<RESET> dir1/modified |
|
<GREEN>A<RESET> dir2/added |
|
<BLUE>??<RESET> dir1/untracked |
|
<BLUE>??<RESET> dir2/modified |
|
<BLUE>??<RESET> dir2/untracked |
|
<BLUE>??<RESET> expect |
|
<BLUE>??<RESET> output |
|
<BLUE>??<RESET> untracked |
|
EOF |
|
|
|
test_expect_success 'status -s with color.ui' ' |
|
|
|
git config --unset color.status && |
|
git config color.ui always && |
|
git status -s | test_decode_color >output && |
|
test_cmp expect output |
|
|
|
' |
|
|
|
test_expect_success 'status -s with color.status' ' |
|
|
|
git config --unset color.ui && |
|
git config color.status always && |
|
git status -s | test_decode_color >output && |
|
test_cmp expect output |
|
|
|
' |
|
|
|
cat >expect <<\EOF |
|
M dir1/modified |
|
A dir2/added |
|
?? dir1/untracked |
|
?? dir2/modified |
|
?? dir2/untracked |
|
?? expect |
|
?? output |
|
?? untracked |
|
EOF |
|
|
|
test_expect_success 'status --porcelain ignores color.ui' ' |
|
|
|
git config --unset color.status && |
|
git config color.ui always && |
|
git status --porcelain | test_decode_color >output && |
|
test_cmp expect output |
|
|
|
' |
|
|
|
test_expect_success 'status --porcelain ignores color.status' ' |
|
|
|
git config --unset color.ui && |
|
git config color.status always && |
|
git status --porcelain | test_decode_color >output && |
|
test_cmp expect output |
|
|
|
' |
|
|
|
# recover unconditionally from color tests |
|
git config --unset color.status |
|
git config --unset color.ui |
|
|
|
cat >expect <<\EOF |
|
# On branch master |
|
# Changes to be committed: |
|
# (use "git reset HEAD <file>..." to unstage) |
|
# |
|
# new file: dir2/added |
|
# |
|
# Changed but not updated: |
|
# (use "git add <file>..." to update what will be committed) |
|
# (use "git checkout -- <file>..." to discard changes in working directory) |
|
# |
|
# modified: dir1/modified |
|
# |
|
# Untracked files: |
|
# (use "git add <file>..." to include in what will be committed) |
|
# |
|
# dir1/untracked |
|
# dir2/modified |
|
# dir2/untracked |
|
# expect |
|
# output |
|
# untracked |
|
EOF |
|
|
|
|
|
test_expect_success 'status without relative paths' ' |
|
|
|
git config status.relativePaths false |
|
(cd dir1 && git status) >output && |
|
test_cmp expect output |
|
|
|
' |
|
|
|
cat >expect <<\EOF |
|
M dir1/modified |
|
A dir2/added |
|
?? dir1/untracked |
|
?? dir2/modified |
|
?? dir2/untracked |
|
?? expect |
|
?? output |
|
?? untracked |
|
EOF |
|
|
|
test_expect_success 'status -s without relative paths' ' |
|
|
|
(cd dir1 && git status -s) >output && |
|
test_cmp expect output |
|
|
|
' |
|
|
|
cat <<EOF >expect |
|
# On branch master |
|
# Changes to be committed: |
|
# (use "git reset HEAD <file>..." to unstage) |
|
# |
|
# modified: dir1/modified |
|
# |
|
# Untracked files: |
|
# (use "git add <file>..." to include in what will be committed) |
|
# |
|
# dir1/untracked |
|
# dir2/ |
|
# expect |
|
# output |
|
# untracked |
|
EOF |
|
test_expect_success 'dry-run of partial commit excluding new file in index' ' |
|
git commit --dry-run dir1/modified >output && |
|
test_cmp expect output |
|
' |
|
|
|
test_expect_success 'setup status submodule summary' ' |
|
test_create_repo sm && ( |
|
cd sm && |
|
>foo && |
|
git add foo && |
|
git commit -m "Add foo" |
|
) && |
|
git add sm |
|
' |
|
|
|
cat >expect <<EOF |
|
# On branch master |
|
# Changes to be committed: |
|
# (use "git reset HEAD <file>..." to unstage) |
|
# |
|
# new file: dir2/added |
|
# new file: sm |
|
# |
|
# Changed but not updated: |
|
# (use "git add <file>..." to update what will be committed) |
|
# (use "git checkout -- <file>..." to discard changes in working directory) |
|
# |
|
# modified: dir1/modified |
|
# |
|
# Untracked files: |
|
# (use "git add <file>..." to include in what will be committed) |
|
# |
|
# dir1/untracked |
|
# dir2/modified |
|
# dir2/untracked |
|
# expect |
|
# output |
|
# untracked |
|
EOF |
|
test_expect_success 'status submodule summary is disabled by default' ' |
|
git status >output && |
|
test_cmp expect output |
|
' |
|
|
|
# we expect the same as the previous test |
|
test_expect_success 'status --untracked-files=all does not show submodule' ' |
|
git status --untracked-files=all >output && |
|
test_cmp expect output |
|
' |
|
|
|
cat >expect <<EOF |
|
M dir1/modified |
|
A dir2/added |
|
A sm |
|
?? dir1/untracked |
|
?? dir2/modified |
|
?? dir2/untracked |
|
?? expect |
|
?? output |
|
?? untracked |
|
EOF |
|
test_expect_success 'status -s submodule summary is disabled by default' ' |
|
git status -s >output && |
|
test_cmp expect output |
|
' |
|
|
|
# we expect the same as the previous test |
|
test_expect_success 'status -s --untracked-files=all does not show submodule' ' |
|
git status -s --untracked-files=all >output && |
|
test_cmp expect output |
|
' |
|
|
|
head=$(cd sm && git rev-parse --short=7 --verify HEAD) |
|
|
|
cat >expect <<EOF |
|
# On branch master |
|
# Changes to be committed: |
|
# (use "git reset HEAD <file>..." to unstage) |
|
# |
|
# new file: dir2/added |
|
# new file: sm |
|
# |
|
# Changed but not updated: |
|
# (use "git add <file>..." to update what will be committed) |
|
# (use "git checkout -- <file>..." to discard changes in working directory) |
|
# |
|
# modified: dir1/modified |
|
# |
|
# Submodule changes to be committed: |
|
# |
|
# * sm 0000000...$head (1): |
|
# > Add foo |
|
# |
|
# Untracked files: |
|
# (use "git add <file>..." to include in what will be committed) |
|
# |
|
# dir1/untracked |
|
# dir2/modified |
|
# dir2/untracked |
|
# expect |
|
# output |
|
# untracked |
|
EOF |
|
test_expect_success 'status submodule summary' ' |
|
git config status.submodulesummary 10 && |
|
git status >output && |
|
test_cmp expect output |
|
' |
|
|
|
cat >expect <<EOF |
|
M dir1/modified |
|
A dir2/added |
|
A sm |
|
?? dir1/untracked |
|
?? dir2/modified |
|
?? dir2/untracked |
|
?? expect |
|
?? output |
|
?? untracked |
|
EOF |
|
test_expect_success 'status -s submodule summary' ' |
|
git status -s >output && |
|
test_cmp expect output |
|
' |
|
|
|
cat >expect <<EOF |
|
# On branch master |
|
# Changed but not updated: |
|
# (use "git add <file>..." to update what will be committed) |
|
# (use "git checkout -- <file>..." to discard changes in working directory) |
|
# |
|
# modified: dir1/modified |
|
# |
|
# Untracked files: |
|
# (use "git add <file>..." to include in what will be committed) |
|
# |
|
# dir1/untracked |
|
# dir2/modified |
|
# dir2/untracked |
|
# expect |
|
# output |
|
# untracked |
|
no changes added to commit (use "git add" and/or "git commit -a") |
|
EOF |
|
test_expect_success 'status submodule summary (clean submodule)' ' |
|
git commit -m "commit submodule" && |
|
git config status.submodulesummary 10 && |
|
test_must_fail git commit --dry-run >output && |
|
test_cmp expect output && |
|
git status >output && |
|
test_cmp expect output |
|
' |
|
|
|
cat >expect <<EOF |
|
M dir1/modified |
|
?? dir1/untracked |
|
?? dir2/modified |
|
?? dir2/untracked |
|
?? expect |
|
?? output |
|
?? untracked |
|
EOF |
|
test_expect_success 'status -s submodule summary (clean submodule)' ' |
|
git status -s >output && |
|
test_cmp expect output |
|
' |
|
|
|
cat >expect <<EOF |
|
# On branch master |
|
# Changes to be committed: |
|
# (use "git reset HEAD^1 <file>..." to unstage) |
|
# |
|
# new file: dir2/added |
|
# new file: sm |
|
# |
|
# Changed but not updated: |
|
# (use "git add <file>..." to update what will be committed) |
|
# (use "git checkout -- <file>..." to discard changes in working directory) |
|
# |
|
# modified: dir1/modified |
|
# |
|
# Submodule changes to be committed: |
|
# |
|
# * sm 0000000...$head (1): |
|
# > Add foo |
|
# |
|
# Untracked files: |
|
# (use "git add <file>..." to include in what will be committed) |
|
# |
|
# dir1/untracked |
|
# dir2/modified |
|
# dir2/untracked |
|
# expect |
|
# output |
|
# untracked |
|
EOF |
|
test_expect_success 'commit --dry-run submodule summary (--amend)' ' |
|
git config status.submodulesummary 10 && |
|
git commit --dry-run --amend >output && |
|
test_cmp expect output |
|
' |
|
|
|
test_done
|
|
|