t4015: modernise style

Move the preparatory steps that create the expected output inside
the test bodies, remove unnecessary blank lines before and after the
test bodies, and drop SP between redirection operator and its target.

Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Junio C Hamano 2015-05-26 11:19:52 -07:00
parent fdf96a20ac
commit d55ef3e044

View file

@ -9,138 +9,144 @@ test_description='Test special whitespace in diff engine.
. ./test-lib.sh . ./test-lib.sh
. "$TEST_DIRECTORY"/diff-lib.sh . "$TEST_DIRECTORY"/diff-lib.sh
# Ray Lehtiniemi's example test_expect_success "Ray Lehtiniemi's example" '
cat <<-\EOF >x &&
do {
nothing;
} while (0);
EOF
git update-index --add x &&
cat << EOF > x cat <<-\EOF >x &&
do { do
nothing; {
} while (0); nothing;
EOF }
while (0);
EOF
git update-index --add x cat <<-\EOF >expect &&
diff --git a/x b/x
index adf3937..6edc172 100644
--- a/x
+++ b/x
@@ -1,3 +1,5 @@
-do {
+do
+{
nothing;
-} while (0);
+}
+while (0);
EOF
cat << EOF > x git diff >out &&
do test_cmp expect out &&
{
nothing;
}
while (0);
EOF
cat << EOF > expect git diff -w >out &&
diff --git a/x b/x test_cmp expect out &&
index adf3937..6edc172 100644
--- a/x
+++ b/x
@@ -1,3 +1,5 @@
-do {
+do
+{
nothing;
-} while (0);
+}
+while (0);
EOF
git diff > out git diff -b >out &&
test_expect_success "Ray's example without options" 'test_cmp expect out' test_cmp expect out
'
git diff -w > out test_expect_success 'another test, without options' '
test_expect_success "Ray's example with -w" 'test_cmp expect out' tr Q "\015" <<-\EOF >x &&
git diff -b > out
test_expect_success "Ray's example with -b" 'test_cmp expect out'
tr 'Q' '\015' << EOF > x
whitespace at beginning
whitespace change
whitespace in the middle
whitespace at end
unchanged line
CR at endQ
EOF
git update-index x
tr '_' ' ' << EOF > x
whitespace at beginning whitespace at beginning
whitespace change whitespace change
white space in the middle whitespace in the middle
whitespace at end__ whitespace at end
unchanged line unchanged line
CR at end CR at endQ
EOF EOF
tr 'Q_' '\015 ' << EOF > expect git update-index x &&
diff --git a/x b/x
index d99af23..8b32fb5 100644
--- a/x
+++ b/x
@@ -1,6 +1,6 @@
-whitespace at beginning
-whitespace change
-whitespace in the middle
-whitespace at end
+ whitespace at beginning
+whitespace change
+white space in the middle
+whitespace at end__
unchanged line
-CR at endQ
+CR at end
EOF
git diff > out
test_expect_success 'another test, without options' 'test_cmp expect out'
cat << EOF > expect tr "_" " " <<-\EOF >x &&
EOF _ whitespace at beginning
git diff -w > out whitespace change
test_expect_success 'another test, with -w' 'test_cmp expect out' white space in the middle
git diff -w -b > out whitespace at end__
test_expect_success 'another test, with -w -b' 'test_cmp expect out' unchanged line
git diff -w --ignore-space-at-eol > out CR at end
test_expect_success 'another test, with -w --ignore-space-at-eol' 'test_cmp expect out' EOF
git diff -w -b --ignore-space-at-eol > out
test_expect_success 'another test, with -w -b --ignore-space-at-eol' 'test_cmp expect out'
tr 'Q_' '\015 ' << EOF > expect tr "Q_" "\015 " <<-\EOF >expect &&
diff --git a/x b/x diff --git a/x b/x
index d99af23..8b32fb5 100644 index d99af23..22d9f73 100644
--- a/x --- a/x
+++ b/x +++ b/x
@@ -1,6 +1,6 @@ @@ -1,6 +1,6 @@
-whitespace at beginning -whitespace at beginning
+ whitespace at beginning -whitespace change
whitespace change -whitespace in the middle
-whitespace in the middle -whitespace at end
+white space in the middle + whitespace at beginning
whitespace at end__ +whitespace change
unchanged line +white space in the middle
CR at end +whitespace at end__
EOF unchanged line
git diff -b > out -CR at endQ
test_expect_success 'another test, with -b' 'test_cmp expect out' +CR at end
git diff -b --ignore-space-at-eol > out EOF
test_expect_success 'another test, with -b --ignore-space-at-eol' 'test_cmp expect out'
tr 'Q_' '\015 ' << EOF > expect git diff >out &&
diff --git a/x b/x test_cmp expect out &&
index d99af23..8b32fb5 100644
--- a/x >expect &&
+++ b/x git diff -w >out &&
@@ -1,6 +1,6 @@ test_cmp expect out &&
-whitespace at beginning
-whitespace change git diff -w -b >out &&
-whitespace in the middle test_cmp expect out &&
+ whitespace at beginning
+whitespace change git diff -w --ignore-space-at-eol >out &&
+white space in the middle test_cmp expect out &&
whitespace at end__
unchanged line git diff -w -b --ignore-space-at-eol >out &&
CR at end test_cmp expect out &&
EOF
git diff --ignore-space-at-eol > out
test_expect_success 'another test, with --ignore-space-at-eol' 'test_cmp expect out' tr "Q_" "\015 " <<-\EOF >expect &&
diff --git a/x b/x
index d99af23..22d9f73 100644
--- a/x
+++ b/x
@@ -1,6 +1,6 @@
-whitespace at beginning
+_ whitespace at beginning
whitespace change
-whitespace in the middle
+white space in the middle
whitespace at end__
unchanged line
CR at end
EOF
git diff -b >out &&
test_cmp expect out &&
git diff -b --ignore-space-at-eol >out &&
test_cmp expect out &&
tr "Q_" "\015 " <<-\EOF >expect &&
diff --git a/x b/x
index d99af23..22d9f73 100644
--- a/x
+++ b/x
@@ -1,6 +1,6 @@
-whitespace at beginning
-whitespace change
-whitespace in the middle
+_ whitespace at beginning
+whitespace change
+white space in the middle
whitespace at end__
unchanged line
CR at end
EOF
git diff --ignore-space-at-eol >out &&
test_cmp expect out
'
test_expect_success 'ignore-blank-lines: only new lines' ' test_expect_success 'ignore-blank-lines: only new lines' '
test_seq 5 >x && test_seq 5 >x &&
@ -489,291 +495,219 @@ test_expect_success 'ignore-blank-lines: mix changes and blank lines' '
' '
test_expect_success 'check mixed spaces and tabs in indent' ' test_expect_success 'check mixed spaces and tabs in indent' '
# This is indented with SP HT SP. # This is indented with SP HT SP.
echo " foo();" > x && echo " foo();" >x &&
git diff --check | grep "space before tab in indent" git diff --check | grep "space before tab in indent"
' '
test_expect_success 'check mixed tabs and spaces in indent' ' test_expect_success 'check mixed tabs and spaces in indent' '
# This is indented with HT SP HT. # This is indented with HT SP HT.
echo " foo();" > x && echo " foo();" >x &&
git diff --check | grep "space before tab in indent" git diff --check | grep "space before tab in indent"
' '
test_expect_success 'check with no whitespace errors' ' test_expect_success 'check with no whitespace errors' '
git commit -m "snapshot" && git commit -m "snapshot" &&
echo "foo();" > x && echo "foo();" >x &&
git diff --check git diff --check
' '
test_expect_success 'check with trailing whitespace' ' test_expect_success 'check with trailing whitespace' '
echo "foo(); " >x &&
echo "foo(); " > x &&
test_must_fail git diff --check test_must_fail git diff --check
' '
test_expect_success 'check with space before tab in indent' ' test_expect_success 'check with space before tab in indent' '
# indent has space followed by hard tab # indent has space followed by hard tab
echo " foo();" > x && echo " foo();" >x &&
test_must_fail git diff --check test_must_fail git diff --check
' '
test_expect_success '--check and --exit-code are not exclusive' ' test_expect_success '--check and --exit-code are not exclusive' '
git checkout x && git checkout x &&
git diff --check --exit-code git diff --check --exit-code
' '
test_expect_success '--check and --quiet are not exclusive' ' test_expect_success '--check and --quiet are not exclusive' '
git diff --check --quiet git diff --check --quiet
' '
test_expect_success 'check staged with no whitespace errors' ' test_expect_success 'check staged with no whitespace errors' '
echo "foo();" >x &&
echo "foo();" > x &&
git add x && git add x &&
git diff --cached --check git diff --cached --check
' '
test_expect_success 'check staged with trailing whitespace' ' test_expect_success 'check staged with trailing whitespace' '
echo "foo(); " >x &&
echo "foo(); " > x &&
git add x && git add x &&
test_must_fail git diff --cached --check test_must_fail git diff --cached --check
' '
test_expect_success 'check staged with space before tab in indent' ' test_expect_success 'check staged with space before tab in indent' '
# indent has space followed by hard tab # indent has space followed by hard tab
echo " foo();" > x && echo " foo();" >x &&
git add x && git add x &&
test_must_fail git diff --cached --check test_must_fail git diff --cached --check
' '
test_expect_success 'check with no whitespace errors (diff-index)' ' test_expect_success 'check with no whitespace errors (diff-index)' '
echo "foo();" >x &&
echo "foo();" > x &&
git add x && git add x &&
git diff-index --check HEAD git diff-index --check HEAD
' '
test_expect_success 'check with trailing whitespace (diff-index)' ' test_expect_success 'check with trailing whitespace (diff-index)' '
echo "foo(); " >x &&
echo "foo(); " > x &&
git add x && git add x &&
test_must_fail git diff-index --check HEAD test_must_fail git diff-index --check HEAD
' '
test_expect_success 'check with space before tab in indent (diff-index)' ' test_expect_success 'check with space before tab in indent (diff-index)' '
# indent has space followed by hard tab # indent has space followed by hard tab
echo " foo();" > x && echo " foo();" >x &&
git add x && git add x &&
test_must_fail git diff-index --check HEAD test_must_fail git diff-index --check HEAD
' '
test_expect_success 'check staged with no whitespace errors (diff-index)' ' test_expect_success 'check staged with no whitespace errors (diff-index)' '
echo "foo();" >x &&
echo "foo();" > x &&
git add x && git add x &&
git diff-index --cached --check HEAD git diff-index --cached --check HEAD
' '
test_expect_success 'check staged with trailing whitespace (diff-index)' ' test_expect_success 'check staged with trailing whitespace (diff-index)' '
echo "foo(); " >x &&
echo "foo(); " > x &&
git add x && git add x &&
test_must_fail git diff-index --cached --check HEAD test_must_fail git diff-index --cached --check HEAD
' '
test_expect_success 'check staged with space before tab in indent (diff-index)' ' test_expect_success 'check staged with space before tab in indent (diff-index)' '
# indent has space followed by hard tab # indent has space followed by hard tab
echo " foo();" > x && echo " foo();" >x &&
git add x && git add x &&
test_must_fail git diff-index --cached --check HEAD test_must_fail git diff-index --cached --check HEAD
' '
test_expect_success 'check with no whitespace errors (diff-tree)' ' test_expect_success 'check with no whitespace errors (diff-tree)' '
echo "foo();" >x &&
echo "foo();" > x &&
git commit -m "new commit" x && git commit -m "new commit" x &&
git diff-tree --check HEAD^ HEAD git diff-tree --check HEAD^ HEAD
' '
test_expect_success 'check with trailing whitespace (diff-tree)' ' test_expect_success 'check with trailing whitespace (diff-tree)' '
echo "foo(); " >x &&
echo "foo(); " > x &&
git commit -m "another commit" x && git commit -m "another commit" x &&
test_must_fail git diff-tree --check HEAD^ HEAD test_must_fail git diff-tree --check HEAD^ HEAD
' '
test_expect_success 'check with space before tab in indent (diff-tree)' ' test_expect_success 'check with space before tab in indent (diff-tree)' '
# indent has space followed by hard tab # indent has space followed by hard tab
echo " foo();" > x && echo " foo();" >x &&
git commit -m "yet another" x && git commit -m "yet another" x &&
test_must_fail git diff-tree --check HEAD^ HEAD test_must_fail git diff-tree --check HEAD^ HEAD
' '
test_expect_success 'check trailing whitespace (trailing-space: off)' ' test_expect_success 'check trailing whitespace (trailing-space: off)' '
git config core.whitespace "-trailing-space" && git config core.whitespace "-trailing-space" &&
echo "foo (); " > x && echo "foo (); " >x &&
git diff --check git diff --check
' '
test_expect_success 'check trailing whitespace (trailing-space: on)' ' test_expect_success 'check trailing whitespace (trailing-space: on)' '
git config core.whitespace "trailing-space" && git config core.whitespace "trailing-space" &&
echo "foo (); " > x && echo "foo (); " >x &&
test_must_fail git diff --check test_must_fail git diff --check
' '
test_expect_success 'check space before tab in indent (space-before-tab: off)' ' test_expect_success 'check space before tab in indent (space-before-tab: off)' '
# indent contains space followed by HT # indent contains space followed by HT
git config core.whitespace "-space-before-tab" && git config core.whitespace "-space-before-tab" &&
echo " foo ();" > x && echo " foo ();" >x &&
git diff --check git diff --check
' '
test_expect_success 'check space before tab in indent (space-before-tab: on)' ' test_expect_success 'check space before tab in indent (space-before-tab: on)' '
# indent contains space followed by HT # indent contains space followed by HT
git config core.whitespace "space-before-tab" && git config core.whitespace "space-before-tab" &&
echo " foo (); " > x && echo " foo (); " >x &&
test_must_fail git diff --check test_must_fail git diff --check
' '
test_expect_success 'check spaces as indentation (indent-with-non-tab: off)' ' test_expect_success 'check spaces as indentation (indent-with-non-tab: off)' '
git config core.whitespace "-indent-with-non-tab" && git config core.whitespace "-indent-with-non-tab" &&
echo " foo ();" > x && echo " foo ();" >x &&
git diff --check git diff --check
' '
test_expect_success 'check spaces as indentation (indent-with-non-tab: on)' ' test_expect_success 'check spaces as indentation (indent-with-non-tab: on)' '
git config core.whitespace "indent-with-non-tab" && git config core.whitespace "indent-with-non-tab" &&
echo " foo ();" > x && echo " foo ();" >x &&
test_must_fail git diff --check test_must_fail git diff --check
' '
test_expect_success 'ditto, but tabwidth=9' ' test_expect_success 'ditto, but tabwidth=9' '
git config core.whitespace "indent-with-non-tab,tabwidth=9" && git config core.whitespace "indent-with-non-tab,tabwidth=9" &&
git diff --check git diff --check
' '
test_expect_success 'check tabs and spaces as indentation (indent-with-non-tab: on)' ' test_expect_success 'check tabs and spaces as indentation (indent-with-non-tab: on)' '
git config core.whitespace "indent-with-non-tab" && git config core.whitespace "indent-with-non-tab" &&
echo " foo ();" > x && echo " foo ();" >x &&
test_must_fail git diff --check test_must_fail git diff --check
' '
test_expect_success 'ditto, but tabwidth=10' ' test_expect_success 'ditto, but tabwidth=10' '
git config core.whitespace "indent-with-non-tab,tabwidth=10" && git config core.whitespace "indent-with-non-tab,tabwidth=10" &&
test_must_fail git diff --check test_must_fail git diff --check
' '
test_expect_success 'ditto, but tabwidth=20' ' test_expect_success 'ditto, but tabwidth=20' '
git config core.whitespace "indent-with-non-tab,tabwidth=20" && git config core.whitespace "indent-with-non-tab,tabwidth=20" &&
git diff --check git diff --check
' '
test_expect_success 'check tabs as indentation (tab-in-indent: off)' ' test_expect_success 'check tabs as indentation (tab-in-indent: off)' '
git config core.whitespace "-tab-in-indent" && git config core.whitespace "-tab-in-indent" &&
echo " foo ();" > x && echo " foo ();" >x &&
git diff --check git diff --check
' '
test_expect_success 'check tabs as indentation (tab-in-indent: on)' ' test_expect_success 'check tabs as indentation (tab-in-indent: on)' '
git config core.whitespace "tab-in-indent" && git config core.whitespace "tab-in-indent" &&
echo " foo ();" > x && echo " foo ();" >x &&
test_must_fail git diff --check test_must_fail git diff --check
' '
test_expect_success 'check tabs and spaces as indentation (tab-in-indent: on)' ' test_expect_success 'check tabs and spaces as indentation (tab-in-indent: on)' '
git config core.whitespace "tab-in-indent" && git config core.whitespace "tab-in-indent" &&
echo " foo ();" > x && echo " foo ();" >x &&
test_must_fail git diff --check test_must_fail git diff --check
' '
test_expect_success 'ditto, but tabwidth=1 (must be irrelevant)' ' test_expect_success 'ditto, but tabwidth=1 (must be irrelevant)' '
git config core.whitespace "tab-in-indent,tabwidth=1" && git config core.whitespace "tab-in-indent,tabwidth=1" &&
test_must_fail git diff --check test_must_fail git diff --check
' '
test_expect_success 'check tab-in-indent and indent-with-non-tab conflict' ' test_expect_success 'check tab-in-indent and indent-with-non-tab conflict' '
git config core.whitespace "tab-in-indent,indent-with-non-tab" && git config core.whitespace "tab-in-indent,indent-with-non-tab" &&
echo "foo ();" > x && echo "foo ();" >x &&
test_must_fail git diff --check test_must_fail git diff --check
' '
test_expect_success 'check tab-in-indent excluded from wildcard whitespace attribute' ' test_expect_success 'check tab-in-indent excluded from wildcard whitespace attribute' '
git config --unset core.whitespace && git config --unset core.whitespace &&
echo "x whitespace" > .gitattributes && echo "x whitespace" >.gitattributes &&
echo " foo ();" > x && echo " foo ();" >x &&
git diff --check && git diff --check &&
rm -f .gitattributes rm -f .gitattributes
' '
test_expect_success 'line numbers in --check output are correct' ' test_expect_success 'line numbers in --check output are correct' '
echo "" >x &&
echo "" > x && echo "foo(); " >>x &&
echo "foo(); " >> x &&
git diff --check | grep "x:2:" git diff --check | grep "x:2:"
' '
test_expect_success 'checkdiff detects new trailing blank lines (1)' ' test_expect_success 'checkdiff detects new trailing blank lines (1)' '
@ -878,26 +812,27 @@ test_expect_success 'setup diff colors' '
git config color.diff.commit yellow && git config color.diff.commit yellow &&
git config color.diff.whitespace "normal red" && git config color.diff.whitespace "normal red" &&
git config core.autocrlf false git config core.autocrlf false &&
cat >expected <<-\EOF
<BOLD>diff --git a/x b/x<RESET>
<BOLD>index 9daeafb..2874b91 100644<RESET>
<BOLD>--- a/x<RESET>
<BOLD>+++ b/x<RESET>
<CYAN>@@ -1 +1,4 @@<RESET>
test<RESET>
<GREEN>+<RESET><GREEN>{<RESET>
<GREEN>+<RESET><BRED> <RESET>
<GREEN>+<RESET><GREEN>}<RESET>
EOF
' '
cat >expected <<\EOF
<BOLD>diff --git a/x b/x<RESET>
<BOLD>index 9daeafb..2874b91 100644<RESET>
<BOLD>--- a/x<RESET>
<BOLD>+++ b/x<RESET>
<CYAN>@@ -1 +1,4 @@<RESET>
test<RESET>
<GREEN>+<RESET><GREEN>{<RESET>
<GREEN>+<RESET><BRED> <RESET>
<GREEN>+<RESET><GREEN>}<RESET>
EOF
test_expect_success 'diff that introduces a line with only tabs' ' test_expect_success 'diff that introduces a line with only tabs' '
git config core.whitespace blank-at-eol && git config core.whitespace blank-at-eol &&
git reset --hard && git reset --hard &&
echo "test" > x && echo "test" >x &&
git commit -m "initial" x && git commit -m "initial" x &&
echo "{NTN}" | tr "NT" "\n\t" >> x && echo "{NTN}" | tr "NT" "\n\t" >>x &&
git -c color.diff=always diff | test_decode_color >current && git -c color.diff=always diff | test_decode_color >current &&
test_cmp expected current test_cmp expected current
' '