3 test_description='branch --contains <commit>, --no-contains <commit> --merged, and --no-merged'
7 test_expect_success setup '
12 git commit -m initial &&
17 git commit -a -m "second on master" &&
22 git commit -a -m "second on side" &&
28 test_expect_success 'branch --contains=master' '
30 git branch --contains=master >actual &&
32 echo " master" && echo "* side"
34 test_cmp expect actual
38 test_expect_success 'branch --contains master' '
40 git branch --contains master >actual &&
42 echo " master" && echo "* side"
44 test_cmp expect actual
48 test_expect_success 'branch --no-contains=master' '
50 git branch --no-contains=master >actual &&
51 test_must_be_empty actual
55 test_expect_success 'branch --no-contains master' '
57 git branch --no-contains master >actual &&
58 test_must_be_empty actual
62 test_expect_success 'branch --contains=side' '
64 git branch --contains=side >actual &&
68 test_cmp expect actual
72 test_expect_success 'branch --no-contains=side' '
74 git branch --no-contains=side >actual &&
78 test_cmp expect actual
82 test_expect_success 'branch --contains with pattern implies --list' '
84 git branch --contains=master master >actual &&
88 test_cmp expect actual
92 test_expect_success 'branch --no-contains with pattern implies --list' '
94 git branch --no-contains=master master >actual &&
95 test_must_be_empty actual
99 test_expect_success 'side: branch --merged' '
101 git branch --merged >actual &&
106 test_cmp expect actual
110 test_expect_success 'branch --merged with pattern implies --list' '
112 git branch --merged=side master >actual &&
116 test_cmp expect actual
120 test_expect_success 'side: branch --no-merged' '
122 git branch --no-merged >actual &&
123 test_must_be_empty actual
127 test_expect_success 'master: branch --merged' '
129 git checkout master &&
130 git branch --merged >actual &&
134 test_cmp expect actual
138 test_expect_success 'master: branch --no-merged' '
140 git branch --no-merged >actual &&
144 test_cmp expect actual
148 test_expect_success 'branch --no-merged with pattern implies --list' '
150 git branch --no-merged=master master >actual &&
151 test_must_be_empty actual
155 test_expect_success 'implicit --list conflicts with modification options' '
157 test_must_fail git branch --contains=master -d &&
158 test_must_fail git branch --contains=master -m foo &&
159 test_must_fail git branch --no-contains=master -d &&
160 test_must_fail git branch --no-contains=master -m foo
164 test_expect_success 'Assert that --contains only works on commits, not trees & blobs' '
165 test_must_fail git branch --contains master^{tree} &&
166 blob=$(git hash-object -w --stdin <<-\EOF
170 test_must_fail git branch --contains $blob &&
171 test_must_fail git branch --no-contains $blob
174 test_expect_success 'multiple branch --contains' '
175 git checkout -b side2 master &&
178 git commit -m "add feature" &&
179 git checkout -b next master &&
181 git branch --contains side --contains side2 >actual &&
182 cat >expect <<-\EOF &&
187 test_cmp expect actual
190 test_expect_success 'multiple branch --merged' '
191 git branch --merged next --merged master >actual &&
192 cat >expect <<-\EOF &&
197 test_cmp expect actual
200 test_expect_success 'multiple branch --no-contains' '
201 git branch --no-contains side --no-contains side2 >actual &&
202 cat >expect <<-\EOF &&
205 test_cmp expect actual
208 test_expect_success 'multiple branch --no-merged' '
209 git branch --no-merged next --no-merged master >actual &&
210 cat >expect <<-\EOF &&
213 test_cmp expect actual
216 test_expect_success 'branch --contains combined with --no-contains' '
217 git checkout -b seen master &&
220 git branch --contains side --no-contains side2 >actual &&
221 cat >expect <<-\EOF &&
225 test_cmp expect actual
228 test_expect_success 'branch --merged combined with --no-merged' '
229 git branch --merged seen --no-merged next >actual &&
230 cat >expect <<-\EOF &&
234 test_cmp expect actual
237 # We want to set up a case where the walk for the tracking info
238 # of one branch crosses the tip of another branch (and make sure
239 # that the latter walk does not mess up our flag to see if it was
242 # Here "topic" tracks "master" with one extra commit, and "zzz" points to the
243 # same tip as master The name "zzz" must come alphabetically after "topic"
244 # as we process them in that order.
245 test_expect_success PREPARE_FOR_MAIN_BRANCH 'branch --merged with --verbose' '
246 git branch --track topic master &&
247 git branch zzz topic &&
248 git checkout topic &&
250 git branch --merged topic >actual &&
251 cat >expect <<-\EOF &&
256 test_cmp expect actual &&
257 git branch --verbose --merged topic >actual &&
258 cat >expect <<-EOF &&
259 main $(git rev-parse --short main) second on main
260 * topic $(git rev-parse --short topic ) [ahead 1] foo
261 zzz $(git rev-parse --short zzz ) second on main
263 test_i18ncmp expect actual