@@ -16,22 +16,47 @@ test_expect_success setup '
16
16
'
17
17
18
18
test_rebase_same_head () {
19
+ status_n=" $1 " &&
20
+ shift &&
21
+ what_n=" $1 " &&
22
+ shift &&
23
+ cmp_n=" $1 " &&
24
+ shift &&
25
+ status_f=" $1 " &&
26
+ shift &&
27
+ what_f=" $1 " &&
28
+ shift &&
29
+ cmp_f=" $1 " &&
30
+ shift &&
31
+ test_rebase_same_head_ $status_n $what_n $cmp_n " " " $* " &&
32
+ test_rebase_same_head_ $status_f $what_f $cmp_f " --no-ff" " $* "
33
+ }
34
+
35
+ test_rebase_same_head_ () {
19
36
status=" $1 " &&
20
37
shift &&
21
38
what=" $1 " &&
22
39
shift &&
23
40
cmp=" $1 " &&
24
41
shift &&
25
- test_expect_$status " git rebase $* with $changes is $what " "
42
+ flag=" $1 "
43
+ shift &&
44
+ test_expect_$status " git rebase$flag $* with $changes is $what with $cmp HEAD" "
26
45
oldhead=\$ (git rev-parse HEAD) &&
27
46
test_when_finished 'git reset --hard \$ oldhead' &&
28
- git rebase $* >stdout &&
47
+ git rebase$flag $* >stdout &&
29
48
if test $what = work
30
49
then
50
+ # Must check this case first, for 'is up to
51
+ # date, rebase forced[...]rewinding head' cases
31
52
test_i18ngrep 'rewinding head' stdout
32
53
elif test $what = noop
33
54
then
34
- test_i18ngrep 'is up to date' stdout
55
+ test_i18ngrep 'is up to date' stdout &&
56
+ test_i18ngrep ! 'rebase forced' stdout
57
+ elif test $what = noop-force
58
+ then
59
+ test_i18ngrep 'is up to date, rebase forced' stdout
35
60
fi &&
36
61
newhead=\$ (git rev-parse HEAD) &&
37
62
if test $cmp = same
@@ -45,32 +70,32 @@ test_rebase_same_head () {
45
70
}
46
71
47
72
changes=' no changes'
48
- test_rebase_same_head success work same
49
- test_rebase_same_head success noop same master
50
- test_rebase_same_head success noop same --onto B B
51
- test_rebase_same_head success noop same --onto B... B
52
- test_rebase_same_head success noop same --onto master... master
53
- test_rebase_same_head success noop same --no-fork-point
54
- test_rebase_same_head success work same --fork-point master
55
- test_rebase_same_head failure noop same --fork-point --onto B B
56
- test_rebase_same_head failure work same --fork-point --onto B... B
57
- test_rebase_same_head success work same --fork-point --onto master... master
73
+ test_rebase_same_head success work same success work same
74
+ test_rebase_same_head success noop same success noop-force same master
75
+ test_rebase_same_head success noop same success noop-force diff --onto B B
76
+ test_rebase_same_head success noop same success noop-force diff --onto B... B
77
+ test_rebase_same_head success noop same success noop-force same --onto master... master
78
+ test_rebase_same_head success noop same success noop-force same --no-fork-point
79
+ test_rebase_same_head success work same success work same --fork-point master
80
+ test_rebase_same_head failure noop same success work diff --fork-point --onto B B
81
+ test_rebase_same_head failure work same success work diff --fork-point --onto B... B
82
+ test_rebase_same_head success work same success work same --fork-point --onto master... master
58
83
59
84
test_expect_success ' add work same to side' '
60
85
test_commit E
61
86
'
62
87
63
88
changes=' our changes'
64
- test_rebase_same_head success work same
65
- test_rebase_same_head success noop same master
66
- test_rebase_same_head success noop same --onto B B
67
- test_rebase_same_head success noop same --onto B... B
68
- test_rebase_same_head success noop same --onto master... master
69
- test_rebase_same_head success noop same --no-fork-point
70
- test_rebase_same_head success work same --fork-point master
71
- test_rebase_same_head failure work same --fork-point --onto B B
72
- test_rebase_same_head failure work same --fork-point --onto B... B
73
- test_rebase_same_head success work same --fork-point --onto master... master
89
+ test_rebase_same_head success work same success work same
90
+ test_rebase_same_head success noop same success noop-force same master
91
+ test_rebase_same_head success noop same success noop-force diff --onto B B
92
+ test_rebase_same_head success noop same success noop-force diff --onto B... B
93
+ test_rebase_same_head success noop same success noop-force same --onto master... master
94
+ test_rebase_same_head success noop same success noop-force same --no-fork-point
95
+ test_rebase_same_head success work same success work same --fork-point master
96
+ test_rebase_same_head failure work same success work diff --fork-point --onto B B
97
+ test_rebase_same_head failure work same success work diff --fork-point --onto B... B
98
+ test_rebase_same_head success work same success work same --fork-point --onto master... master
74
99
75
100
test_expect_success ' add work same to upstream' '
76
101
git checkout master &&
@@ -79,11 +104,11 @@ test_expect_success 'add work same to upstream' '
79
104
'
80
105
81
106
changes=' our and their changes'
82
- test_rebase_same_head success noop same --onto B B
83
- test_rebase_same_head success noop same --onto B... B
84
- test_rebase_same_head failure work same --onto master... master
85
- test_rebase_same_head failure work same --fork-point --onto B B
86
- test_rebase_same_head failure work same --fork-point --onto B... B
87
- test_rebase_same_head failure work same --fork-point --onto master... master
107
+ test_rebase_same_head success noop same success noop-force diff --onto B B
108
+ test_rebase_same_head success noop same success noop-force diff --onto B... B
109
+ test_rebase_same_head failure work same success work diff --onto master... master
110
+ test_rebase_same_head failure work same success work diff --fork-point --onto B B
111
+ test_rebase_same_head failure work same success work diff --fork-point --onto B... B
112
+ test_rebase_same_head failure work same success work diff --fork-point --onto master... master
88
113
89
114
test_done
0 commit comments