#!/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_i18ncmp 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_i18ncmp 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_i18ncmp 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_i18ncmp 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_i18ncmp 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_i18ncmp 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_i18ncmp 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_i18ncmp 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_i18ncmp 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_i18ncmp 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_i18ncmp expect output ' test_done