Because as described in previous patch - it should not. Several failures are demonstrated here: - git cat-file --textconv :symlink.bin # also HEAD:symlink.bin - git blame --textconv symlink.bin - git blame -C -C --textconv regular-file # but also looks on symlink.bin At present they all fail with something like. E: /tmp/j3ELEs_symlink.bin is not "binary" file Cc: Axel Bonnet <axel.bonnet@xxxxxxxxxxxxxxx> Cc: Clément Poulain <clement.poulain@xxxxxxxxxxxxxxx> Cc: Diane Gasselin <diane.gasselin@xxxxxxxxxxxxxxx> Signed-off-by: Kirill Smelkov <kirr@xxxxxxxxxxxxxxxxxxx> --- t/t8006-blame-textconv.sh | 44 ++++++++++++++++++++++++++++++++++++++++++ t/t8007-cat-file-textconv.sh | 29 +++++++++++++++++++++++++++ 2 files changed, 73 insertions(+), 0 deletions(-) diff --git a/t/t8006-blame-textconv.sh b/t/t8006-blame-textconv.sh index d0f8d62..3ed6155 100755 --- a/t/t8006-blame-textconv.sh +++ b/t/t8006-blame-textconv.sh @@ -17,10 +17,12 @@ chmod +x helper test_expect_success 'setup ' ' echo "bin: test 1" >one.bin && echo "bin: test number 2" >two.bin && + ln -s one.bin symlink.bin && git add . && GIT_AUTHOR_NAME=Number1 git commit -a -m First --date="2010-01-01 18:00:00" && echo "bin: test 1 version 2" >one.bin && echo "bin: test number 2 version 2" >>two.bin && + ln -sf two.bin symlink.bin && GIT_AUTHOR_NAME=Number2 git commit -a -m Second --date="2010-01-01 20:00:00" ' @@ -78,4 +80,46 @@ test_expect_success 'blame from previous revision' ' test_cmp expected result ' +cat >expected <<EOF +(Number2 2010-01-01 20:00:00 +0000 1) two.bin +EOF + +test_expect_success 'blame with --no-textconv (on symlink)' ' + git blame --no-textconv symlink.bin >blame && + find_blame <blame >result && + test_cmp expected result +' + +# fails with '...symlink.bin is not "binary" file' +test_expect_failure 'blame --textconv (on symlink)' ' + git blame --textconv symlink.bin >blame && + find_blame <blame >result && + test_cmp expected result +' + +# cp two.bin three.bin and make small tweak +# (this will direct blame -C -C three.bin to consider two.bin and symlink.bin) +test_expect_success 'make another new commit' ' + echo "bin: test number 2" >three.bin && + echo "bin: test number 2 version 2" >>three.bin && + echo "bin: test number 2 version 3" >>three.bin && + echo "bin: test number 3" >>three.bin && + git add three.bin && + GIT_AUTHOR_NAME=Number4 git commit -a -m Fourth --date="2010-01-01 23:00:00" +' + +cat >expected <<EOF +(Number1 2010-01-01 18:00:00 +0000 1) converted: test number 2 +(Number2 2010-01-01 20:00:00 +0000 2) converted: test number 2 version 2 +(Number3 2010-01-01 22:00:00 +0000 3) converted: test number 2 version 3 +(Number4 2010-01-01 23:00:00 +0000 4) converted: test number 3 +EOF + +# fails with '...symlink.bin is not "binary" file' +test_expect_failure 'blame on last commit (-C -C, symlink)' ' + git blame -C -C three.bin >blame && + find_blame <blame >result && + test_cmp expected result +' + test_done diff --git a/t/t8007-cat-file-textconv.sh b/t/t8007-cat-file-textconv.sh index 413d623..dfb2b04 100755 --- a/t/t8007-cat-file-textconv.sh +++ b/t/t8007-cat-file-textconv.sh @@ -12,6 +12,7 @@ chmod +x helper test_expect_success 'setup ' ' echo "bin: test" >one.bin && + ln -s one.bin symlink.bin && git add . && GIT_AUTHOR_NAME=Number1 git commit -a -m First --date="2010-01-01 18:00:00" && echo "bin: test version 2" >one.bin && @@ -68,4 +69,32 @@ test_expect_success 'cat-file --textconv on previous commit' ' git cat-file --textconv HEAD^:one.bin >result && test_cmp expected result ' + +echo -n "one.bin" >expected + +test_expect_success 'cat-file without --textconv (symlink)' ' + git cat-file blob :symlink.bin >result && + test_cmp expected result +' + +cat >expected <<EOF +fatal: git cat-file --textconv: unable to run textconv on :symlink.bin +EOF + +# fails because cat-file tries to run converter on symlink.bin +test_expect_failure 'cat-file --textconv on index (symlink)' ' + ! git cat-file --textconv :symlink.bin 2>result && + test_cmp expected result +' + +cat >expected <<EOF +fatal: git cat-file --textconv: unable to run textconv on HEAD:symlink.bin +EOF + +# fails because cat-file tries to run converter on symlink.bin +test_expect_failure 'cat-file --textconv on HEAD (symlink)' ' + ! git cat-file --textconv HEAD:symlink.bin 2>result && + test_cmp expected result +' + test_done -- 1.7.3.rc2 -- 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