#!/bin/sh # # Copyright (c) 2006 Eric Wong # test_description='git rebase --merge --skip tests' . ./test-lib.sh . "$TEST_DIRECTORY"/lib-rebase.sh # we assume the default git am -3 --skip strategy is tested independently # and always works :) test_expect_success setup ' echo hello > hello && git add hello && git commit -m "hello" && git branch skip-reference && echo world >> hello && git commit -a -m "hello world" && echo goodbye >> hello && git commit -a -m "goodbye" && git tag goodbye && git checkout --detach && git checkout HEAD^ . && test_tick && git commit -m reverted-goodbye && git tag reverted-goodbye && git checkout -f skip-reference && echo moo > hello && git commit -a -m "we should skip this" && echo moo > cow && git add cow && git commit -m "this should not be skipped" && git branch pre-rebase skip-reference && git branch skip-merge skip-reference ' test_expect_success 'rebase with git am -3 (default)' ' test_must_fail git rebase master ' test_expect_success 'rebase --skip can not be used with other options' ' test_must_fail git rebase -v --skip && test_must_fail git rebase --skip -v ' test_expect_success 'rebase --skip with am -3' ' git rebase --skip ' test_expect_success 'rebase moves back to skip-reference' ' test refs/heads/skip-reference = $(git symbolic-ref HEAD) && git branch post-rebase && git reset --hard pre-rebase && test_must_fail git rebase master && echo "hello" > hello && git add hello && git rebase --continue && test refs/heads/skip-reference = $(git symbolic-ref HEAD) && git reset --hard post-rebase ' test_expect_success 'checkout skip-merge' 'git checkout -f skip-merge' test_expect_success 'rebase with --merge' ' test_must_fail git rebase --merge master ' test_expect_success 'rebase --skip with --merge' ' git rebase --skip ' test_expect_success 'merge and reference trees equal' ' test -z "$(git diff-tree skip-merge skip-reference)" ' test_expect_success 'moved back to branch correctly' ' test refs/heads/skip-merge = $(git symbolic-ref HEAD) ' test_debug 'gitk --all & sleep 1' test_expect_success 'fixup that empties commit fails' ' test_when_finished "git rebase --abort" && ( set_fake_editor && test_must_fail env FAKE_LINES="1 fixup 2" git rebase -i \ goodbye^ reverted-goodbye ) ' test_expect_success 'squash that empties commit fails' ' test_when_finished "git rebase --abort" && ( set_fake_editor && test_must_fail env FAKE_LINES="1 squash 2" git rebase -i \ goodbye^ reverted-goodbye ) ' # Must be the last test in this file test_expect_success '$EDITOR and friends are unchanged' ' test_editor_unchanged ' test_done