|  | #!/bin/sh | 
|  |  | 
|  | test_description='patience diff algorithm' | 
|  |  | 
|  | . ./test-lib.sh | 
|  |  | 
|  | cat >file1 <<\EOF | 
|  | #include <stdio.h> | 
|  |  | 
|  | // Frobs foo heartily | 
|  | int frobnitz(int foo) | 
|  | { | 
|  | int i; | 
|  | for(i = 0; i < 10; i++) | 
|  | { | 
|  | printf("Your answer is: "); | 
|  | printf("%d\n", foo); | 
|  | } | 
|  | } | 
|  |  | 
|  | int fact(int n) | 
|  | { | 
|  | if(n > 1) | 
|  | { | 
|  | return fact(n-1) * n; | 
|  | } | 
|  | return 1; | 
|  | } | 
|  |  | 
|  | int main(int argc, char **argv) | 
|  | { | 
|  | frobnitz(fact(10)); | 
|  | } | 
|  | EOF | 
|  |  | 
|  | cat >file2 <<\EOF | 
|  | #include <stdio.h> | 
|  |  | 
|  | int fib(int n) | 
|  | { | 
|  | if(n > 2) | 
|  | { | 
|  | return fib(n-1) + fib(n-2); | 
|  | } | 
|  | return 1; | 
|  | } | 
|  |  | 
|  | // Frobs foo heartily | 
|  | int frobnitz(int foo) | 
|  | { | 
|  | int i; | 
|  | for(i = 0; i < 10; i++) | 
|  | { | 
|  | printf("%d\n", foo); | 
|  | } | 
|  | } | 
|  |  | 
|  | int main(int argc, char **argv) | 
|  | { | 
|  | frobnitz(fib(10)); | 
|  | } | 
|  | EOF | 
|  |  | 
|  | cat >expect <<\EOF | 
|  | diff --git a/file1 b/file2 | 
|  | index 6faa5a3..e3af329 100644 | 
|  | --- a/file1 | 
|  | +++ b/file2 | 
|  | @@ -1,26 +1,25 @@ | 
|  | #include <stdio.h> | 
|  |  | 
|  | +int fib(int n) | 
|  | +{ | 
|  | +    if(n > 2) | 
|  | +    { | 
|  | +        return fib(n-1) + fib(n-2); | 
|  | +    } | 
|  | +    return 1; | 
|  | +} | 
|  | + | 
|  | // Frobs foo heartily | 
|  | int frobnitz(int foo) | 
|  | { | 
|  | int i; | 
|  | for(i = 0; i < 10; i++) | 
|  | { | 
|  | -        printf("Your answer is: "); | 
|  | printf("%d\n", foo); | 
|  | } | 
|  | } | 
|  |  | 
|  | -int fact(int n) | 
|  | -{ | 
|  | -    if(n > 1) | 
|  | -    { | 
|  | -        return fact(n-1) * n; | 
|  | -    } | 
|  | -    return 1; | 
|  | -} | 
|  | - | 
|  | int main(int argc, char **argv) | 
|  | { | 
|  | -    frobnitz(fact(10)); | 
|  | +    frobnitz(fib(10)); | 
|  | } | 
|  | EOF | 
|  |  | 
|  | test_expect_success 'patience diff' ' | 
|  |  | 
|  | test_must_fail git diff --no-index --patience file1 file2 > output && | 
|  | test_cmp expect output | 
|  |  | 
|  | ' | 
|  |  | 
|  | test_expect_success 'patience diff output is valid' ' | 
|  |  | 
|  | mv file2 expect && | 
|  | git apply < output && | 
|  | test_cmp expect file2 | 
|  |  | 
|  | ' | 
|  |  | 
|  | cat >uniq1 <<\EOF | 
|  | 1 | 
|  | 2 | 
|  | 3 | 
|  | 4 | 
|  | 5 | 
|  | 6 | 
|  | EOF | 
|  |  | 
|  | cat >uniq2 <<\EOF | 
|  | a | 
|  | b | 
|  | c | 
|  | d | 
|  | e | 
|  | f | 
|  | EOF | 
|  |  | 
|  | cat >expect <<\EOF | 
|  | diff --git a/uniq1 b/uniq2 | 
|  | index b414108..0fdf397 100644 | 
|  | --- a/uniq1 | 
|  | +++ b/uniq2 | 
|  | @@ -1,6 +1,6 @@ | 
|  | -1 | 
|  | -2 | 
|  | -3 | 
|  | -4 | 
|  | -5 | 
|  | -6 | 
|  | +a | 
|  | +b | 
|  | +c | 
|  | +d | 
|  | +e | 
|  | +f | 
|  | EOF | 
|  |  | 
|  | test_expect_success 'completely different files' ' | 
|  |  | 
|  | test_must_fail git diff --no-index --patience uniq1 uniq2 > output && | 
|  | test_cmp expect output | 
|  |  | 
|  | ' | 
|  |  | 
|  | test_done |