diff options
author | Junio C Hamano <gitster@pobox.com> | 2011-01-05 13:31:01 -0800 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2011-01-05 13:31:01 -0800 |
commit | 9e98354ab9717480e2e15b5ae56c10c3d5702a9b (patch) | |
tree | 716ed1df67e67bd8dccaca8909af135452806614 /t | |
parent | 0c30ed0cb57988378d721d817c55f74a93dffb13 (diff) | |
parent | 4290f690676bc14c49c7cddbcda1c09017948718 (diff) | |
download | git-9e98354ab9717480e2e15b5ae56c10c3d5702a9b.tar.gz git-9e98354ab9717480e2e15b5ae56c10c3d5702a9b.tar.xz |
Merge branch 'pw/convert-pathname-substitution'
* pw/convert-pathname-substitution:
t0021: avoid getting filter killed with SIGPIPE
convert filter: supply path to external driver
Diffstat (limited to 't')
-rwxr-xr-x | t/t0021-conversion.sh | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/t/t0021-conversion.sh b/t/t0021-conversion.sh index 828e35baf..9078b84ae 100755 --- a/t/t0021-conversion.sh +++ b/t/t0021-conversion.sh @@ -93,4 +93,47 @@ test_expect_success expanded_in_repo ' cmp expanded-keywords expected-output ' +# The use of %f in a filter definition is expanded to the path to +# the filename being smudged or cleaned. It must be shell escaped. +# First, set up some interesting file names and pet them in +# .gitattributes. +test_expect_success 'filter shell-escaped filenames' ' + cat >argc.sh <<-EOF && + #!$SHELL_PATH + cat >/dev/null + echo argc: \$# "\$@" + EOF + normal=name-no-magic && + special="name with '\''sq'\'' and \$x" && + echo some test text >"$normal" && + echo some test text >"$special" && + git add "$normal" "$special" && + git commit -q -m "add files" && + echo "name* filter=argc" >.gitattributes && + + # delete the files and check them out again, using a smudge filter + # that will count the args and echo the command-line back to us + git config filter.argc.smudge "sh ./argc.sh %f" && + rm "$normal" "$special" && + git checkout -- "$normal" "$special" && + + # make sure argc.sh counted the right number of args + echo "argc: 1 $normal" >expect && + test_cmp expect "$normal" && + echo "argc: 1 $special" >expect && + test_cmp expect "$special" && + + # do the same thing, but with more args in the filter expression + git config filter.argc.smudge "sh ./argc.sh %f --my-extra-arg" && + rm "$normal" "$special" && + git checkout -- "$normal" "$special" && + + # make sure argc.sh counted the right number of args + echo "argc: 2 $normal --my-extra-arg" >expect && + test_cmp expect "$normal" && + echo "argc: 2 $special --my-extra-arg" >expect && + test_cmp expect "$special" && + : +' + test_done |