1#!/bin/sh
   2test_description='subtree merge strategy'
   4. ./test-lib.sh
   6test_expect_success setup '
   8        s="1 2 3 4 5 6 7 8"
  10        for i in $s; do echo $i; done >hello &&
  11        git add hello &&
  12        git commit -m initial &&
  13        git checkout -b side &&
  14        echo >>hello world &&
  15        git add hello &&
  16        git commit -m second &&
  17        git checkout master &&
  18        for i in mundo $s; do echo $i; done >hello &&
  19        git add hello &&
  20        git commit -m master
  21'
  23test_expect_success 'subtree available and works like recursive' '
  25        git merge -s subtree side &&
  27        for i in mundo $s world; do echo $i; done >expect &&
  28        test_cmp expect hello
  29'
  31test_expect_success 'setup' '
  33        mkdir git-gui &&
  34        cd git-gui &&
  35        git init &&
  36        echo git-gui > git-gui.sh &&
  37        o1=$(git hash-object git-gui.sh) &&
  38        git add git-gui.sh &&
  39        git commit -m "initial git-gui" &&
  40        cd .. &&
  41        mkdir git &&
  42        cd git &&
  43        git init &&
  44        echo git >git.c &&
  45        o2=$(git hash-object git.c) &&
  46        git add git.c &&
  47        git commit -m "initial git"
  48'
  49test_expect_success 'initial merge' '
  51        git remote add -f gui ../git-gui &&
  52        git merge -s ours --no-commit gui/master &&
  53        git read-tree --prefix=git-gui/ -u gui/master &&
  54        git commit -m "Merge git-gui as our subdirectory" &&
  55        git checkout -b work &&
  56        git ls-files -s >actual &&
  57        (
  58                echo "100644 $o1 0      git-gui/git-gui.sh"
  59                echo "100644 $o2 0      git.c"
  60        ) >expected &&
  61        test_cmp expected actual
  62'
  63test_expect_success 'merge update' '
  65        cd ../git-gui &&
  66        echo git-gui2 > git-gui.sh &&
  67        o3=$(git hash-object git-gui.sh) &&
  68        git add git-gui.sh &&
  69        git checkout -b master2 &&
  70        git commit -m "update git-gui" &&
  71        cd ../git &&
  72        git pull -s subtree gui master2 &&
  73        git ls-files -s >actual &&
  74        (
  75                echo "100644 $o3 0      git-gui/git-gui.sh"
  76                echo "100644 $o2 0      git.c"
  77        ) >expected &&
  78        test_cmp expected actual
  79'
  80test_expect_success 'initial ambiguous subtree' '
  82        cd ../git &&
  83        git reset --hard master &&
  84        git checkout -b master2 &&
  85        git merge -s ours --no-commit gui/master &&
  86        git read-tree --prefix=git-gui2/ -u gui/master &&
  87        git commit -m "Merge git-gui2 as our subdirectory" &&
  88        git checkout -b work2 &&
  89        git ls-files -s >actual &&
  90        (
  91                echo "100644 $o1 0      git-gui/git-gui.sh"
  92                echo "100644 $o1 0      git-gui2/git-gui.sh"
  93                echo "100644 $o2 0      git.c"
  94        ) >expected &&
  95        test_cmp expected actual
  96'
  97test_expect_success 'merge using explicit' '
  99        cd ../git &&
 100        git reset --hard master2 &&
 101        git pull -Xsubtree=git-gui gui master2 &&
 102        git ls-files -s >actual &&
 103        (
 104                echo "100644 $o3 0      git-gui/git-gui.sh"
 105                echo "100644 $o1 0      git-gui2/git-gui.sh"
 106                echo "100644 $o2 0      git.c"
 107        ) >expected &&
 108        test_cmp expected actual
 109'
 110test_expect_success 'merge2 using explicit' '
 112        cd ../git &&
 113        git reset --hard master2 &&
 114        git pull -Xsubtree=git-gui2 gui master2 &&
 115        git ls-files -s >actual &&
 116        (
 117                echo "100644 $o1 0      git-gui/git-gui.sh"
 118                echo "100644 $o3 0      git-gui2/git-gui.sh"
 119                echo "100644 $o2 0      git.c"
 120        ) >expected &&
 121        test_cmp expected actual
 122'
 123test_done