pretty: test --expand-tabs
The test prepares a simple commit with HT on its log message lines, and makes sure that - formats that should or should not expand tabs by default do or do not expand tabs respectively, - with explicit --expand-tabs=<N> and short-hands --expand-tabs (equivalent to --expand-tabs=8) and --no-expand-tabs (equivalent to --expand-tabs=0) before or after the explicit --pretty=$fmt, the tabs are expanded (or not expanded) accordingly. The tests use the second line of the log message for formats other than --pretty=short, primarily because the first line of the email format is handled specially to add the [PATCH] prefix, etc. in a separate codepath (--pretty=short uses the first line because there is no other line to test). Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
fe37a9c586
commit
915c96df38
105
t/t4213-log-tabexpand.sh
Executable file
105
t/t4213-log-tabexpand.sh
Executable file
@ -0,0 +1,105 @@
|
||||
#!/bin/sh
|
||||
|
||||
test_description='log/show --expand-tabs'
|
||||
|
||||
. ./test-lib.sh
|
||||
|
||||
HT=" "
|
||||
title='tab indent at the beginning of the title line'
|
||||
body='tab indent on a line in the body'
|
||||
|
||||
# usage: count_expand $indent $numSP $numHT @format_args
|
||||
count_expand ()
|
||||
{
|
||||
expect=
|
||||
count=$(( $1 + $2 )) ;# expected spaces
|
||||
while test $count -gt 0
|
||||
do
|
||||
expect="$expect "
|
||||
count=$(( $count - 1 ))
|
||||
done
|
||||
shift 2
|
||||
count=$1 ;# expected tabs
|
||||
while test $count -gt 0
|
||||
do
|
||||
expect="$expect$HT"
|
||||
count=$(( $count - 1 ))
|
||||
done
|
||||
shift
|
||||
|
||||
# The remainder of the command line is "git show -s" options
|
||||
case " $* " in
|
||||
*' --pretty=short '*)
|
||||
line=$title ;;
|
||||
*)
|
||||
line=$body ;;
|
||||
esac
|
||||
|
||||
# Prefix the output with the command line arguments, and
|
||||
# replace SP with a dot both in the expecte and actual output
|
||||
# so that test_cmp would show the differene together with the
|
||||
# breakage in a way easier to consume by the debugging user.
|
||||
{
|
||||
echo "git show -s $*"
|
||||
echo "$expect$line"
|
||||
} | sed -e 's/ /./g' >expect
|
||||
|
||||
{
|
||||
echo "git show -s $*"
|
||||
git show -s "$@" |
|
||||
sed -n -e "/$line\$/p"
|
||||
} | sed -e 's/ /./g' >actual
|
||||
|
||||
test_cmp expect actual
|
||||
}
|
||||
|
||||
test_expand ()
|
||||
{
|
||||
fmt=$1
|
||||
case "$fmt" in
|
||||
*=raw | *=short | *=email)
|
||||
default="0 1" ;;
|
||||
*)
|
||||
default="8 0" ;;
|
||||
esac
|
||||
case "$fmt" in
|
||||
*=email)
|
||||
in=0 ;;
|
||||
*)
|
||||
in=4 ;;
|
||||
esac
|
||||
test_expect_success "expand/no-expand${fmt:+ for $fmt}" '
|
||||
count_expand $in $default $fmt &&
|
||||
count_expand $in 8 0 $fmt --expand-tabs &&
|
||||
count_expand $in 8 0 --expand-tabs $fmt &&
|
||||
count_expand $in 8 0 $fmt --expand-tabs=8 &&
|
||||
count_expand $in 8 0 --expand-tabs=8 $fmt &&
|
||||
count_expand $in 0 1 $fmt --no-expand-tabs &&
|
||||
count_expand $in 0 1 --no-expand-tabs $fmt &&
|
||||
count_expand $in 0 1 $fmt --expand-tabs=0 &&
|
||||
count_expand $in 0 1 --expand-tabs=0 $fmt &&
|
||||
count_expand $in 4 0 $fmt --expand-tabs=4 &&
|
||||
count_expand $in 4 0 --expand-tabs=4 $fmt
|
||||
'
|
||||
}
|
||||
|
||||
test_expect_success 'setup' '
|
||||
test_tick &&
|
||||
sed -e "s/Q/$HT/g" <<-EOF >msg &&
|
||||
Q$title
|
||||
|
||||
Q$body
|
||||
EOF
|
||||
git commit --allow-empty -F msg
|
||||
'
|
||||
|
||||
test_expand ""
|
||||
test_expand --pretty
|
||||
test_expand --pretty=short
|
||||
test_expand --pretty=medium
|
||||
test_expand --pretty=full
|
||||
test_expand --pretty=fuller
|
||||
test_expand --pretty=raw
|
||||
test_expand --pretty=email
|
||||
|
||||
test_done
|
Loading…
Reference in New Issue
Block a user