Am 09.05.2015 um 22:36 schrieb dturner@xxxxxxxxxxxxxxxx:
diff --git a/t/t1006-cat-file.sh b/t/t1006-cat-file.sh index ab36b1e..dd80c08 100755 --- a/t/t1006-cat-file.sh +++ b/t/t1006-cat-file.sh @@ -189,6 +189,13 @@ do ' done +for opt in t s e p +do + test_expect_success "Passing -$opt with --follow-symlinks fails" ' + test_must_fail git cat-file --follow-symlinks -$opt $hello_sha1 + ' +done + test_expect_success "--batch-check for a non-existent named object" ' test "foobar42 missing foobar84 missing" = \ @@ -296,4 +303,187 @@ test_expect_success '%(deltabase) reports packed delta bases' ' } ' +# Tests for git cat-file --follow-symlinks +test_expect_success 'prep for symlink tests' ' + echo_without_newline "$hello_content" > morx && + ln -s morx same-dir-link && + ln -s ../fleem out-of-repo-link && + ln -s .. out-of-repo-link-dir && + ln -s same-dir-link link-to-link && + ln -s nope broken-same-dir-link && + mkdir dir && + ln -s ../morx dir/parent-dir-link && + ln -s .. dir/link-dir && + ln -s ../../escape dir/out-of-repo-link && + ln -s ../.. dir/out-of-repo-link-dir && + ln -s nope dir/broken-link-in-dir && + mkdir dir/subdir && + ln -s ../../morx dir/subdir/grandparent-dir-link && + ln -s ../../../great-escape dir/subdir/out-of-repo-link && + ln -s ../../.. dir/subdir/out-of-repo-link-dir && + ln -s ../../../ dir/subdir/out-of-repo-link-dir-trailing && + ln -s ../parent-dir-link dir/subdir/parent-dir-link-to-link && + echo_without_newline "$hello_content" >dir/subdir/ind2 && + echo_without_newline "$hello_content" >dir/ind1 && + ln -s dir dirlink && + ln -s dir/subdir subdirlink && + ln -s subdir/ind2 dir/link-to-child && + ln -s dir/link-to-child link-to-down-link && + ln -s dir/.. up-down && + ln -s dir/../ up-down-trailing && + ln -s dir/../morx up-down-file && + ln -s dir/../../morx up-up-down-file && + ln -s subdirlink/../../morx up-two-down-file && + ln -s loop1 loop2 && + ln -s loop2 loop1 && + git add . && + git commit -am "test" +'
These tests will fail on a file system that does not support symbolic links, such as on Windows. Would you please separate the test cases (that come after the setup) into two groups:
1. Those that inspect the filesystem and expect a symbolic link. Protect these tests with a SYMLINKS prerequisite.
2. Those that look only at repository or index contents and do not require a symbolic link on the file system. These do not need to be protected.
Note that you do not require a symlink enabled file system to generate a repository with symlinks, i.e., you don't have to protect the setup code with SYMLINKS. For this, you can use 'test_ln_s_add' instead of the above sequence of 'ln -s' followed by a single 'git add .'.
+ +echo $hello_sha1 blob $hello_size > found
This seems to be used only in the next test. Please move it inside test_expect_success.
+ +test_expect_success 'git cat-file --batch-check --follow-symlinks works for non-links' ' + echo HEAD:morx | git cat-file --batch-check --follow-symlinks > actual && + test_cmp found actual && + echo HEAD:nope missing > expect && + echo HEAD:nope | git cat-file --batch-check --follow-symlinks > actual && + test_cmp expect actual +' + +test_expect_success 'git cat-file --batch-check --follow-symlinks works for in-repo, same-dir links' ' + echo HEAD:same-dir-link | git cat-file --batch-check --follow-symlinks > actual && + test_cmp found actual +' + +test_expect_success 'git cat-file --batch-check --follow-symlinks works for broken in-repo, same-dir links' ' + echo HEAD:broken-same-dir-link missing > expect && + echo HEAD:broken-same-dir-link | git cat-file --batch-check --follow-symlinks > actual && + test_cmp expect actual +' + +test_expect_success 'git cat-file --batch-check --follow-symlinks works for same-dir links-to-links' ' + echo HEAD:link-to-link | git cat-file --batch-check --follow-symlinks > actual && + test_cmp found actual +' + +test_expect_success 'git cat-file --batch-check --follow-symlinks works for parent-dir links' ' + echo HEAD:dir/parent-dir-link | git cat-file --batch-check --follow-symlinks > actual && + test_cmp found actual && + echo HEAD:dir/parent-dir-link/nope missing > expect && + echo HEAD:dir/parent-dir-link/nope | git cat-file --batch-check --follow-symlinks > actual && + test_cmp expect actual +' + +test_expect_success 'git cat-file --batch-check --follow-symlinks works for .. links' ' + echo HEAD:dir/link-dir/nope missing > expect && + echo HEAD:dir/link-dir/nope | git cat-file --batch-check --follow-symlinks > actual && + test_cmp expect actual && + echo HEAD:dir/link-dir/morx | git cat-file --batch-check --follow-symlinks > actual && + test_cmp found actual && + echo HEAD:dir/broken-link-in-dir missing > expect && + echo HEAD:dir/broken-link-in-dir | git cat-file --batch-check --follow-symlinks > actual && + test_cmp expect actual +' + +test_expect_success 'git cat-file --batch-check --follow-symlinks works for ../.. links' ' + echo HEAD:dir/subdir/grandparent-dir-link/nope missing > expect && + echo HEAD:dir/subdir/grandparent-dir-link/nope | git cat-file --batch-check --follow-symlinks > actual && + test_cmp expect actual && + echo HEAD:dir/subdir/grandparent-dir-link | git cat-file --batch-check --follow-symlinks > actual && + test_cmp found actual && + echo HEAD:dir/subdir/parent-dir-link-to-link | git cat-file --batch-check --follow-symlinks > actual && + test_cmp found actual +' + +test_expect_success 'git cat-file --batch-check --follow-symlinks works for dir/ links' ' + echo HEAD:dirlink/morx missing > expect && + echo HEAD:dirlink/morx | git cat-file --batch-check --follow-symlinks > actual && + test_cmp expect actual && + echo $hello_sha1 blob $hello_size > expect && + echo HEAD:dirlink/ind1 | git cat-file --batch-check --follow-symlinks > actual && + test_cmp expect actual +' + +test_expect_success 'git cat-file --batch-check --follow-symlinks works for dir/subdir links' ' + echo HEAD:subdirlink/morx missing > expect && + echo HEAD:subdirlink/morx | git cat-file --batch-check --follow-symlinks > actual && + test_cmp expect actual && + echo HEAD:subdirlink/ind2 | git cat-file --batch-check --follow-symlinks > actual && + test_cmp found actual +' + +test_expect_success 'git cat-file --batch-check --follow-symlinks works for dir -> subdir links' ' + echo HEAD:dir/link-to-child/morx missing > expect && + echo HEAD:dir/link-to-child/morx | git cat-file --batch-check --follow-symlinks > actual && + test_cmp expect actual && + echo HEAD:dir/link-to-child | git cat-file --batch-check --follow-symlinks > actual && + test_cmp found actual && + echo HEAD:link-to-down-link | git cat-file --batch-check --follow-symlinks > actual && + test_cmp found actual +' + +test_expect_success 'git cat-file --batch-check --follow-symlinks works for out-of-repo symlinks' ' + echo symlink 8 > expect && + echo ../fleem >> expect && + echo HEAD:out-of-repo-link | git cat-file --batch-check --follow-symlinks > actual && + test_cmp expect actual && + echo symlink 2 > expect && + echo .. >> expect && + echo HEAD:out-of-repo-link-dir | git cat-file --batch-check --follow-symlinks > actual && + test_cmp expect actual +' + +test_expect_success 'git cat-file --batch-check --follow-symlinks works for out-of-repo symlinks in dirs' ' + echo symlink 9 > expect && + echo ../escape >> expect && + echo HEAD:dir/out-of-repo-link | git cat-file --batch-check --follow-symlinks > actual && + test_cmp expect actual && + echo symlink 2 > expect && + echo .. >> expect && + echo HEAD:dir/out-of-repo-link-dir | git cat-file --batch-check --follow-symlinks > actual && + test_cmp expect actual +' + +test_expect_success 'git cat-file --batch-check --follow-symlinks works for out-of-repo symlinks in subdirs' ' + echo symlink 15 > expect && + echo ../great-escape >> expect && + echo HEAD:dir/subdir/out-of-repo-link | git cat-file --batch-check --follow-symlinks > actual && + test_cmp expect actual && + echo symlink 2 > expect && + echo .. >> expect && + echo HEAD:dir/subdir/out-of-repo-link-dir | git cat-file --batch-check --follow-symlinks > actual && + test_cmp expect actual && + echo symlink 3 > expect && + echo ../ >> expect && + echo HEAD:dir/subdir/out-of-repo-link-dir-trailing | git cat-file --batch-check --follow-symlinks > actual && + test_cmp expect actual +' + +test_expect_success 'git cat-file --batch-check --follow-symlinks works for symlinks with internal ..' ' + echo HEAD: | git cat-file --batch-check > expect && + echo HEAD:up-down | git cat-file --batch-check --follow-symlinks > actual && + test_cmp expect actual && + echo HEAD:up-down-trailing | git cat-file --batch-check --follow-symlinks > actual && + test_cmp expect actual && + echo HEAD:up-down-file | git cat-file --batch-check --follow-symlinks > actual && + test_cmp found actual && + echo symlink 7 > expect && + echo ../morx >> expect && + echo HEAD:up-up-down-file | git cat-file --batch-check --follow-symlinks > actual && + test_cmp expect actual && + echo HEAD:up-two-down-file | git cat-file --batch-check --follow-symlinks > actual && + test_cmp found actual +' + +test_expect_success 'git cat-file --batch-check --follow-symlink breaks loops' ' + echo HEAD:loop1 missing > expect && + echo HEAD:loop1 | git cat-file --batch-check --follow-symlinks > actual && + test_cmp expect actual +' + +test_expect_success 'git cat-file --batch --follow-symlink returns correct sha and mode' ' + echo HEAD:morx | git cat-file --batch > expect && + echo HEAD:morx | git cat-file --batch --follow-symlinks > actual && + test_cmp expect actual +' test_done
-- Hannes -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html