summaryrefslogtreecommitdiffstats
path: root/t/t3409-rebase-preserve-merges.sh
blob: 8cde40f8e80b5df9e8ebf1cd66cd196817107cd4 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
#!/bin/sh
#
# Copyright(C) 2008 Stephen Habermann & Andreas Ericsson
#
test_description='git rebase -p should preserve merges

Run "git rebase -p" and check that merges are properly carried along
'
. ./test-lib.sh

GIT_AUTHOR_EMAIL=bogus_email_address
export GIT_AUTHOR_EMAIL

#echo 'Setting up:
#
#A1--A2  <-- origin/master
# \   \
#  B1--M  <-- topic
#   \
#    B2  <-- origin/topic
#
#'

test_expect_success 'setup for merge-preserving rebase' \
	'echo First > A &&
	git add A &&
	git-commit -m "Add A1" &&
	git checkout -b topic &&
	echo Second > B &&
	git add B &&
	git-commit -m "Add B1" &&
	git checkout -f master &&
	echo Third >> A &&
	git-commit -a -m "Modify A2" &&

	git clone ./. clone1 &&
	cd clone1 &&
	git checkout -b topic origin/topic &&
	git merge origin/master &&
	cd ..

	git clone ./. clone2
	cd clone2 &&
	git checkout -b topic origin/topic &&
	git merge origin/master &&
	cd .. &&

	git checkout topic &&
	echo Fourth >> B &&
	git commit -a -m "Modify B2"
'

test_expect_success 'rebase -p fakes interactive rebase' '
	cd clone2 &&
	git fetch &&
	git rebase -p origin/topic &&
	test 1 = $(git rev-list --all --pretty=oneline | grep "Modify A" | wc -l) &&
	test 1 = $(git rev-list --all --pretty=oneline | grep "Merge commit" | wc -l)
'

test_done