#!/bin/sh # # Copyright (c) 2012 Zbigniew Jędrzejewski-Szmek # setglobal test_description = ''test --stat output of various commands'' source ./test-lib.sh source "$TEST_DIRECTORY"/lib-terminal.sh # 120 character name setglobal name = 'aaaaaaaaaa' setglobal name = "$name$name$name$name$name$name$name$name$name$name$name$name" test_expect_success 'preparation' ' >"$name" && git add "$name" && git commit -m message && echo a >"$name" && git commit -m message "$name" ' while read cmd args { cat >expect << ''' ...aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa | 1 + ''' test_expect_success "$cmd: small change with long name gives more space to the name" ' git $cmd $args >output && grep " | " output >actual && test_cmp expect actual ' cat >expect << ''' ...aaaaaaaaaaaaaaaaaaaaaaaaaaaaa | 1 + ''' test_expect_success "$cmd --stat=width: a long name is given more room when the bar is short" ' git $cmd $args --stat=40 >output && grep " | " output >actual && test_cmp expect actual ' test_expect_success "$cmd --stat-width=width with long name" ' git $cmd $args --stat-width=40 >output && grep " | " output >actual && test_cmp expect actual ' cat >expect << ''' ...aaaaaaaaaaaaaaaaaaaaaaaaaaa | 1 + ''' test_expect_success "$cmd --stat=...,name-width with long name" ' git $cmd $args --stat=60,30 >output && grep " | " output >actual && test_cmp expect actual ' test_expect_success "$cmd --stat-name-width with long name" ' git $cmd $args --stat-name-width=30 >output && grep " | " output >actual && test_cmp expect actual ' } <<\EOF format-patch -1 --stdout diff HEAD^ HEAD --stat show --stat log -1 --stat EOF test_expect_success 'preparation for big change tests' ' >abcd && git add abcd && git commit -m message && i=0 && while test $i -lt 1000 do echo $i && i=$(($i + 1)) done >abcd && git commit -m message abcd ' cat >expect80 << ''' abcd | 1000 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ''' cat >expect80-graph << ''' | abcd | 1000 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ''' cat >expect200 << ''' abcd | 1000 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ''' cat >expect200-graph << ''' | abcd | 1000 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ''' while read verb expect cmd args { test_expect_success "$cmd $verb COLUMNS (big change)" ' COLUMNS=200 git $cmd $args >output && grep " | " output >actual && test_cmp "$expect" actual ' match $cmd { with diff|show continue } test_expect_success "$cmd --graph $verb COLUMNS (big change)" ' COLUMNS=200 git $cmd $args --graph >output && grep " | " output >actual && test_cmp "$expect-graph" actual ' } <<\EOF ignores expect80 format-patch -1 --stdout respects expect200 diff HEAD^ HEAD --stat respects expect200 show --stat respects expect200 log -1 --stat EOF cat >expect40 << ''' abcd | 1000 ++++++++++++++++++++++++++ ''' cat >expect40-graph << ''' | abcd | 1000 ++++++++++++++++++++++++ ''' while read verb expect cmd args { test_expect_success "$cmd $verb not enough COLUMNS (big change)" ' COLUMNS=40 git $cmd $args >output && grep " | " output >actual && test_cmp "$expect" actual ' match $cmd { with diff|show continue } test_expect_success "$cmd --graph $verb not enough COLUMNS (big change)" ' COLUMNS=40 git $cmd $args --graph >output && grep " | " output >actual && test_cmp "$expect-graph" actual ' } <<\EOF ignores expect80 format-patch -1 --stdout respects expect40 diff HEAD^ HEAD --stat respects expect40 show --stat respects expect40 log -1 --stat EOF cat >expect40 << ''' abcd | 1000 ++++++++++++++++++++++++++ ''' cat >expect40-graph << ''' | abcd | 1000 ++++++++++++++++++++++++++ ''' while read verb expect cmd args { test_expect_success "$cmd $verb statGraphWidth config" ' git -c diff.statGraphWidth=26 $cmd $args >output && grep " | " output >actual && test_cmp "$expect" actual ' match $cmd { with diff|show continue } test_expect_success "$cmd --graph $verb statGraphWidth config" ' git -c diff.statGraphWidth=26 $cmd $args --graph >output && grep " | " output >actual && test_cmp "$expect-graph" actual ' } <<\EOF ignores expect80 format-patch -1 --stdout respects expect40 diff HEAD^ HEAD --stat respects expect40 show --stat respects expect40 log -1 --stat EOF cat >expect << ''' abcd | 1000 ++++++++++++++++++++++++++ ''' cat >expect-graph << ''' | abcd | 1000 ++++++++++++++++++++++++++ ''' while read cmd args { test_expect_success "$cmd --stat=width with big change" ' git $cmd $args --stat=40 >output && grep " | " output >actual && test_cmp expect actual ' test_expect_success "$cmd --stat-width=width with big change" ' git $cmd $args --stat-width=40 >output && grep " | " output >actual && test_cmp expect actual ' test_expect_success "$cmd --stat-graph-width with big change" ' git $cmd $args --stat-graph-width=26 >output && grep " | " output >actual && test_cmp expect actual ' match $cmd { with diff|show continue } test_expect_success "$cmd --stat-width=width --graph with big change" ' git $cmd $args --stat-width=40 --graph >output && grep " | " output >actual && test_cmp expect-graph actual ' test_expect_success "$cmd --stat-graph-width --graph with big change" ' git $cmd $args --stat-graph-width=26 --graph >output && grep " | " output >actual && test_cmp expect-graph actual ' } <<\EOF format-patch -1 --stdout diff HEAD^ HEAD --stat show --stat log -1 --stat EOF test_expect_success 'preparation for long filename tests' ' cp abcd aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa && git add aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa && git commit -m message ' cat >expect << ''' ...aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa | 1000 ++++++++++++ ''' cat >expect-graph << ''' | ...aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa | 1000 ++++++++++++ ''' while read cmd args { test_expect_success "$cmd --stat=width with big change is more balanced" ' git $cmd $args --stat-width=60 >output && grep " | " output >actual && test_cmp expect actual ' match $cmd { with diff|show continue } test_expect_success "$cmd --stat=width --graph with big change is balanced" ' git $cmd $args --stat-width=60 --graph >output && grep " | " output >actual && test_cmp expect-graph actual ' } <<\EOF format-patch -1 --stdout diff HEAD^ HEAD --stat show --stat log -1 --stat EOF cat >expect80 << ''' ...aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa | 1000 ++++++++++++++++++++ ''' cat >expect80-graph << ''' | ...aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa | 1000 ++++++++++++++++++++ ''' cat >expect200 << ''' aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa | 1000 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ''' cat >expect200-graph << ''' | aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa | 1000 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ''' while read verb expect cmd args { test_expect_success "$cmd $verb COLUMNS (long filename)" ' COLUMNS=200 git $cmd $args >output && grep " | " output >actual && test_cmp "$expect" actual ' match $cmd { with diff|show continue } test_expect_success "$cmd --graph $verb COLUMNS (long filename)" ' COLUMNS=200 git $cmd $args --graph >output && grep " | " output >actual && test_cmp "$expect-graph" actual ' } <<\EOF ignores expect80 format-patch -1 --stdout respects expect200 diff HEAD^ HEAD --stat respects expect200 show --stat respects expect200 log -1 --stat EOF cat >expect1 << ''' ...aaaaaaa | 1000 ++++++ ''' cat >expect1-graph << ''' | ...aaaaaaa | 1000 ++++++ ''' while read verb expect cmd args { test_expect_success COLUMNS_CAN_BE_1 \ "$cmd $verb prefix greater than COLUMNS (big change)" ' COLUMNS=1 git $cmd $args >output && grep " | " output >actual && test_cmp "$expect" actual ' match $cmd { with diff|show continue } test_expect_success COLUMNS_CAN_BE_1 \ "$cmd --graph $verb prefix greater than COLUMNS (big change)" ' COLUMNS=1 git $cmd $args --graph >output && grep " | " output >actual && test_cmp "$expect-graph" actual ' } <<\EOF ignores expect80 format-patch -1 --stdout respects expect1 diff HEAD^ HEAD --stat respects expect1 show --stat respects expect1 log -1 --stat EOF cat >expect << ''' abcd | 1000 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ''' test_expect_success 'merge --stat respects COLUMNS (big change)' ' git checkout -b branch HEAD^^ && COLUMNS=100 git merge --stat --no-ff master^ >output && grep " | " output >actual && test_cmp expect actual ' cat >expect << ''' aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa | 1000 +++++++++++++++++++++++++++++++++++++++ ''' test_expect_success 'merge --stat respects COLUMNS (long filename)' ' COLUMNS=100 git merge --stat --no-ff master >output && grep " | " output >actual && test_cmp expect actual ' test_done