| #!/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 |