git rebase is split into three types: am, merge, and interactive.  Various
options imply different types, and which mode we are using determine which
sub-script (git-rebase--$type) is executed to finish the work.  Not all
options work with all types, so add tests for combinations where we expect
to receive an error rather than having options be silently ignored.

Signed-off-by: Elijah Newren <new...@gmail.com>
---
 t/t3422-rebase-incompatible-options.sh | 69 ++++++++++++++++++++++++++
 1 file changed, 69 insertions(+)
 create mode 100755 t/t3422-rebase-incompatible-options.sh

diff --git a/t/t3422-rebase-incompatible-options.sh 
b/t/t3422-rebase-incompatible-options.sh
new file mode 100755
index 0000000000..04cdae921b
--- /dev/null
+++ b/t/t3422-rebase-incompatible-options.sh
@@ -0,0 +1,69 @@
+#!/bin/sh
+
+test_description='test if rebase detects and aborts on incompatible options'
+. ./test-lib.sh
+
+test_expect_success 'setup' '
+       test_seq 2 9 >foo &&
+       git add foo &&
+       git commit -m orig &&
+
+       git branch A &&
+       git branch B &&
+
+       git checkout A &&
+       test_seq 1 9 >foo &&
+       git add foo &&
+       git commit -m A &&
+
+       git checkout B &&
+       # This is indented with HT SP HT.
+       echo "          foo();" >>foo &&
+       git add foo &&
+       git commit -m B
+'
+
+#
+# Rebase has lots of useful options like --whitepsace=fix, which are
+# actually all built in terms of flags to git-am.  Since neither
+# --merge nor --interactive (nor any options that imply those two) use
+# git-am, using them together will result in flags like --whitespace=fix
+# being ignored.  Make sure rebase warns the user and aborts instead.
+#
+
+test_run_rebase () {
+       opt=$1
+       shift
+       test_expect_failure "$opt incompatible with --merge" "
+               git checkout B^0 &&
+               test_must_fail git rebase $opt --merge A
+       "
+
+       test_expect_failure "$opt incompatible with --strategy=ours" "
+               git checkout B^0 &&
+               test_must_fail git rebase $opt --strategy=ours A
+       "
+
+       test_expect_failure "$opt incompatible with --strategy-option=ours" "
+               git checkout B^0 &&
+               test_must_fail git rebase $opt --strategy=ours A
+       "
+
+       test_expect_failure "$opt incompatible with --interactive" "
+               git checkout B^0 &&
+               test_must_fail git rebase $opt --interactive A
+       "
+
+       test_expect_failure "$opt incompatible with --exec" "
+               git checkout B^0 &&
+               test_must_fail git rebase $opt --exec 'true' A
+       "
+
+}
+
+test_run_rebase --whitespace=fix
+test_run_rebase --ignore-whitespace
+test_run_rebase --committer-date-is-author-date
+test_run_rebase -C4
+
+test_done
-- 
2.18.0.rc2.1.g5453d3f70b.dirty

Reply via email to