| #!/bin/sh | 
 |  | 
 | test_description='branch --contains <commit>, --no-contains <commit> --merged, and --no-merged' | 
 |  | 
 | . ./test-lib.sh | 
 |  | 
 | test_expect_success setup ' | 
 |  | 
 | 	>file && | 
 | 	git add file && | 
 | 	test_tick && | 
 | 	git commit -m initial && | 
 | 	git branch side && | 
 |  | 
 | 	echo 1 >file && | 
 | 	test_tick && | 
 | 	git commit -a -m "second on master" && | 
 |  | 
 | 	git checkout side && | 
 | 	echo 1 >file && | 
 | 	test_tick && | 
 | 	git commit -a -m "second on side" && | 
 |  | 
 | 	git merge master | 
 |  | 
 | ' | 
 |  | 
 | test_expect_success 'branch --contains=master' ' | 
 |  | 
 | 	git branch --contains=master >actual && | 
 | 	{ | 
 | 		echo "  master" && echo "* side" | 
 | 	} >expect && | 
 | 	test_cmp expect actual | 
 |  | 
 | ' | 
 |  | 
 | test_expect_success 'branch --contains master' ' | 
 |  | 
 | 	git branch --contains master >actual && | 
 | 	{ | 
 | 		echo "  master" && echo "* side" | 
 | 	} >expect && | 
 | 	test_cmp expect actual | 
 |  | 
 | ' | 
 |  | 
 | test_expect_success 'branch --no-contains=master' ' | 
 |  | 
 | 	git branch --no-contains=master >actual && | 
 | 	test_must_be_empty actual | 
 |  | 
 | ' | 
 |  | 
 | test_expect_success 'branch --no-contains master' ' | 
 |  | 
 | 	git branch --no-contains master >actual && | 
 | 	test_must_be_empty actual | 
 |  | 
 | ' | 
 |  | 
 | test_expect_success 'branch --contains=side' ' | 
 |  | 
 | 	git branch --contains=side >actual && | 
 | 	{ | 
 | 		echo "* side" | 
 | 	} >expect && | 
 | 	test_cmp expect actual | 
 |  | 
 | ' | 
 |  | 
 | test_expect_success 'branch --no-contains=side' ' | 
 |  | 
 | 	git branch --no-contains=side >actual && | 
 | 	{ | 
 | 		echo "  master" | 
 | 	} >expect && | 
 | 	test_cmp expect actual | 
 |  | 
 | ' | 
 |  | 
 | test_expect_success 'branch --contains with pattern implies --list' ' | 
 |  | 
 | 	git branch --contains=master master >actual && | 
 | 	{ | 
 | 		echo "  master" | 
 | 	} >expect && | 
 | 	test_cmp expect actual | 
 |  | 
 | ' | 
 |  | 
 | test_expect_success 'branch --no-contains with pattern implies --list' ' | 
 |  | 
 | 	git branch --no-contains=master master >actual && | 
 | 	test_must_be_empty actual | 
 |  | 
 | ' | 
 |  | 
 | test_expect_success 'side: branch --merged' ' | 
 |  | 
 | 	git branch --merged >actual && | 
 | 	{ | 
 | 		echo "  master" && | 
 | 		echo "* side" | 
 | 	} >expect && | 
 | 	test_cmp expect actual | 
 |  | 
 | ' | 
 |  | 
 | test_expect_success 'branch --merged with pattern implies --list' ' | 
 |  | 
 | 	git branch --merged=side master >actual && | 
 | 	{ | 
 | 		echo "  master" | 
 | 	} >expect && | 
 | 	test_cmp expect actual | 
 |  | 
 | ' | 
 |  | 
 | test_expect_success 'side: branch --no-merged' ' | 
 |  | 
 | 	git branch --no-merged >actual && | 
 | 	test_must_be_empty actual | 
 |  | 
 | ' | 
 |  | 
 | test_expect_success 'master: branch --merged' ' | 
 |  | 
 | 	git checkout master && | 
 | 	git branch --merged >actual && | 
 | 	{ | 
 | 		echo "* master" | 
 | 	} >expect && | 
 | 	test_cmp expect actual | 
 |  | 
 | ' | 
 |  | 
 | test_expect_success 'master: branch --no-merged' ' | 
 |  | 
 | 	git branch --no-merged >actual && | 
 | 	{ | 
 | 		echo "  side" | 
 | 	} >expect && | 
 | 	test_cmp expect actual | 
 |  | 
 | ' | 
 |  | 
 | test_expect_success 'branch --no-merged with pattern implies --list' ' | 
 |  | 
 | 	git branch --no-merged=master master >actual && | 
 | 	test_must_be_empty actual | 
 |  | 
 | ' | 
 |  | 
 | test_expect_success 'implicit --list conflicts with modification options' ' | 
 |  | 
 | 	test_must_fail git branch --contains=master -d && | 
 | 	test_must_fail git branch --contains=master -m foo && | 
 | 	test_must_fail git branch --no-contains=master -d && | 
 | 	test_must_fail git branch --no-contains=master -m foo | 
 |  | 
 | ' | 
 |  | 
 | test_expect_success 'Assert that --contains only works on commits, not trees & blobs' ' | 
 | 	test_must_fail git branch --contains master^{tree} && | 
 | 	blob=$(git hash-object -w --stdin <<-\EOF | 
 | 	Some blob | 
 | 	EOF | 
 | 	) && | 
 | 	test_must_fail git branch --contains $blob && | 
 | 	test_must_fail git branch --no-contains $blob | 
 | ' | 
 |  | 
 | # We want to set up a case where the walk for the tracking info | 
 | # of one branch crosses the tip of another branch (and make sure | 
 | # that the latter walk does not mess up our flag to see if it was | 
 | # merged). | 
 | # | 
 | # Here "topic" tracks "master" with one extra commit, and "zzz" points to the | 
 | # same tip as master The name "zzz" must come alphabetically after "topic" | 
 | # as we process them in that order. | 
 | test_expect_success 'branch --merged with --verbose' ' | 
 | 	git branch --track topic master && | 
 | 	git branch zzz topic && | 
 | 	git checkout topic && | 
 | 	test_commit foo && | 
 | 	git branch --merged topic >actual && | 
 | 	cat >expect <<-\EOF && | 
 | 	  master | 
 | 	* topic | 
 | 	  zzz | 
 | 	EOF | 
 | 	test_cmp expect actual && | 
 | 	git branch --verbose --merged topic >actual && | 
 | 	cat >expect <<-\EOF && | 
 | 	  master c77a0a9 second on master | 
 | 	* topic  2c939f4 [ahead 1] foo | 
 | 	  zzz    c77a0a9 second on master | 
 | 	EOF | 
 | 	test_i18ncmp expect actual | 
 | ' | 
 |  | 
 | test_expect_success 'branch --contains combined with --no-contains' ' | 
 | 	git branch --contains zzz --no-contains topic >actual && | 
 | 	cat >expect <<-\EOF && | 
 | 	  master | 
 | 	  side | 
 | 	  zzz | 
 | 	EOF | 
 | 	test_cmp expect actual | 
 |  | 
 | ' | 
 |  | 
 | test_done |