#!/bin/sh test_description='recursive merge corner cases' . ./test-lib.sh # # L1 L2 # o---o # / \ / \ # o X ? # \ / \ / # o---o # R1 R2 # test_expect_success setup ' ten="0 1 2 3 4 5 6 7 8 9" for i in $ten do echo line $i in a sample file done >one && for i in $ten do echo line $i in another sample file done >two && git add one two && test_tick && git commit -m initial && git branch L1 && git checkout -b R1 && git mv one three && test_tick && git commit -m R1 && git checkout L1 && git mv two three && test_tick && git commit -m L1 && git checkout L1^0 && test_tick && git merge -s ours R1 && git tag L2 && git checkout R1^0 && test_tick && git merge -s ours L1 && git tag R2 ' test_expect_success merge ' git reset --hard && git checkout L2^0 && test_must_fail git merge -s recursive R2^0 ' test_done