|  | #!/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 |