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
|