diff options
author | Junio C Hamano <gitster@pobox.com> | 2014-09-19 23:05:11 +0200 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2014-09-19 23:05:11 +0200 |
commit | 92ea1ac8267a14f4eae55f175ac7ff0aeaaddc89 (patch) | |
tree | 7bdf4543e8c2428be6f51b8225d3d3a56fbdae36 /t | |
parent | Merge branch 'lf/bundle-exclusion' into maint (diff) | |
parent | read-cache: check for leading symlinks when refreshing index (diff) | |
download | git-92ea1ac8267a14f4eae55f175ac7ff0aeaaddc89.tar.xz git-92ea1ac8267a14f4eae55f175ac7ff0aeaaddc89.zip |
Merge branch 'rs/refresh-beyond-symlink' into maint
* rs/refresh-beyond-symlink:
read-cache: check for leading symlinks when refreshing index
Diffstat (limited to 't')
-rwxr-xr-x | t/t7515-status-symlinks.sh | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/t/t7515-status-symlinks.sh b/t/t7515-status-symlinks.sh new file mode 100755 index 0000000000..9f989be01b --- /dev/null +++ b/t/t7515-status-symlinks.sh @@ -0,0 +1,43 @@ +#!/bin/sh + +test_description='git status and symlinks' + +. ./test-lib.sh + +test_expect_success 'setup' ' + echo .gitignore >.gitignore && + echo actual >>.gitignore && + echo expect >>.gitignore && + mkdir dir && + echo x >dir/file1 && + echo y >dir/file2 && + git add dir && + git commit -m initial && + git tag initial +' + +test_expect_success SYMLINKS 'symlink to a directory' ' + test_when_finished "rm symlink" && + ln -s dir symlink && + echo "?? symlink" >expect && + git status --porcelain >actual && + test_cmp expect actual +' + +test_expect_success SYMLINKS 'symlink replacing a directory' ' + test_when_finished "rm -rf copy && git reset --hard initial" && + mkdir copy && + cp dir/file1 copy/file1 && + echo "changed in copy" >copy/file2 && + git add copy && + git commit -m second && + rm -rf copy && + ln -s dir copy && + echo " D copy/file1" >expect && + echo " D copy/file2" >>expect && + echo "?? copy" >>expect && + git status --porcelain >actual && + test_cmp expect actual +' + +test_done |