Extract the commonly used initialization of the --stat-width=<width>, --stat-name-width=<width> and --stat-graph-with=<width> parameters to their internal default values into a helper function, to avoid repeating the same initialization code in a few places. Add a couple of tests to additionally cover existing configuration options diff.statNameWidth=<width> and diff.statGraphWidth=<width> when used by git-merge to generate --stat outputs. This closes the gap that existed previously in the --stat tests, and reduces the chances for having any regressions introduced by this commit. While there, perform a small bunch of minor wording tweaks in the improved unit test, to improve its test-level consistency a bit. Signed-off-by: Dragan Simic <dsimic@manjaro.org> Signed-off-by: Junio C Hamano <gitster@pobox.com>
		
			
				
	
	
		
			418 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			418 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
#!/bin/sh
 | 
						|
#
 | 
						|
# Copyright (c) 2012 Zbigniew Jędrzejewski-Szmek
 | 
						|
#
 | 
						|
 | 
						|
test_description='test --stat output of various commands'
 | 
						|
 | 
						|
GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME=main
 | 
						|
export GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME
 | 
						|
 | 
						|
TEST_PASSES_SANITIZE_LEAK=true
 | 
						|
. ./test-lib.sh
 | 
						|
. "$TEST_DIRECTORY"/lib-terminal.sh
 | 
						|
 | 
						|
# 120-character name
 | 
						|
name=aaaaaaaaaa
 | 
						|
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"
 | 
						|
'
 | 
						|
 | 
						|
cat >expect72 <<-'EOF'
 | 
						|
 ...aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa | 1 +
 | 
						|
EOF
 | 
						|
test_expect_success "format-patch: small change with long name gives more space to the name" '
 | 
						|
	git format-patch -1 --stdout >output &&
 | 
						|
	grep " | " output >actual &&
 | 
						|
	test_cmp expect72 actual
 | 
						|
'
 | 
						|
 | 
						|
while read cmd args
 | 
						|
do
 | 
						|
	cat >expect80 <<-'EOF'
 | 
						|
	 ...aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa | 1 +
 | 
						|
	EOF
 | 
						|
	test_expect_success "$cmd: small change with long name gives more space to the name" '
 | 
						|
		git $cmd $args >output &&
 | 
						|
		grep " | " output >actual &&
 | 
						|
		test_cmp expect80 actual
 | 
						|
	'
 | 
						|
done <<\EOF
 | 
						|
diff HEAD^ HEAD --stat
 | 
						|
show --stat
 | 
						|
log -1 --stat
 | 
						|
EOF
 | 
						|
 | 
						|
cat >expect.60 <<-'EOF'
 | 
						|
 ...aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa | 1 +
 | 
						|
EOF
 | 
						|
cat >expect.6030 <<-'EOF'
 | 
						|
 ...aaaaaaaaaaaaaaaaaaaaaaaaaaa | 1 +
 | 
						|
EOF
 | 
						|
while read verb expect cmd args
 | 
						|
do
 | 
						|
	# No width limit applied when statNameWidth is ignored
 | 
						|
	case "$expect" in expect72|expect.6030)
 | 
						|
		test_expect_success "$cmd $verb diff.statNameWidth with long name" '
 | 
						|
			git -c diff.statNameWidth=30 $cmd $args >output &&
 | 
						|
			grep " | " output >actual &&
 | 
						|
			test_cmp $expect actual
 | 
						|
		';;
 | 
						|
	esac
 | 
						|
	# Maximum width limit still applied when statNameWidth is ignored
 | 
						|
	case "$expect" in expect.60|expect.6030)
 | 
						|
		test_expect_success "$cmd --stat=width $verb diff.statNameWidth with long name" '
 | 
						|
			git -c diff.statNameWidth=30 $cmd $args --stat=60 >output &&
 | 
						|
			grep " | " output >actual &&
 | 
						|
			test_cmp $expect actual
 | 
						|
		';;
 | 
						|
	esac
 | 
						|
done <<\EOF
 | 
						|
ignores expect72 format-patch -1 --stdout
 | 
						|
ignores expect.60 format-patch -1 --stdout
 | 
						|
respects expect.6030 diff HEAD^ HEAD --stat
 | 
						|
respects expect.6030 show --stat
 | 
						|
respects expect.6030 log -1 --stat
 | 
						|
EOF
 | 
						|
 | 
						|
cat >expect.40 <<-'EOF'
 | 
						|
 ...aaaaaaaaaaaaaaaaaaaaaaaaaaaaa | 1 +
 | 
						|
EOF
 | 
						|
cat >expect2.40 <<-'EOF'
 | 
						|
 ...aaaaaaaaaaaaaaaaaaaaaaaaaaaaa | 1 +
 | 
						|
 ...aaaaaaaaaaaaaaaaaaaaaaaaaaaaa | 1 +
 | 
						|
EOF
 | 
						|
cat >expect2.6030 <<-'EOF'
 | 
						|
 ...aaaaaaaaaaaaaaaaaaaaaaaaaaa | 1 +
 | 
						|
 ...aaaaaaaaaaaaaaaaaaaaaaaaaaa | 1 +
 | 
						|
EOF
 | 
						|
while read expect cmd args
 | 
						|
do
 | 
						|
	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.40 actual
 | 
						|
	'
 | 
						|
 | 
						|
	test_expect_success "$cmd --stat-width=width with long name" '
 | 
						|
		git $cmd $args --stat-width=40 >output &&
 | 
						|
		grep " | " output >actual &&
 | 
						|
		test_cmp $expect.40 actual
 | 
						|
	'
 | 
						|
 | 
						|
	test_expect_success "$cmd --stat=width,name-width with long name" '
 | 
						|
		git $cmd $args --stat=60,30 >output &&
 | 
						|
		grep " | " output >actual &&
 | 
						|
		test_cmp $expect.6030 actual
 | 
						|
	'
 | 
						|
 | 
						|
	test_expect_success "$cmd --stat-name-width=width with long name" '
 | 
						|
		git $cmd $args --stat-name-width=30 >output &&
 | 
						|
		grep " | " output >actual &&
 | 
						|
		test_cmp $expect.6030 actual
 | 
						|
	'
 | 
						|
done <<\EOF
 | 
						|
expect2 format-patch --cover-letter -1 --stdout
 | 
						|
expect diff HEAD^ HEAD --stat
 | 
						|
expect show --stat
 | 
						|
expect 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)) || return 1
 | 
						|
	done >abcd &&
 | 
						|
	git commit -m message abcd
 | 
						|
'
 | 
						|
 | 
						|
cat >expect72 <<'EOF'
 | 
						|
 abcd | 1000 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 | 
						|
 abcd | 1000 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 | 
						|
EOF
 | 
						|
test_expect_success "format-patch --cover-letter ignores COLUMNS with big change" '
 | 
						|
	COLUMNS=200 git format-patch -1 --stdout --cover-letter >output &&
 | 
						|
	grep " | " output >actual &&
 | 
						|
	test_cmp expect72 actual
 | 
						|
'
 | 
						|
 | 
						|
cat >expect72 <<'EOF'
 | 
						|
 abcd | 1000 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 | 
						|
EOF
 | 
						|
cat >expect72-graph <<'EOF'
 | 
						|
|  abcd | 1000 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 | 
						|
EOF
 | 
						|
cat >expect200 <<'EOF'
 | 
						|
 abcd | 1000 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 | 
						|
EOF
 | 
						|
cat >expect200-graph <<'EOF'
 | 
						|
|  abcd | 1000 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 | 
						|
EOF
 | 
						|
while read verb expect cmd args
 | 
						|
do
 | 
						|
	test_expect_success "$cmd $verb COLUMNS with big change" '
 | 
						|
		COLUMNS=200 git $cmd $args >output &&
 | 
						|
		grep " | " output >actual &&
 | 
						|
		test_cmp "$expect" actual
 | 
						|
	'
 | 
						|
 | 
						|
	case "$cmd" in diff|show) continue;; esac
 | 
						|
 | 
						|
	test_expect_success "$cmd --graph $verb COLUMNS with big change" '
 | 
						|
		COLUMNS=200 git $cmd $args --graph >output &&
 | 
						|
		grep " | " output >actual &&
 | 
						|
		test_cmp "$expect-graph" actual
 | 
						|
	'
 | 
						|
done <<\EOF
 | 
						|
ignores expect72 format-patch -1 --stdout
 | 
						|
respects expect200 diff HEAD^ HEAD --stat
 | 
						|
respects expect200 show --stat
 | 
						|
respects expect200 log -1 --stat
 | 
						|
EOF
 | 
						|
 | 
						|
cat >expect40 <<'EOF'
 | 
						|
 abcd | 1000 ++++++++++++++++++++++++++
 | 
						|
EOF
 | 
						|
cat >expect40-graph <<'EOF'
 | 
						|
|  abcd | 1000 ++++++++++++++++++++++++
 | 
						|
EOF
 | 
						|
while read verb expect cmd args
 | 
						|
do
 | 
						|
	test_expect_success "$cmd $verb not enough COLUMNS with big change" '
 | 
						|
		COLUMNS=40 git $cmd $args >output &&
 | 
						|
		grep " | " output >actual &&
 | 
						|
		test_cmp "$expect" actual
 | 
						|
	'
 | 
						|
 | 
						|
	case "$cmd" in diff|show) continue;; esac
 | 
						|
 | 
						|
	test_expect_success "$cmd --graph $verb not enough COLUMNS with big change" '
 | 
						|
		COLUMNS=40 git $cmd $args --graph >output &&
 | 
						|
		grep " | " output >actual &&
 | 
						|
		test_cmp "$expect-graph" actual
 | 
						|
	'
 | 
						|
done <<\EOF
 | 
						|
ignores expect72 format-patch -1 --stdout
 | 
						|
respects expect40 diff HEAD^ HEAD --stat
 | 
						|
respects expect40 show --stat
 | 
						|
respects expect40 log -1 --stat
 | 
						|
EOF
 | 
						|
 | 
						|
cat >expect40 <<'EOF'
 | 
						|
 abcd | 1000 ++++++++++++++++++++++++++
 | 
						|
EOF
 | 
						|
cat >expect40-graph <<'EOF'
 | 
						|
|  abcd | 1000 ++++++++++++++++++++++++++
 | 
						|
EOF
 | 
						|
while read verb expect cmd args
 | 
						|
do
 | 
						|
	test_expect_success "$cmd $verb diff.statGraphWidth" '
 | 
						|
		git -c diff.statGraphWidth=26 $cmd $args >output &&
 | 
						|
		grep " | " output >actual &&
 | 
						|
		test_cmp "$expect" actual
 | 
						|
	'
 | 
						|
 | 
						|
	case "$cmd" in diff|show) continue;; esac
 | 
						|
 | 
						|
	test_expect_success "$cmd --graph $verb diff.statGraphWidth" '
 | 
						|
		git -c diff.statGraphWidth=26 $cmd $args --graph >output &&
 | 
						|
		grep " | " output >actual &&
 | 
						|
		test_cmp "$expect-graph" actual
 | 
						|
	'
 | 
						|
done <<\EOF
 | 
						|
ignores expect72 format-patch -1 --stdout
 | 
						|
respects expect40 diff HEAD^ HEAD --stat
 | 
						|
respects expect40 show --stat
 | 
						|
respects expect40 log -1 --stat
 | 
						|
EOF
 | 
						|
 | 
						|
cat >expect <<'EOF'
 | 
						|
 abcd | 1000 ++++++++++++++++++++++++++
 | 
						|
EOF
 | 
						|
cat >expect-graph <<'EOF'
 | 
						|
|  abcd | 1000 ++++++++++++++++++++++++++
 | 
						|
EOF
 | 
						|
while read cmd args
 | 
						|
do
 | 
						|
	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=width with big change" '
 | 
						|
		git $cmd $args --stat-graph-width=26 >output &&
 | 
						|
		grep " | " output >actual &&
 | 
						|
		test_cmp expect actual
 | 
						|
	'
 | 
						|
 | 
						|
	case "$cmd" in diff|show) continue;; esac
 | 
						|
 | 
						|
	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=width --graph with big change" '
 | 
						|
		git $cmd $args --stat-graph-width=26 --graph >output &&
 | 
						|
		grep " | " output >actual &&
 | 
						|
		test_cmp expect-graph actual
 | 
						|
	'
 | 
						|
done <<\EOF
 | 
						|
format-patch -1 --stdout
 | 
						|
diff HEAD^ HEAD --stat
 | 
						|
show --stat
 | 
						|
log -1 --stat
 | 
						|
EOF
 | 
						|
 | 
						|
test_expect_success 'preparation for long-name tests' '
 | 
						|
	cp abcd aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa &&
 | 
						|
	git add aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa &&
 | 
						|
	git commit -m message
 | 
						|
'
 | 
						|
 | 
						|
cat >expect <<'EOF'
 | 
						|
 ...aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa | 1000 ++++++++++++
 | 
						|
EOF
 | 
						|
cat >expect-graph <<'EOF'
 | 
						|
|  ...aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa | 1000 ++++++++++++
 | 
						|
EOF
 | 
						|
while read cmd args
 | 
						|
do
 | 
						|
	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
 | 
						|
	'
 | 
						|
 | 
						|
	case "$cmd" in diff|show) continue;; esac
 | 
						|
 | 
						|
	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
 | 
						|
	'
 | 
						|
done <<\EOF
 | 
						|
format-patch -1 --stdout
 | 
						|
diff HEAD^ HEAD --stat
 | 
						|
show --stat
 | 
						|
log -1 --stat
 | 
						|
EOF
 | 
						|
 | 
						|
cat >expect72 <<'EOF'
 | 
						|
 ...aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa | 1000 +++++++++++++++++
 | 
						|
EOF
 | 
						|
cat >expect72-graph <<'EOF'
 | 
						|
|  ...aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa | 1000 +++++++++++++++++
 | 
						|
EOF
 | 
						|
cat >expect200 <<'EOF'
 | 
						|
 aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa | 1000 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 | 
						|
EOF
 | 
						|
cat >expect200-graph <<'EOF'
 | 
						|
|  aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa | 1000 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 | 
						|
EOF
 | 
						|
while read verb expect cmd args
 | 
						|
do
 | 
						|
	test_expect_success "$cmd $verb COLUMNS with long name" '
 | 
						|
		COLUMNS=200 git $cmd $args >output &&
 | 
						|
		grep " | " output >actual &&
 | 
						|
		test_cmp "$expect" actual
 | 
						|
	'
 | 
						|
 | 
						|
	case "$cmd" in diff|show) continue;; esac
 | 
						|
 | 
						|
	test_expect_success "$cmd --graph $verb COLUMNS with long name" '
 | 
						|
		COLUMNS=200 git $cmd $args --graph >output &&
 | 
						|
		grep " | " output >actual &&
 | 
						|
		test_cmp "$expect-graph" actual
 | 
						|
	'
 | 
						|
done <<\EOF
 | 
						|
ignores expect72 format-patch -1 --stdout
 | 
						|
respects expect200 diff HEAD^ HEAD --stat
 | 
						|
respects expect200 show --stat
 | 
						|
respects expect200 log -1 --stat
 | 
						|
EOF
 | 
						|
 | 
						|
cat >expect1 <<'EOF'
 | 
						|
 ...aaaaaaa | 1000 ++++++
 | 
						|
EOF
 | 
						|
cat >expect1-graph <<'EOF'
 | 
						|
|  ...aaaaaaa | 1000 ++++++
 | 
						|
EOF
 | 
						|
while read verb expect cmd args
 | 
						|
do
 | 
						|
	test_expect_success COLUMNS_CAN_BE_1 \
 | 
						|
		"$cmd $verb prefix greater than COLUMNS with big change" '
 | 
						|
		COLUMNS=1 git $cmd $args >output &&
 | 
						|
		grep " | " output >actual &&
 | 
						|
		test_cmp "$expect" actual
 | 
						|
	'
 | 
						|
 | 
						|
	case "$cmd" in diff|show) continue;; esac
 | 
						|
 | 
						|
	test_expect_success COLUMNS_CAN_BE_1 \
 | 
						|
		"$cmd --graph $verb prefix greater than COLUMNS with big change" '
 | 
						|
		COLUMNS=1 git $cmd $args --graph >output &&
 | 
						|
		grep " | " output >actual &&
 | 
						|
		test_cmp "$expect-graph" actual
 | 
						|
	'
 | 
						|
done <<\EOF
 | 
						|
ignores expect72 format-patch -1 --stdout
 | 
						|
respects expect1 diff HEAD^ HEAD --stat
 | 
						|
respects expect1 show --stat
 | 
						|
respects expect1 log -1 --stat
 | 
						|
EOF
 | 
						|
 | 
						|
cat >expect <<'EOF'
 | 
						|
 abcd | 1000 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 | 
						|
EOF
 | 
						|
test_expect_success 'merge --stat respects diff.statGraphWidth with big change' '
 | 
						|
	git checkout -b branch1 HEAD^^ &&
 | 
						|
	git -c diff.statGraphWidth=26 merge --stat --no-ff main^ >output &&
 | 
						|
	grep " | " output >actual &&
 | 
						|
	test_cmp expect40 actual
 | 
						|
'
 | 
						|
test_expect_success 'merge --stat respects COLUMNS with big change' '
 | 
						|
	git checkout -b branch2 HEAD^^ &&
 | 
						|
	COLUMNS=100 git merge --stat --no-ff main^ >output &&
 | 
						|
	grep " | " output >actual &&
 | 
						|
	test_cmp expect actual
 | 
						|
'
 | 
						|
 | 
						|
cat >expect <<'EOF'
 | 
						|
 aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa | 1000 +++++++++++++++++++++++++++++++++++++++
 | 
						|
EOF
 | 
						|
cat >expect.30 <<'EOF'
 | 
						|
 ...aaaaaaaaaaaaaaaaaaaaaaaaaaa | 1000 ++++++++++++++++++++++++++++++++++++++++
 | 
						|
EOF
 | 
						|
test_expect_success 'merge --stat respects diff.statNameWidth with long name' '
 | 
						|
	git switch branch1 &&
 | 
						|
	git -c diff.statNameWidth=30 merge --stat --no-ff main >output &&
 | 
						|
	grep " | " output >actual &&
 | 
						|
	test_cmp expect.30 actual
 | 
						|
'
 | 
						|
test_expect_success 'merge --stat respects COLUMNS with long name' '
 | 
						|
	git switch branch2 &&
 | 
						|
	COLUMNS=100 git merge --stat --no-ff main >output &&
 | 
						|
	grep " | " output >actual &&
 | 
						|
	test_cmp expect actual
 | 
						|
'
 | 
						|
 | 
						|
test_done
 |