| #!/bin/sh |
| |
| test_description='rebasing a commit with multi-line first paragraph.' |
| |
| GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME=main |
| export GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME |
| |
| . ./test-lib.sh |
| |
| test_expect_success setup ' |
| |
| >file && |
| git add file && |
| test_tick && |
| git commit -m initial && |
| |
| echo hello >file && |
| test_tick && |
| git commit -a -m "A sample commit log message that has a long |
| summary that spills over multiple lines. |
| |
| But otherwise with a sane description." && |
| |
| git branch side && |
| |
| git reset --hard HEAD^ && |
| >elif && |
| git add elif && |
| test_tick && |
| git commit -m second && |
| |
| git checkout -b side2 && |
| >afile && |
| git add afile && |
| test_tick && |
| git commit -m third && |
| echo hello >afile && |
| test_tick && |
| git commit -a -m fourth && |
| git checkout -b side-merge && |
| git reset --hard HEAD^^ && |
| git merge --no-ff -m "A merge commit log message that has a long |
| summary that spills over multiple lines. |
| |
| But otherwise with a sane description." side2 && |
| git branch side-merge-original |
| ' |
| |
| test_expect_success rebase ' |
| |
| git checkout side && |
| git rebase main && |
| git cat-file commit HEAD | sed -e "1,/^\$/d" >actual && |
| git cat-file commit side@{1} | sed -e "1,/^\$/d" >expect && |
| test_cmp expect actual |
| |
| ' |
| test_expect_success REBASE_P rebasep ' |
| |
| git checkout side-merge && |
| git rebase -p side && |
| git cat-file commit HEAD | sed -e "1,/^\$/d" >actual && |
| git cat-file commit side-merge-original | sed -e "1,/^\$/d" >expect && |
| test_cmp expect actual |
| |
| ' |
| |
| test_done |