1#!/bin/sh
   2#
   3# Copyright (c) 2009 Giuseppe Bilotta
   4#
   5test_description='git-apply --ignore-whitespace.
   7'
   9. ./test-lib.sh
  10# This primes main.c file that indents without using HT at all.
  12# Various patches with HT and other spaces are attempted in the test.
  13cat > patch1.patch <<\EOF
  15diff --git a/main.c b/main.c
  16new file mode 100644
  17--- /dev/null
  18+++ b/main.c
  19@@ -0,0 +1,22 @@
  20+#include <stdio.h>
  21+
  22+void print_int(int num);
  23+int func(int num);
  24+
  25+int main() {
  26+       int i;
  27+
  28+       for (i = 0; i < 10; i++) {
  29+               print_int(func(i)); /* stuff */
  30+       }
  31+
  32+       return 0;
  33+}
  34+
  35+int func(int num) {
  36+       return num * num;
  37+}
  38+
  39+void print_int(int num) {
  40+       printf("%d", num);
  41+}
  42EOF
  43# Since whitespace is very significant and we want to prevent whitespace
  45# mangling when creating this test from a patch, we protect 'fixable'
  46# whitespace by replacing spaces with Z and replacing them at patch
  47# creation time, hence the sed trick.
  48# This patch will fail unless whitespace differences are being ignored
  50sed -e 's/Z/ /g' > patch2.patch <<\EOF
  52diff --git a/main.c b/main.c
  53--- a/main.c
  54+++ b/main.c
  55@@ -10,6 +10,8 @@
  56Z               print_int(func(i)); /* stuff */
  57Z       }
  58Z
  59+       printf("\n");
  60+
  61Z       return 0;
  62Z}
  63Z
  64EOF
  65# This patch will fail even if whitespace differences are being ignored,
  67# because of the missing string at EOL. TODO: this testcase should be
  68# improved by creating a line that has the same hash with and without
  69# the final string.
  70sed -e 's/Z/ /g' > patch3.patch <<\EOF
  72diff --git a/main.c b/main.c
  73--- a/main.c
  74+++ b/main.c
  75@@ -10,3 +10,4 @@
  76Z       for (i = 0; i < 10; i++) {
  77Z               print_int(func(i));Z
  78+               /* stuff */
  79Z       }
  80EOF
  81# This patch will fail even if whitespace differences are being ignored,
  83# because of the missing EOL at EOF.
  84sed -e 's/Z/ /g' > patch4.patch <<\EOF
  86diff --git a/main.c b/main.c
  87--- a/main.c
  88+++ b/main.c
  89@@ -21,1 +21,1 @@
  90-       };Z
  91\ No newline at end of file
  92+       };
  93EOF
  94# This patch will fail unless whitespace differences are being ignored.
  96sed -e 's/Z/ /g' > patch5.patch <<\EOF
  98diff --git a/main.c b/main.c
  99--- a/main.c
 100+++ b/main.c
 101@@ -2,2 +2,3 @@
 102Z       void print_int(int num);
 103+       /* a comment */
 104Z       int func(int num);
 105EOF
 106# And this is how the final output should be.  Patches introduce
 108# HTs but the original SP indents are mostly kept.
 109sed -e 's/T/    /g' > main.c.final <<\EOF
 111#include <stdio.h>
 112void print_int(int num);
 114int func(int num);
 115int main() {
 117       int i;
 118       for (i = 0; i < 10; i++) {
 120               print_int(func(i)); /* stuff */
 121       }
 122Tprintf("\n");
 124       return 0;
 126}
 127int func(int num) {
 129       return num * num;
 130}
 131void print_int(int num) {
 133       printf("%d", num);
 134}
 135EOF
 136test_expect_success 'file creation' '
 138        git apply patch1.patch
 139'
 140test_expect_success 'patch2 fails (retab)' '
 142        test_must_fail git apply patch2.patch
 143'
 144test_expect_success 'patch2 applies with --ignore-whitespace' '
 146        git apply --ignore-whitespace patch2.patch
 147'
 148test_expect_success 'patch2 reverse applies with --ignore-space-change' '
 150        git apply -R --ignore-space-change patch2.patch
 151'
 152git config apply.ignorewhitespace change
 154test_expect_success 'patch2 applies (apply.ignorewhitespace = change)' '
 156        git apply patch2.patch &&
 157        test_cmp main.c.final main.c
 158'
 159test_expect_success 'patch3 fails (missing string at EOL)' '
 161        test_must_fail git apply patch3.patch
 162'
 163test_expect_success 'patch4 fails (missing EOL at EOF)' '
 165        test_must_fail git apply patch4.patch
 166'
 167test_expect_success 'patch5 fails (leading whitespace differences matter)' '
 169        test_must_fail git apply patch5.patch
 170'
 171test_expect_success 're-create file (with --ignore-whitespace)' '
 173        rm -f main.c &&
 174        git apply patch1.patch
 175'
 176test_expect_success 'patch5 fails (--no-ignore-whitespace)' '
 178        test_must_fail git apply --no-ignore-whitespace patch5.patch
 179'
 180test_done