| #!/bin/sh |
| # |
| # Copyright (c) 2005 Junio C Hamano |
| # Copyright (c) 2005 Robert Fitzsimons |
| # |
| |
| test_description='git apply test patches with multiple fragments. |
| |
| ' |
| . ./test-lib.sh |
| |
| # setup |
| |
| cat > patch1.patch <<\EOF |
| diff --git a/main.c b/main.c |
| new file mode 100644 |
| --- /dev/null |
| +++ b/main.c |
| @@ -0,0 +1,23 @@ |
| +#include <stdio.h> |
| + |
| +int func(int num); |
| +void print_int(int num); |
| + |
| +int main() { |
| + int i; |
| + |
| + for (i = 0; i < 10; i++) { |
| + print_int(func(i)); |
| + } |
| + |
| + return 0; |
| +} |
| + |
| +int func(int num) { |
| + return num * num; |
| +} |
| + |
| +void print_int(int num) { |
| + printf("%d", num); |
| +} |
| + |
| EOF |
| cat > patch2.patch <<\EOF |
| diff --git a/main.c b/main.c |
| --- a/main.c |
| +++ b/main.c |
| @@ -1,7 +1,9 @@ |
| +#include <stdlib.h> |
| #include <stdio.h> |
| |
| int func(int num); |
| void print_int(int num); |
| +void print_ln(); |
| |
| int main() { |
| int i; |
| @@ -10,6 +12,8 @@ |
| print_int(func(i)); |
| } |
| |
| + print_ln(); |
| + |
| return 0; |
| } |
| |
| @@ -21,3 +25,7 @@ |
| printf("%d", num); |
| } |
| |
| +void print_ln() { |
| + printf("\n"); |
| +} |
| + |
| EOF |
| cat > patch3.patch <<\EOF |
| diff --git a/main.c b/main.c |
| --- a/main.c |
| +++ b/main.c |
| @@ -1,9 +1,7 @@ |
| -#include <stdlib.h> |
| #include <stdio.h> |
| |
| int func(int num); |
| void print_int(int num); |
| -void print_ln(); |
| |
| int main() { |
| int i; |
| @@ -12,8 +10,6 @@ |
| print_int(func(i)); |
| } |
| |
| - print_ln(); |
| - |
| return 0; |
| } |
| |
| @@ -25,7 +21,3 @@ |
| printf("%d", num); |
| } |
| |
| -void print_ln() { |
| - printf("\n"); |
| -} |
| - |
| EOF |
| cat > patch4.patch <<\EOF |
| diff --git a/main.c b/main.c |
| --- a/main.c |
| +++ b/main.c |
| @@ -1,13 +1,14 @@ |
| #include <stdio.h> |
| |
| int func(int num); |
| -void print_int(int num); |
| +int func2(int num); |
| |
| int main() { |
| int i; |
| |
| for (i = 0; i < 10; i++) { |
| - print_int(func(i)); |
| + printf("%d", func(i)); |
| + printf("%d", func3(i)); |
| } |
| |
| return 0; |
| @@ -17,7 +18,7 @@ |
| return num * num; |
| } |
| |
| -void print_int(int num) { |
| - printf("%d", num); |
| +int func2(int num) { |
| + return num * num * num; |
| } |
| |
| EOF |
| |
| test_expect_success "S = git apply (1)" \ |
| 'git apply patch1.patch patch2.patch' |
| mv main.c main.c.git |
| |
| test_expect_success "S = patch (1)" \ |
| 'cat patch1.patch patch2.patch | patch -p1' |
| |
| test_expect_success "S = cmp (1)" \ |
| 'cmp main.c.git main.c' |
| |
| rm -f main.c main.c.git |
| |
| test_expect_success "S = git apply (2)" \ |
| 'git apply patch1.patch patch2.patch patch3.patch' |
| mv main.c main.c.git |
| |
| test_expect_success "S = patch (2)" \ |
| 'cat patch1.patch patch2.patch patch3.patch | patch -p1' |
| |
| test_expect_success "S = cmp (2)" \ |
| 'cmp main.c.git main.c' |
| |
| rm -f main.c main.c.git |
| |
| test_expect_success "S = git apply (3)" \ |
| 'git apply patch1.patch patch4.patch' |
| mv main.c main.c.git |
| |
| test_expect_success "S = patch (3)" \ |
| 'cat patch1.patch patch4.patch | patch -p1' |
| |
| test_expect_success "S = cmp (3)" \ |
| 'cmp main.c.git main.c' |
| |
| test_done |
| |