checkout -m: recreate merge when checking out of unmerged index
[gitweb.git] / t / t3030-merge-recursive.sh
index aef92b9b920874eb42b97ee72427935610be4e75..f2880152b019f4d77e3b743d7a7b02ba6d197d11 100755 (executable)
@@ -9,12 +9,12 @@ test_expect_success 'setup 1' '
        echo hello >a &&
        o0=$(git hash-object a) &&
        cp a b &&
-       cp a A &&
+       cp a c &&
        mkdir d &&
        cp a d/e &&
 
        test_tick &&
-       git add a b A d/e &&
+       git add a b c d/e &&
        git commit -m initial &&
        c0=$(git rev-parse --verify HEAD) &&
        git branch side &&
@@ -34,34 +34,34 @@ test_expect_success 'setup 1' '
        c1=$(git rev-parse --verify HEAD) &&
        ( git ls-tree -r HEAD ; git ls-files -s ) >actual &&
        (
-               echo "100644 blob $o0   A"
                echo "100644 blob $o1   a"
                echo "100644 blob $o0   b"
+               echo "100644 blob $o0   c"
                echo "100644 blob $o1   d/e"
-               echo "100644 $o0 0      A"
                echo "100644 $o1 0      a"
                echo "100644 $o0 0      b"
+               echo "100644 $o0 0      c"
                echo "100644 $o1 0      d/e"
        ) >expected &&
-       git diff -u expected actual
+       test_cmp expected actual
 '
 
 test_expect_success 'setup 2' '
 
-       rm -rf [Aabd] &&
+       rm -rf [abcd] &&
        git checkout side &&
        ( git ls-tree -r HEAD ; git ls-files -s ) >actual &&
        (
-               echo "100644 blob $o0   A"
                echo "100644 blob $o0   a"
                echo "100644 blob $o0   b"
+               echo "100644 blob $o0   c"
                echo "100644 blob $o0   d/e"
-               echo "100644 $o0 0      A"
                echo "100644 $o0 0      a"
                echo "100644 $o0 0      b"
+               echo "100644 $o0 0      c"
                echo "100644 $o0 0      d/e"
        ) >expected &&
-       git diff -u expected actual &&
+       test_cmp expected actual &&
 
        echo goodbye >>a &&
        o2=$(git hash-object a) &&
@@ -73,34 +73,34 @@ test_expect_success 'setup 2' '
        c2=$(git rev-parse --verify HEAD) &&
        ( git ls-tree -r HEAD ; git ls-files -s ) >actual &&
        (
-               echo "100644 blob $o0   A"
                echo "100644 blob $o2   a"
                echo "100644 blob $o0   b"
+               echo "100644 blob $o0   c"
                echo "100644 blob $o0   d/e"
-               echo "100644 $o0 0      A"
                echo "100644 $o2 0      a"
                echo "100644 $o0 0      b"
+               echo "100644 $o0 0      c"
                echo "100644 $o0 0      d/e"
        ) >expected &&
-       git diff -u expected actual
+       test_cmp expected actual
 '
 
 test_expect_success 'setup 3' '
 
-       rm -rf [Aabd] &&
+       rm -rf [abcd] &&
        git checkout df-1 &&
        ( git ls-tree -r HEAD ; git ls-files -s ) >actual &&
        (
-               echo "100644 blob $o0   A"
                echo "100644 blob $o0   a"
                echo "100644 blob $o0   b"
+               echo "100644 blob $o0   c"
                echo "100644 blob $o0   d/e"
-               echo "100644 $o0 0      A"
                echo "100644 $o0 0      a"
                echo "100644 $o0 0      b"
+               echo "100644 $o0 0      c"
                echo "100644 $o0 0      d/e"
        ) >expected &&
-       git diff -u expected actual &&
+       test_cmp expected actual &&
 
        rm -f b && mkdir b && echo df-1 >b/c && git add b/c &&
        o3=$(git hash-object b/c) &&
@@ -110,34 +110,34 @@ test_expect_success 'setup 3' '
        c3=$(git rev-parse --verify HEAD) &&
        ( git ls-tree -r HEAD ; git ls-files -s ) >actual &&
        (
-               echo "100644 blob $o0   A"
                echo "100644 blob $o0   a"
                echo "100644 blob $o3   b/c"
+               echo "100644 blob $o0   c"
                echo "100644 blob $o0   d/e"
-               echo "100644 $o0 0      A"
                echo "100644 $o0 0      a"
                echo "100644 $o3 0      b/c"
+               echo "100644 $o0 0      c"
                echo "100644 $o0 0      d/e"
        ) >expected &&
-       git diff -u expected actual
+       test_cmp expected actual
 '
 
 test_expect_success 'setup 4' '
 
-       rm -rf [Aabd] &&
+       rm -rf [abcd] &&
        git checkout df-2 &&
        ( git ls-tree -r HEAD ; git ls-files -s ) >actual &&
        (
-               echo "100644 blob $o0   A"
                echo "100644 blob $o0   a"
                echo "100644 blob $o0   b"
+               echo "100644 blob $o0   c"
                echo "100644 blob $o0   d/e"
-               echo "100644 $o0 0      A"
                echo "100644 $o0 0      a"
                echo "100644 $o0 0      b"
+               echo "100644 $o0 0      c"
                echo "100644 $o0 0      d/e"
        ) >expected &&
-       git diff -u expected actual &&
+       test_cmp expected actual &&
 
        rm -f a && mkdir a && echo df-2 >a/c && git add a/c &&
        o4=$(git hash-object a/c) &&
@@ -147,34 +147,34 @@ test_expect_success 'setup 4' '
        c4=$(git rev-parse --verify HEAD) &&
        ( git ls-tree -r HEAD ; git ls-files -s ) >actual &&
        (
-               echo "100644 blob $o0   A"
                echo "100644 blob $o4   a/c"
                echo "100644 blob $o0   b"
+               echo "100644 blob $o0   c"
                echo "100644 blob $o0   d/e"
-               echo "100644 $o0 0      A"
                echo "100644 $o4 0      a/c"
                echo "100644 $o0 0      b"
+               echo "100644 $o0 0      c"
                echo "100644 $o0 0      d/e"
        ) >expected &&
-       git diff -u expected actual
+       test_cmp expected actual
 '
 
 test_expect_success 'setup 5' '
 
-       rm -rf [Aabd] &&
+       rm -rf [abcd] &&
        git checkout remove &&
        ( git ls-tree -r HEAD ; git ls-files -s ) >actual &&
        (
-               echo "100644 blob $o0   A"
                echo "100644 blob $o0   a"
                echo "100644 blob $o0   b"
+               echo "100644 blob $o0   c"
                echo "100644 blob $o0   d/e"
-               echo "100644 $o0 0      A"
                echo "100644 $o0 0      a"
                echo "100644 $o0 0      b"
+               echo "100644 $o0 0      c"
                echo "100644 $o0 0      d/e"
        ) >expected &&
-       git diff -u expected actual &&
+       test_cmp expected actual &&
 
        rm -f b &&
        echo remove-conflict >a &&
@@ -188,33 +188,33 @@ test_expect_success 'setup 5' '
        c5=$(git rev-parse --verify HEAD) &&
        ( git ls-tree -r HEAD ; git ls-files -s ) >actual &&
        (
-               echo "100644 blob $o0   A"
                echo "100644 blob $o5   a"
+               echo "100644 blob $o0   c"
                echo "100644 blob $o0   d/e"
-               echo "100644 $o0 0      A"
                echo "100644 $o5 0      a"
+               echo "100644 $o0 0      c"
                echo "100644 $o0 0      d/e"
        ) >expected &&
-       git diff -u expected actual
+       test_cmp expected actual
 
 '
 
 test_expect_success 'setup 6' '
 
-       rm -rf [Aabd] &&
+       rm -rf [abcd] &&
        git checkout df-3 &&
        ( git ls-tree -r HEAD ; git ls-files -s ) >actual &&
        (
-               echo "100644 blob $o0   A"
                echo "100644 blob $o0   a"
                echo "100644 blob $o0   b"
+               echo "100644 blob $o0   c"
                echo "100644 blob $o0   d/e"
-               echo "100644 $o0 0      A"
                echo "100644 $o0 0      a"
                echo "100644 $o0 0      b"
+               echo "100644 $o0 0      c"
                echo "100644 $o0 0      d/e"
        ) >expected &&
-       git diff -u expected actual &&
+       test_cmp expected actual &&
 
        rm -fr d && echo df-3 >d && git add d &&
        o6=$(git hash-object d) &&
@@ -224,21 +224,21 @@ test_expect_success 'setup 6' '
        c6=$(git rev-parse --verify HEAD) &&
        ( git ls-tree -r HEAD ; git ls-files -s ) >actual &&
        (
-               echo "100644 blob $o0   A"
                echo "100644 blob $o0   a"
                echo "100644 blob $o0   b"
+               echo "100644 blob $o0   c"
                echo "100644 blob $o6   d"
-               echo "100644 $o0 0      A"
                echo "100644 $o0 0      a"
                echo "100644 $o0 0      b"
+               echo "100644 $o0 0      c"
                echo "100644 $o6 0      d"
        ) >expected &&
-       git diff -u expected actual
+       test_cmp expected actual
 '
 
 test_expect_success 'merge-recursive simple' '
 
-       rm -fr [Aabd] &&
+       rm -fr [abcd] &&
        git checkout -f "$c2" &&
 
        git-merge-recursive "$c0" -- "$c2" "$c1"
@@ -258,20 +258,31 @@ test_expect_success 'merge-recursive result' '
 
        git ls-files -s >actual &&
        (
-               echo "100644 $o0 0      A"
                echo "100644 $o0 1      a"
                echo "100644 $o2 2      a"
                echo "100644 $o1 3      a"
                echo "100644 $o0 0      b"
+               echo "100644 $o0 0      c"
                echo "100644 $o1 0      d/e"
        ) >expected &&
-       git diff -u expected actual
+       test_cmp expected actual
+
+'
+
+test_expect_success 'fail if the index has unresolved entries' '
+
+       rm -fr [abcd] &&
+       git checkout -f "$c1" &&
+
+       test_must_fail git merge "$c5" &&
+       test_must_fail git merge "$c5" 2> out &&
+       grep "You are in the middle of a conflicted merge" out
 
 '
 
 test_expect_success 'merge-recursive remove conflict' '
 
-       rm -fr [Aabd] &&
+       rm -fr [abcd] &&
        git checkout -f "$c1" &&
 
        git-merge-recursive "$c0" -- "$c1" "$c5"
@@ -291,18 +302,18 @@ test_expect_success 'merge-recursive remove conflict' '
 
        git ls-files -s >actual &&
        (
-               echo "100644 $o0 0      A"
                echo "100644 $o0 1      a"
                echo "100644 $o1 2      a"
                echo "100644 $o5 3      a"
+               echo "100644 $o0 0      c"
                echo "100644 $o1 0      d/e"
        ) >expected &&
-       git diff -u expected actual
+       test_cmp expected actual
 
 '
 
 test_expect_success 'merge-recursive d/f simple' '
-       rm -fr [Aabd] &&
+       rm -fr [abcd] &&
        git reset --hard &&
        git checkout -f "$c1" &&
 
@@ -313,18 +324,18 @@ test_expect_success 'merge-recursive result' '
 
        git ls-files -s >actual &&
        (
-               echo "100644 $o0 0      A"
                echo "100644 $o1 0      a"
                echo "100644 $o3 0      b/c"
+               echo "100644 $o0 0      c"
                echo "100644 $o1 0      d/e"
        ) >expected &&
-       git diff -u expected actual
+       test_cmp expected actual
 
 '
 
 test_expect_success 'merge-recursive d/f conflict' '
 
-       rm -fr [Aabd] &&
+       rm -fr [abcd] &&
        git reset --hard &&
        git checkout -f "$c1" &&
 
@@ -345,20 +356,20 @@ test_expect_success 'merge-recursive d/f conflict result' '
 
        git ls-files -s >actual &&
        (
-               echo "100644 $o0 0      A"
                echo "100644 $o0 1      a"
                echo "100644 $o1 2      a"
                echo "100644 $o4 0      a/c"
                echo "100644 $o0 0      b"
+               echo "100644 $o0 0      c"
                echo "100644 $o1 0      d/e"
        ) >expected &&
-       git diff -u expected actual
+       test_cmp expected actual
 
 '
 
 test_expect_success 'merge-recursive d/f conflict the other way' '
 
-       rm -fr [Aabd] &&
+       rm -fr [abcd] &&
        git reset --hard &&
        git checkout -f "$c4" &&
 
@@ -379,20 +390,20 @@ test_expect_success 'merge-recursive d/f conflict result the other way' '
 
        git ls-files -s >actual &&
        (
-               echo "100644 $o0 0      A"
                echo "100644 $o0 1      a"
                echo "100644 $o1 3      a"
                echo "100644 $o4 0      a/c"
                echo "100644 $o0 0      b"
+               echo "100644 $o0 0      c"
                echo "100644 $o1 0      d/e"
        ) >expected &&
-       git diff -u expected actual
+       test_cmp expected actual
 
 '
 
 test_expect_success 'merge-recursive d/f conflict' '
 
-       rm -fr [Aabd] &&
+       rm -fr [abcd] &&
        git reset --hard &&
        git checkout -f "$c1" &&
 
@@ -413,20 +424,20 @@ test_expect_success 'merge-recursive d/f conflict result' '
 
        git ls-files -s >actual &&
        (
-               echo "100644 $o0 0      A"
                echo "100644 $o1 0      a"
                echo "100644 $o0 0      b"
+               echo "100644 $o0 0      c"
                echo "100644 $o6 3      d"
                echo "100644 $o0 1      d/e"
                echo "100644 $o1 2      d/e"
        ) >expected &&
-       git diff -u expected actual
+       test_cmp expected actual
 
 '
 
 test_expect_success 'merge-recursive d/f conflict' '
 
-       rm -fr [Aabd] &&
+       rm -fr [abcd] &&
        git reset --hard &&
        git checkout -f "$c6" &&
 
@@ -447,14 +458,14 @@ test_expect_success 'merge-recursive d/f conflict result' '
 
        git ls-files -s >actual &&
        (
-               echo "100644 $o0 0      A"
                echo "100644 $o1 0      a"
                echo "100644 $o0 0      b"
+               echo "100644 $o0 0      c"
                echo "100644 $o6 2      d"
                echo "100644 $o0 1      d/e"
                echo "100644 $o1 3      d/e"
        ) >expected &&
-       git diff -u expected actual
+       test_cmp expected actual
 
 '
 
@@ -471,58 +482,57 @@ test_expect_success 'reset and bind merge' '
        git read-tree --prefix=M/ master &&
        git ls-files -s >actual &&
        (
-               echo "100644 $o0 0      A"
-               echo "100644 $o0 0      M/A"
                echo "100644 $o1 0      M/a"
                echo "100644 $o0 0      M/b"
+               echo "100644 $o0 0      M/c"
                echo "100644 $o1 0      M/d/e"
                echo "100644 $o1 0      a"
                echo "100644 $o0 0      b"
+               echo "100644 $o0 0      c"
                echo "100644 $o1 0      d/e"
        ) >expected &&
-       git diff -u expected actual &&
+       test_cmp expected actual &&
 
        git read-tree --prefix=a1/ master &&
        git ls-files -s >actual &&
        (
-               echo "100644 $o0 0      A"
-               echo "100644 $o0 0      M/A"
                echo "100644 $o1 0      M/a"
                echo "100644 $o0 0      M/b"
+               echo "100644 $o0 0      M/c"
                echo "100644 $o1 0      M/d/e"
                echo "100644 $o1 0      a"
-               echo "100644 $o0 0      a1/A"
                echo "100644 $o1 0      a1/a"
                echo "100644 $o0 0      a1/b"
+               echo "100644 $o0 0      a1/c"
                echo "100644 $o1 0      a1/d/e"
                echo "100644 $o0 0      b"
+               echo "100644 $o0 0      c"
                echo "100644 $o1 0      d/e"
        ) >expected &&
-       git diff -u expected actual
+       test_cmp expected actual
 
        git read-tree --prefix=z/ master &&
        git ls-files -s >actual &&
        (
-               echo "100644 $o0 0      A"
-               echo "100644 $o0 0      M/A"
                echo "100644 $o1 0      M/a"
                echo "100644 $o0 0      M/b"
+               echo "100644 $o0 0      M/c"
                echo "100644 $o1 0      M/d/e"
                echo "100644 $o1 0      a"
-               echo "100644 $o0 0      a1/A"
                echo "100644 $o1 0      a1/a"
                echo "100644 $o0 0      a1/b"
+               echo "100644 $o0 0      a1/c"
                echo "100644 $o1 0      a1/d/e"
                echo "100644 $o0 0      b"
+               echo "100644 $o0 0      c"
                echo "100644 $o1 0      d/e"
-               echo "100644 $o0 0      z/A"
                echo "100644 $o1 0      z/a"
                echo "100644 $o0 0      z/b"
+               echo "100644 $o0 0      z/c"
                echo "100644 $o1 0      z/d/e"
        ) >expected &&
-       git diff -u expected actual
+       test_cmp expected actual
 
 '
 
 test_done
-