3 test_description="merges with unrelated index changes"
 
   7 # Testcase for some simple merges
 
  18 #   Commit A: some file a
 
  19 #   Commit B: adds file b, modifies end of a
 
  20 #   Commit C: adds file c
 
  21 #   Commit D: adds file d, modifies beginning of a
 
  22 #   Commit E: renames a->subdir/a, adds subdir/e
 
  23 #   Commit F: empty commit
 
  25 test_expect_success 'setup trivial merges' '
 
  28         test_tick && git commit -m A &&
 
  41         test_tick && git commit -m B &&
 
  46         test_tick && git commit -m C &&
 
  52         test_tick && git commit -m D &&
 
  59         test_tick && git commit -m E &&
 
  62         test_tick && git commit --allow-empty -m F
 
  65 test_expect_success 'ff update' '
 
  69         touch random_file && git add random_file &&
 
  73         test_must_fail git rev-parse HEAD:random_file &&
 
  74         test "$(git diff --name-only --cached E)" = "random_file"
 
  77 test_expect_success 'ff update, important file modified' '
 
  85         test_must_fail git merge E^0 &&
 
  86         test_path_is_missing .git/MERGE_HEAD
 
  89 test_expect_success 'resolve, trivial' '
 
  93         touch random_file && git add random_file &&
 
  95         test_must_fail git merge -s resolve C^0 &&
 
  96         test_path_is_missing .git/MERGE_HEAD
 
  99 test_expect_success 'resolve, non-trivial' '
 
 103         touch random_file && git add random_file &&
 
 105         test_must_fail git merge -s resolve D^0 &&
 
 106         test_path_is_missing .git/MERGE_HEAD
 
 109 test_expect_success 'recursive' '
 
 113         touch random_file && git add random_file &&
 
 115         test_must_fail git merge -s recursive C^0 &&
 
 116         test_path_is_missing .git/MERGE_HEAD
 
 119 test_expect_success 'recursive, when merge branch matches merge base' '
 
 123         touch random_file && git add random_file &&
 
 125         test_must_fail git merge -s recursive F^0 &&
 
 126         test_path_is_missing .git/MERGE_HEAD
 
 129 test_expect_success 'merge-recursive, when index==head but head!=HEAD' '
 
 134         git diff C B -- | git apply --cached &&
 
 135         # Merge B & F, with B as "head"
 
 136         git merge-recursive A -- B F > out &&
 
 137         test_i18ngrep "Already up to date" out
 
 140 test_expect_success 'recursive, when file has staged changes not matching HEAD nor what a merge would give' '
 
 145         test_seq 1 10 >subdir/a &&
 
 148         # We have staged changes; merge should error out
 
 149         test_must_fail git merge -s recursive E^0 2>err &&
 
 150         test_i18ngrep "changes to the following files would be overwritten" err
 
 153 test_expect_success 'recursive, when file has staged changes matching what a merge would give' '
 
 158         test_seq 1 11 >subdir/a &&
 
 161         # We have staged changes; merge should error out
 
 162         test_must_fail git merge -s recursive E^0 2>err &&
 
 163         test_i18ngrep "changes to the following files would be overwritten" err
 
 166 test_expect_success 'octopus, unrelated file touched' '
 
 170         touch random_file && git add random_file &&
 
 172         test_must_fail git merge C^0 D^0 &&
 
 173         test_path_is_missing .git/MERGE_HEAD
 
 176 test_expect_success 'octopus, related file removed' '
 
 182         test_must_fail git merge C^0 D^0 &&
 
 183         test_path_is_missing .git/MERGE_HEAD
 
 186 test_expect_success 'octopus, related file modified' '
 
 190         echo 12 >>a && git add a &&
 
 192         test_must_fail git merge C^0 D^0 &&
 
 193         test_path_is_missing .git/MERGE_HEAD
 
 196 test_expect_success 'ours' '
 
 200         touch random_file && git add random_file &&
 
 202         test_must_fail git merge -s ours C^0 &&
 
 203         test_path_is_missing .git/MERGE_HEAD
 
 206 test_expect_success 'subtree' '
 
 210         touch random_file && git add random_file &&
 
 212         test_must_fail git merge -s subtree E^0 &&
 
 213         test_path_is_missing .git/MERGE_HEAD