You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
173 lines
3.9 KiB
173 lines
3.9 KiB
#!/bin/sh |
|
|
|
test_description='diff.*.textconv tests' |
|
. ./test-lib.sh |
|
|
|
find_diff() { |
|
sed '1,/^index /d' | sed '/^-- $/,$d' |
|
} |
|
|
|
cat >expect.binary <<'EOF' |
|
Binary files a/file and b/file differ |
|
EOF |
|
|
|
cat >expect.text <<'EOF' |
|
--- a/file |
|
+++ b/file |
|
@@ -1 +1,2 @@ |
|
0 |
|
+1 |
|
EOF |
|
|
|
cat >hexdump <<'EOF' |
|
#!/bin/sh |
|
"$PERL_PATH" -e '$/ = undef; $_ = <>; s/./ord($&)/ge; print $_' < "$1" |
|
EOF |
|
chmod +x hexdump |
|
|
|
test_expect_success 'setup binary file with history' ' |
|
test_commit --printf one file "\\0\\n" && |
|
test_commit --printf --append two file "\\01\\n" |
|
' |
|
|
|
test_expect_success 'file is considered binary by porcelain' ' |
|
git diff HEAD^ HEAD >diff && |
|
find_diff <diff >actual && |
|
test_cmp expect.binary actual |
|
' |
|
|
|
test_expect_success 'file is considered binary by plumbing' ' |
|
git diff-tree -p HEAD^ HEAD >diff && |
|
find_diff <diff >actual && |
|
test_cmp expect.binary actual |
|
' |
|
|
|
test_expect_success 'setup textconv filters' ' |
|
echo file diff=foo >.gitattributes && |
|
git config diff.foo.textconv "\"$(pwd)\""/hexdump && |
|
git config diff.fail.textconv false |
|
' |
|
|
|
test_expect_success 'diff produces text' ' |
|
git diff HEAD^ HEAD >diff && |
|
find_diff <diff >actual && |
|
test_cmp expect.text actual |
|
' |
|
|
|
test_expect_success 'show commit produces text' ' |
|
git show HEAD >diff && |
|
find_diff <diff >actual && |
|
test_cmp expect.text actual |
|
' |
|
|
|
test_expect_success 'diff-tree produces binary' ' |
|
git diff-tree -p HEAD^ HEAD >diff && |
|
find_diff <diff >actual && |
|
test_cmp expect.binary actual |
|
' |
|
|
|
test_expect_success 'log produces text' ' |
|
git log -1 -p >log && |
|
find_diff <log >actual && |
|
test_cmp expect.text actual |
|
' |
|
|
|
test_expect_success 'format-patch produces binary' ' |
|
git format-patch --no-binary --stdout HEAD^ >patch && |
|
find_diff <patch >actual && |
|
test_cmp expect.binary actual |
|
' |
|
|
|
test_expect_success 'status -v produces text' ' |
|
git reset --soft HEAD^ && |
|
git status -v >diff && |
|
find_diff <diff >actual && |
|
test_cmp expect.text actual && |
|
git reset --soft HEAD@{1} |
|
' |
|
|
|
test_expect_success 'show blob produces binary' ' |
|
git show HEAD:file >actual && |
|
printf "\\0\\n\\01\\n" >expect && |
|
test_cmp expect actual |
|
' |
|
|
|
test_expect_success 'show --textconv blob produces text' ' |
|
git show --textconv HEAD:file >actual && |
|
printf "0\\n1\\n" >expect && |
|
test_cmp expect actual |
|
' |
|
|
|
test_expect_success 'show --no-textconv blob produces binary' ' |
|
git show --no-textconv HEAD:file >actual && |
|
printf "\\0\\n\\01\\n" >expect && |
|
test_cmp expect actual |
|
' |
|
|
|
test_expect_success 'grep-diff (-G) operates on textconv data (add)' ' |
|
echo one >expect && |
|
git log --root --format=%s -G0 >actual && |
|
test_cmp expect actual |
|
' |
|
|
|
test_expect_success 'grep-diff (-G) operates on textconv data (modification)' ' |
|
echo two >expect && |
|
git log --root --format=%s -G1 >actual && |
|
test_cmp expect actual |
|
' |
|
|
|
test_expect_success 'pickaxe (-S) operates on textconv data (add)' ' |
|
echo one >expect && |
|
git log --root --format=%s -S0 >actual && |
|
test_cmp expect actual |
|
' |
|
|
|
test_expect_success 'pickaxe (-S) operates on textconv data (modification)' ' |
|
echo two >expect && |
|
git log --root --format=%s -S1 >actual && |
|
test_cmp expect actual |
|
' |
|
|
|
cat >expect.stat <<'EOF' |
|
file | Bin 2 -> 4 bytes |
|
1 file changed, 0 insertions(+), 0 deletions(-) |
|
EOF |
|
test_expect_success 'diffstat does not run textconv' ' |
|
echo file diff=fail >.gitattributes && |
|
git diff --stat HEAD^ HEAD >actual && |
|
test_cmp expect.stat actual && |
|
|
|
head -n1 <expect.stat >expect.line1 && |
|
head -n1 <actual >actual.line1 && |
|
test_cmp expect.line1 actual.line1 |
|
' |
|
# restore working setup |
|
echo file diff=foo >.gitattributes |
|
|
|
symlink=$(git rev-parse --short $(printf frotz | git hash-object --stdin)) |
|
cat >expect.typechange <<EOF |
|
--- a/file |
|
+++ /dev/null |
|
@@ -1,2 +0,0 @@ |
|
-0 |
|
-1 |
|
diff --git a/file b/file |
|
new file mode 120000 |
|
index 0000000..$symlink |
|
--- /dev/null |
|
+++ b/file |
|
@@ -0,0 +1 @@ |
|
+frotz |
|
\ No newline at end of file |
|
EOF |
|
|
|
test_expect_success 'textconv does not act on symlinks' ' |
|
rm -f file && |
|
test_ln_s_add frotz file && |
|
git commit -m typechange && |
|
git show >diff && |
|
find_diff <diff >actual && |
|
test_cmp expect.typechange actual |
|
' |
|
|
|
test_done
|
|
|