38 lines
		
	
	
		
			859 B
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
			
		
		
	
	
			38 lines
		
	
	
		
			859 B
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
| #!/bin/sh
 | |
| 
 | |
| test_description='blaming through history with topic branches'
 | |
| 
 | |
| . ./test-lib.sh
 | |
| 
 | |
| # Creates the history shown below. '*'s mark the first parent in the merges.
 | |
| # The only line of file.t is changed in commit B2
 | |
| #
 | |
| #        +---C1
 | |
| #       /      \
 | |
| # A0--A1--*A2--*A3
 | |
| #   \     /
 | |
| #    B1-B2
 | |
| #
 | |
| test_expect_success setup '
 | |
| 	test_commit A0 file.t line0 &&
 | |
| 	test_commit A1 &&
 | |
| 	git reset --hard A0 &&
 | |
| 	test_commit B1 &&
 | |
| 	test_commit B2 file.t line0changed &&
 | |
| 	git reset --hard A1 &&
 | |
| 	test_merge A2 B2 &&
 | |
| 	git reset --hard A1 &&
 | |
| 	test_commit C1 &&
 | |
| 	git reset --hard A2 &&
 | |
| 	test_merge A3 C1
 | |
| 	'
 | |
| 
 | |
| test_expect_success 'blame --reverse --first-parent finds A1' '
 | |
| 	git blame --porcelain --reverse --first-parent A0..A3 -- file.t >actual_full &&
 | |
| 	head -n 1 <actual_full | sed -e "s/ .*//" >actual &&
 | |
| 	git rev-parse A1 >expect &&
 | |
| 	test_cmp expect actual
 | |
| 	'
 | |
| 
 | |
| test_done
 |