#!/bin/sh test_description='blaming through history with topic branches' TEST_PASSES_SANITIZE_LEAK=true . ./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 && git rev-parse A1 >expect && test_cmp expect actual ' test_done