#!/bin/sh # # Copyright (c) 2006 Eric Wong # test_description='git rebase --merge --skip tests' . ./test-lib.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 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_done