mirror of
https://github.com/git/git.git
synced 2025-01-23 16:03:32 +08:00
1108cea7f8
As a follow-up to d162b25f95
(tests: remove support for
GIT_TEST_GETTEXT_POISON, 2021-01-20) remove most uses of test_i18ncmp
via a simple s/test_i18ncmp/test_cmp/g search-replacement.
I'm leaving t6300-for-each-ref.sh out due to a conflict with in-flight
changes between "master" and "seen", as well as the prerequisite
itself due to other changes between "master" and "next/seen" which add
new test_i18ncmp uses.
Signed-off-by: Ævar Arnfjörð Bjarmason <avarab@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
234 lines
6.8 KiB
Bash
Executable File
234 lines
6.8 KiB
Bash
Executable File
#!/bin/sh
|
|
|
|
test_description='git status ignored modes'
|
|
|
|
. ./test-lib.sh
|
|
|
|
test_expect_success 'setup initial commit and ignore file' '
|
|
cat >.gitignore <<-\EOF &&
|
|
*.ign
|
|
ignored_dir/
|
|
!*.unignore
|
|
EOF
|
|
git add . &&
|
|
git commit -m "Initial commit"
|
|
'
|
|
|
|
test_expect_success 'Verify behavior of status on directories with ignored files' '
|
|
test_when_finished "git clean -fdx" &&
|
|
cat >expect <<-\EOF &&
|
|
? expect
|
|
? output
|
|
! dir/ignored/ignored_1.ign
|
|
! dir/ignored/ignored_2.ign
|
|
! ignored/ignored_1.ign
|
|
! ignored/ignored_2.ign
|
|
EOF
|
|
|
|
mkdir -p ignored dir/ignored &&
|
|
touch ignored/ignored_1.ign ignored/ignored_2.ign \
|
|
dir/ignored/ignored_1.ign dir/ignored/ignored_2.ign &&
|
|
|
|
git status --porcelain=v2 --ignored=matching --untracked-files=all >output &&
|
|
test_cmp expect output
|
|
'
|
|
|
|
test_expect_success 'Verify status behavior on directory with tracked & ignored files' '
|
|
test_when_finished "git clean -fdx && git reset HEAD~1 --hard" &&
|
|
cat >expect <<-\EOF &&
|
|
? expect
|
|
? output
|
|
! dir/tracked_ignored/ignored_1.ign
|
|
! dir/tracked_ignored/ignored_2.ign
|
|
! tracked_ignored/ignored_1.ign
|
|
! tracked_ignored/ignored_2.ign
|
|
EOF
|
|
|
|
mkdir -p tracked_ignored dir/tracked_ignored &&
|
|
touch tracked_ignored/tracked_1 tracked_ignored/tracked_2 \
|
|
tracked_ignored/ignored_1.ign tracked_ignored/ignored_2.ign \
|
|
dir/tracked_ignored/tracked_1 dir/tracked_ignored/tracked_2 \
|
|
dir/tracked_ignored/ignored_1.ign dir/tracked_ignored/ignored_2.ign &&
|
|
|
|
git add tracked_ignored/tracked_1 tracked_ignored/tracked_2 \
|
|
dir/tracked_ignored/tracked_1 dir/tracked_ignored/tracked_2 &&
|
|
git commit -m "commit tracked files" &&
|
|
|
|
git status --porcelain=v2 --ignored=matching --untracked-files=all >output &&
|
|
test_cmp expect output
|
|
'
|
|
|
|
test_expect_success 'Verify status behavior on directory with untracked and ignored files' '
|
|
test_when_finished "git clean -fdx" &&
|
|
cat >expect <<-\EOF &&
|
|
? dir/untracked_ignored/untracked_1
|
|
? dir/untracked_ignored/untracked_2
|
|
? expect
|
|
? output
|
|
? untracked_ignored/untracked_1
|
|
? untracked_ignored/untracked_2
|
|
! dir/untracked_ignored/ignored_1.ign
|
|
! dir/untracked_ignored/ignored_2.ign
|
|
! untracked_ignored/ignored_1.ign
|
|
! untracked_ignored/ignored_2.ign
|
|
EOF
|
|
|
|
mkdir -p untracked_ignored dir/untracked_ignored &&
|
|
touch untracked_ignored/untracked_1 untracked_ignored/untracked_2 \
|
|
untracked_ignored/ignored_1.ign untracked_ignored/ignored_2.ign \
|
|
dir/untracked_ignored/untracked_1 dir/untracked_ignored/untracked_2 \
|
|
dir/untracked_ignored/ignored_1.ign dir/untracked_ignored/ignored_2.ign &&
|
|
|
|
git status --porcelain=v2 --ignored=matching --untracked-files=all >output &&
|
|
test_cmp expect output
|
|
'
|
|
|
|
test_expect_success 'Verify status matching ignored files on ignored directory' '
|
|
test_when_finished "git clean -fdx" &&
|
|
cat >expect <<-\EOF &&
|
|
? expect
|
|
? output
|
|
! ignored_dir/
|
|
EOF
|
|
|
|
mkdir ignored_dir &&
|
|
touch ignored_dir/ignored_1 ignored_dir/ignored_2 \
|
|
ignored_dir/ignored_1.ign ignored_dir/ignored_2.ign &&
|
|
|
|
git status --porcelain=v2 --ignored=matching --untracked-files=all >output &&
|
|
test_cmp expect output
|
|
'
|
|
|
|
test_expect_success 'Verify status behavior on ignored directory containing tracked file' '
|
|
test_when_finished "git clean -fdx && git reset HEAD~1 --hard" &&
|
|
cat >expect <<-\EOF &&
|
|
? expect
|
|
? output
|
|
! ignored_dir/ignored_1
|
|
! ignored_dir/ignored_1.ign
|
|
! ignored_dir/ignored_2
|
|
! ignored_dir/ignored_2.ign
|
|
EOF
|
|
|
|
mkdir ignored_dir &&
|
|
touch ignored_dir/ignored_1 ignored_dir/ignored_2 \
|
|
ignored_dir/ignored_1.ign ignored_dir/ignored_2.ign \
|
|
ignored_dir/tracked &&
|
|
git add -f ignored_dir/tracked &&
|
|
git commit -m "Force add file in ignored directory" &&
|
|
git status --porcelain=v2 --ignored=matching --untracked-files=all >output &&
|
|
test_cmp expect output
|
|
'
|
|
|
|
test_expect_success 'Verify matching ignored files with --untracked-files=normal' '
|
|
test_when_finished "git clean -fdx" &&
|
|
cat >expect <<-\EOF &&
|
|
? expect
|
|
? output
|
|
? untracked_dir/
|
|
! ignored_dir/
|
|
! ignored_files/ignored_1.ign
|
|
! ignored_files/ignored_2.ign
|
|
EOF
|
|
|
|
mkdir ignored_dir ignored_files untracked_dir &&
|
|
touch ignored_dir/ignored_1 ignored_dir/ignored_2 \
|
|
ignored_files/ignored_1.ign ignored_files/ignored_2.ign \
|
|
untracked_dir/untracked &&
|
|
git status --porcelain=v2 --ignored=matching --untracked-files=normal >output &&
|
|
test_cmp expect output
|
|
'
|
|
|
|
test_expect_success 'Verify matching ignored files with --untracked-files=normal' '
|
|
test_when_finished "git clean -fdx" &&
|
|
cat >expect <<-\EOF &&
|
|
? expect
|
|
? output
|
|
? untracked_dir/
|
|
! ignored_dir/
|
|
! ignored_files/ignored_1.ign
|
|
! ignored_files/ignored_2.ign
|
|
EOF
|
|
|
|
mkdir ignored_dir ignored_files untracked_dir &&
|
|
touch ignored_dir/ignored_1 ignored_dir/ignored_2 \
|
|
ignored_files/ignored_1.ign ignored_files/ignored_2.ign \
|
|
untracked_dir/untracked &&
|
|
git status --porcelain=v2 --ignored=matching --untracked-files=normal >output &&
|
|
test_cmp expect output
|
|
'
|
|
|
|
test_expect_success 'Verify status behavior on ignored directory containing tracked file' '
|
|
test_when_finished "git clean -fdx && git reset HEAD~1 --hard" &&
|
|
cat >expect <<-\EOF &&
|
|
? expect
|
|
? output
|
|
! ignored_dir/ignored_1
|
|
! ignored_dir/ignored_1.ign
|
|
! ignored_dir/ignored_2
|
|
! ignored_dir/ignored_2.ign
|
|
EOF
|
|
|
|
mkdir ignored_dir &&
|
|
touch ignored_dir/ignored_1 ignored_dir/ignored_2 \
|
|
ignored_dir/ignored_1.ign ignored_dir/ignored_2.ign \
|
|
ignored_dir/tracked &&
|
|
git add -f ignored_dir/tracked &&
|
|
git commit -m "Force add file in ignored directory" &&
|
|
git status --porcelain=v2 --ignored=matching --untracked-files=normal >output &&
|
|
test_cmp expect output
|
|
'
|
|
|
|
test_expect_success 'Verify behavior of status with --ignored=no' '
|
|
test_when_finished "git clean -fdx" &&
|
|
cat >expect <<-\EOF &&
|
|
? expect
|
|
? output
|
|
EOF
|
|
|
|
mkdir -p ignored dir/ignored &&
|
|
touch ignored/ignored_1.ign ignored/ignored_2.ign \
|
|
dir/ignored/ignored_1.ign dir/ignored/ignored_2.ign &&
|
|
|
|
git status --porcelain=v2 --ignored=no --untracked-files=all >output &&
|
|
test_cmp expect output
|
|
'
|
|
|
|
test_expect_success 'Verify behavior of status with --ignored=traditional and --untracked-files=all' '
|
|
test_when_finished "git clean -fdx" &&
|
|
cat >expect <<-\EOF &&
|
|
? expect
|
|
? output
|
|
! dir/ignored/ignored_1.ign
|
|
! dir/ignored/ignored_2.ign
|
|
! ignored/ignored_1.ign
|
|
! ignored/ignored_2.ign
|
|
EOF
|
|
|
|
mkdir -p ignored dir/ignored &&
|
|
touch ignored/ignored_1.ign ignored/ignored_2.ign \
|
|
dir/ignored/ignored_1.ign dir/ignored/ignored_2.ign &&
|
|
|
|
git status --porcelain=v2 --ignored=traditional --untracked-files=all >output &&
|
|
test_cmp expect output
|
|
'
|
|
|
|
test_expect_success 'Verify behavior of status with --ignored=traditional and --untracked-files=normal' '
|
|
test_when_finished "git clean -fdx" &&
|
|
cat >expect <<-\EOF &&
|
|
? expect
|
|
? output
|
|
! dir/
|
|
! ignored/
|
|
EOF
|
|
|
|
mkdir -p ignored dir/ignored &&
|
|
touch ignored/ignored_1.ign ignored/ignored_2.ign \
|
|
dir/ignored/ignored_1.ign dir/ignored/ignored_2.ign &&
|
|
|
|
git status --porcelain=v2 --ignored=traditional --untracked-files=normal >output &&
|
|
test_cmp expect output
|
|
'
|
|
|
|
test_done
|