Merge branch 'en/rerere-multi-stage-1-fix'

A corner case bugfix in "git rerere" code.

* en/rerere-multi-stage-1-fix:
  rerere: avoid buffer overrun
  t4200: demonstrate rerere segfault on specially crafted merge
This commit is contained in:
Junio C Hamano 2018-09-24 10:30:48 -07:00
commit bd3941a0ae
2 changed files with 30 additions and 1 deletions

View File

@ -521,7 +521,7 @@ static int check_one_conflict(int i, int *type)
} }
*type = PUNTED; *type = PUNTED;
while (ce_stage(active_cache[i]) == 1) while (i < active_nr && ce_stage(active_cache[i]) == 1)
i++; i++;
/* Only handle regular files with both stages #2 and #3 */ /* Only handle regular files with both stages #2 and #3 */

View File

@ -642,4 +642,33 @@ test_expect_success 'rerere with inner conflict markers' '
test_cmp expect actual test_cmp expect actual
' '
test_expect_success 'setup simple stage 1 handling' '
test_create_repo stage_1_handling &&
(
cd stage_1_handling &&
test_seq 1 10 >original &&
git add original &&
git commit -m original &&
git checkout -b A master &&
git mv original A &&
git commit -m "rename to A" &&
git checkout -b B master &&
git mv original B &&
git commit -m "rename to B"
)
'
test_expect_success 'test simple stage 1 handling' '
(
cd stage_1_handling &&
git config rerere.enabled true &&
git checkout A^0 &&
test_must_fail git merge B^0
)
'
test_done test_done