| #!/bin/sh |
| |
| test_description='rebase should reread the todo file if an exec modifies it' |
| |
| . ./test-lib.sh |
| . "$TEST_DIRECTORY"/lib-rebase.sh |
| |
| test_expect_success 'setup' ' |
| test_commit first file && |
| test_commit second file && |
| test_commit third file |
| ' |
| |
| test_expect_success 'rebase exec modifies rebase-todo' ' |
| todo=.git/rebase-merge/git-rebase-todo && |
| git rebase HEAD -x "echo exec touch F >>$todo" && |
| test -e F |
| ' |
| |
| test_expect_success SHA1 'loose object cache vs re-reading todo list' ' |
| GIT_REBASE_TODO=.git/rebase-merge/git-rebase-todo && |
| export GIT_REBASE_TODO && |
| write_script append-todo.sh <<-\EOS && |
| # For values 5 and 6, this yields SHA-1s with the same first two digits |
| echo "pick $(git rev-parse --short \ |
| $(printf "%s\\n" \ |
| "tree $EMPTY_TREE" \ |
| "author A U Thor <author@example.org> $1 +0000" \ |
| "committer A U Thor <author@example.org> $1 +0000" \ |
| "" \ |
| "$1" | |
| git hash-object -t commit -w --stdin))" >>$GIT_REBASE_TODO |
| |
| shift |
| test -z "$*" || |
| echo "exec $0 $*" >>$GIT_REBASE_TODO |
| EOS |
| |
| git rebase HEAD -x "./append-todo.sh 5 6" |
| ' |
| |
| test_expect_success 'todo is re-read after reword and squash' ' |
| write_script reword-editor.sh <<-\EOS && |
| GIT_SEQUENCE_EDITOR="echo \"exec echo $(cat file) >>actual\" >>" \ |
| git rebase --edit-todo |
| EOS |
| |
| test_write_lines first third >expected && |
| set_fake_editor && |
| GIT_SEQUENCE_EDITOR="$EDITOR" FAKE_LINES="reword 1 squash 2 fixup 3" \ |
| GIT_EDITOR=./reword-editor.sh git rebase -i --root third && |
| test_cmp expected actual |
| ' |
| |
| test_done |