#!/bin/sh test_description='Test diff-highlight' CURR_DIR=$(pwd) TEST_OUTPUT_DIRECTORY=$(pwd) TEST_DIRECTORY="$CURR_DIR"/../../../t DIFF_HIGHLIGHT="$CURR_DIR"/../diff-highlight CW="$(printf "\033[7m")" # white CR="$(printf "\033[27m")" # reset . "$TEST_DIRECTORY"/test-lib.sh if ! test_have_prereq PERL then skip_all='skipping diff-highlight tests; perl not available' test_done fi # dh_test is a test helper function which takes 3 file names as parameters. The # first 2 files are used to generate diff and commit output, which is then # piped through diff-highlight. The 3rd file should contain the expected output # of diff-highlight (minus the diff/commit header, ie. everything after and # including the first @@ line). dh_test () { a="$1" b="$2" && cat >patch.exp && { cat "$a" >file && git add file && git commit -m "Add a file" && cat "$b" >file && git diff file >diff.raw && git commit -a -m "Update a file" && git show >commit.raw } >/dev/null && "$DIFF_HIGHLIGHT" diff.act && "$DIFF_HIGHLIGHT" commit.act && test_cmp patch.exp diff.act && test_cmp patch.exp commit.act } test_strip_patch_header () { sed -n '/^@@/,$p' $* } # dh_test_setup_history generates a contrived graph such that we have at least # 1 nesting (E) and 2 nestings (F). # # A branch # / # D---E---F master # # git log --all --graph # * commit # | A # | * commit # | | F # | * commit # |/ # | E # * commit # D # dh_test_setup_history () { echo "file1" >file1 && echo "file2" >file2 && echo "file3" >file3 && cat file1 >file && git add file && git commit -m "D" && git checkout -b branch && cat file2 >file && git commit -a -m "A" && git checkout master && cat file2 >file && git commit -a -m "E" && cat file3 >file && git commit -a -m "F" } left_trim () { "$PERL_PATH" -pe 's/^\s+//' } trim_graph () { # graphs start with * or | # followed by a space or / or \ "$PERL_PATH" -pe 's@^((\*|\|)( |/|\\))+@@' } test_expect_success 'diff-highlight highlights the beginning of a line' ' cat >a <<-\EOF && aaa bbb ccc EOF cat >b <<-\EOF && aaa 0bb ccc EOF dh_test a b <<-EOF @@ -1,3 +1,3 @@ aaa -${CW}b${CR}bb +${CW}0${CR}bb ccc EOF ' test_expect_success 'diff-highlight highlights the end of a line' ' cat >a <<-\EOF && aaa bbb ccc EOF cat >b <<-\EOF && aaa bb0 ccc EOF dh_test a b <<-EOF @@ -1,3 +1,3 @@ aaa -bb${CW}b${CR} +bb${CW}0${CR} ccc EOF ' test_expect_success 'diff-highlight highlights the middle of a line' ' cat >a <<-\EOF && aaa bbb ccc EOF cat >b <<-\EOF && aaa b0b ccc EOF dh_test a b <<-EOF @@ -1,3 +1,3 @@ aaa -b${CW}b${CR}b +b${CW}0${CR}b ccc EOF ' test_expect_success 'diff-highlight does not highlight whole line' ' cat >a <<-\EOF && aaa bbb ccc EOF cat >b <<-\EOF && aaa 000 ccc EOF dh_test a b <<-EOF @@ -1,3 +1,3 @@ aaa -bbb +000 ccc EOF ' test_expect_failure 'diff-highlight highlights mismatched hunk size' ' cat >a <<-\EOF && aaa bbb EOF cat >b <<-\EOF && aaa b0b ccc EOF dh_test a b <<-EOF @@ -1,3 +1,3 @@ aaa -b${CW}b${CR}b +b${CW}0${CR}b +ccc EOF ' # TODO add multi-byte test test_expect_success 'diff-highlight works with the --graph option' ' dh_test_setup_history && # topo-order so that the order of the commits is the same as with --graph # trim graph elements so we can do a diff # trim leading space because our trim_graph is not perfect git log --branches -p --topo-order | "$DIFF_HIGHLIGHT" | left_trim >graph.exp && git log --branches -p --graph | "$DIFF_HIGHLIGHT" | trim_graph | left_trim >graph.act && test_cmp graph.exp graph.act ' test_done