t4018 (funcname patterns): make .gitattributes state easier to track

Most, but not all, tests in this script rely on attributes declaring
that files with a .java extension should use the "java" driver:

	*.java diff=java

Split out a "set up" test to put such a .gitattributes in place after
the tests that do not want it have run, to make it more likely that
individual tests other than this setup test can be safely modified,
rearranged, or skipped.  Presumably this setup code will learn to
request other drivers for other extensions in the same place when the
test suite learns to exercise other diff drivers.

Similarly, make sure that early test assertions that do not use these
default attributes set up .gitattributes appropriately for themselves,
so tests that run before can be modified with less risk of breaking
something.

Signed-off-by: Jonathan Nieder <jrnieder@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Jonathan Nieder 2011-05-21 14:11:33 -05:00 committed by Junio C Hamano
parent 9963e025e8
commit 5b5e45949b

View File

@ -41,6 +41,7 @@ do
grep "fatal" > /dev/null; } grep "fatal" > /dev/null; }
' '
test_expect_success "builtin $p wordRegex pattern compiles" ' test_expect_success "builtin $p wordRegex pattern compiles" '
echo "*.java diff=$p" >.gitattributes &&
! { git diff --no-index --word-diff \ ! { git diff --no-index --word-diff \
Beer.java Beer-correct.java 2>&1 | Beer.java Beer-correct.java 2>&1 |
grep "fatal" > /dev/null; } grep "fatal" > /dev/null; }
@ -53,8 +54,11 @@ test_expect_success 'default behaviour' '
grep "^@@.*@@ public class Beer" grep "^@@.*@@ public class Beer"
' '
test_expect_success 'set up .gitattributes declaring drivers to test' '
echo "*.java diff=java" >.gitattributes
'
test_expect_success 'preset java pattern' ' test_expect_success 'preset java pattern' '
echo "*.java diff=java" >.gitattributes &&
git diff --no-index Beer.java Beer-correct.java | git diff --no-index Beer.java Beer-correct.java |
grep "^@@.*@@ public static void main(" grep "^@@.*@@ public static void main("
' '