You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
54 lines
1.3 KiB
54 lines
1.3 KiB
#!/bin/sh |
|
|
|
test_description='am --interactive tests' |
|
|
|
TEST_PASSES_SANITIZE_LEAK=true |
|
. ./test-lib.sh |
|
|
|
test_expect_success 'set up patches to apply' ' |
|
test_commit unrelated && |
|
test_commit no-conflict && |
|
test_commit conflict-patch file patch && |
|
git format-patch --stdout -2 >mbox && |
|
|
|
git reset --hard unrelated && |
|
test_commit conflict-main file main base |
|
' |
|
|
|
# Sanity check our setup. |
|
test_expect_success 'applying all patches generates conflict' ' |
|
test_must_fail git am mbox && |
|
echo resolved >file && |
|
git add -u && |
|
git am --resolved |
|
' |
|
|
|
test_expect_success 'interactive am can apply a single patch' ' |
|
git reset --hard base && |
|
# apply the first, but not the second |
|
test_write_lines y n | git am -i mbox && |
|
|
|
echo no-conflict >expect && |
|
git log -1 --format=%s >actual && |
|
test_cmp expect actual |
|
' |
|
|
|
test_expect_success 'interactive am can resolve conflict' ' |
|
git reset --hard base && |
|
# apply both; the second one will conflict |
|
test_write_lines y y | test_must_fail git am -i mbox && |
|
echo resolved >file && |
|
git add -u && |
|
# interactive "--resolved" will ask us if we want to apply the result |
|
echo y | git am -i --resolved && |
|
|
|
echo conflict-patch >expect && |
|
git log -1 --format=%s >actual && |
|
test_cmp expect actual && |
|
|
|
echo resolved >expect && |
|
git cat-file blob HEAD:file >actual && |
|
test_cmp expect actual |
|
' |
|
|
|
test_done
|
|
|