2010-02-19 15:18:58 +08:00
|
|
|
#!/bin/sh
|
|
|
|
|
|
|
|
test_description='Test automatic use of a pager.'
|
|
|
|
|
|
|
|
. ./test-lib.sh
|
|
|
|
|
2010-04-15 08:38:07 +08:00
|
|
|
cleanup_fail() {
|
|
|
|
echo >&2 cleanup failed
|
|
|
|
(exit 1)
|
|
|
|
}
|
|
|
|
|
2010-02-20 16:50:25 +08:00
|
|
|
test_expect_success 'set up terminal for tests' '
|
2010-04-15 08:38:07 +08:00
|
|
|
rm -f stdout_is_tty ||
|
|
|
|
cleanup_fail &&
|
|
|
|
|
2010-02-19 15:18:58 +08:00
|
|
|
if test -t 1
|
|
|
|
then
|
2010-04-15 08:38:07 +08:00
|
|
|
>stdout_is_tty
|
2010-02-20 16:50:25 +08:00
|
|
|
elif
|
|
|
|
test_have_prereq PERL &&
|
|
|
|
"$PERL_PATH" "$TEST_DIRECTORY"/t7006/test-terminal.perl \
|
|
|
|
sh -c "test -t 1"
|
|
|
|
then
|
2010-04-15 08:38:07 +08:00
|
|
|
>test_terminal_works
|
2010-02-19 15:18:58 +08:00
|
|
|
fi
|
|
|
|
'
|
|
|
|
|
|
|
|
if test -e stdout_is_tty
|
|
|
|
then
|
2010-02-20 16:50:25 +08:00
|
|
|
test_terminal() { "$@"; }
|
|
|
|
test_set_prereq TTY
|
|
|
|
elif test -e test_terminal_works
|
|
|
|
then
|
|
|
|
test_terminal() {
|
|
|
|
"$PERL_PATH" "$TEST_DIRECTORY"/t7006/test-terminal.perl "$@"
|
|
|
|
}
|
2010-02-19 15:18:58 +08:00
|
|
|
test_set_prereq TTY
|
|
|
|
else
|
2010-02-20 16:50:25 +08:00
|
|
|
say no usable terminal, so skipping some tests
|
2010-02-19 15:18:58 +08:00
|
|
|
fi
|
|
|
|
|
|
|
|
test_expect_success 'setup' '
|
2010-06-02 23:32:26 +08:00
|
|
|
unset GIT_PAGER GIT_PAGER_IN_USE;
|
2010-04-15 08:38:07 +08:00
|
|
|
test_might_fail git config --unset core.pager &&
|
|
|
|
|
|
|
|
PAGER="cat >paginated.out" &&
|
|
|
|
export PAGER &&
|
|
|
|
|
2010-02-19 15:18:58 +08:00
|
|
|
test_commit initial
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success TTY 'some commands use a pager' '
|
2010-04-15 08:38:07 +08:00
|
|
|
rm -f paginated.out ||
|
|
|
|
cleanup_fail &&
|
|
|
|
|
2010-02-20 16:50:25 +08:00
|
|
|
test_terminal git log &&
|
2010-02-19 15:18:58 +08:00
|
|
|
test -e paginated.out
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success TTY 'some commands do not use a pager' '
|
2010-04-15 08:38:07 +08:00
|
|
|
rm -f paginated.out ||
|
|
|
|
cleanup_fail &&
|
|
|
|
|
2010-02-20 16:50:25 +08:00
|
|
|
test_terminal git rev-list HEAD &&
|
2010-02-19 15:18:58 +08:00
|
|
|
! test -e paginated.out
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'no pager when stdout is a pipe' '
|
2010-04-15 08:38:07 +08:00
|
|
|
rm -f paginated.out ||
|
|
|
|
cleanup_fail &&
|
|
|
|
|
2010-02-19 15:18:58 +08:00
|
|
|
git log | cat &&
|
|
|
|
! test -e paginated.out
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'no pager when stdout is a regular file' '
|
2010-04-15 08:38:07 +08:00
|
|
|
rm -f paginated.out ||
|
|
|
|
cleanup_fail &&
|
|
|
|
|
|
|
|
git log >file &&
|
2010-02-19 15:18:58 +08:00
|
|
|
! test -e paginated.out
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success TTY 'git --paginate rev-list uses a pager' '
|
2010-04-15 08:38:07 +08:00
|
|
|
rm -f paginated.out ||
|
|
|
|
cleanup_fail &&
|
|
|
|
|
2010-02-20 16:50:25 +08:00
|
|
|
test_terminal git --paginate rev-list HEAD &&
|
2010-02-19 15:18:58 +08:00
|
|
|
test -e paginated.out
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'no pager even with --paginate when stdout is a pipe' '
|
2010-04-15 08:38:07 +08:00
|
|
|
rm -f file paginated.out ||
|
|
|
|
cleanup_fail &&
|
|
|
|
|
2010-02-19 15:18:58 +08:00
|
|
|
git --paginate log | cat &&
|
|
|
|
! test -e paginated.out
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success TTY 'no pager with --no-pager' '
|
2010-04-15 08:38:07 +08:00
|
|
|
rm -f paginated.out ||
|
|
|
|
cleanup_fail &&
|
|
|
|
|
2010-02-20 16:50:25 +08:00
|
|
|
test_terminal git --no-pager log &&
|
2010-02-19 15:18:58 +08:00
|
|
|
! test -e paginated.out
|
|
|
|
'
|
|
|
|
|
|
|
|
# A colored commit log will begin with an appropriate ANSI escape
|
|
|
|
# for the first color; the text "commit" comes later.
|
|
|
|
colorful() {
|
2010-04-15 08:38:07 +08:00
|
|
|
read firstline <$1
|
2010-06-22 02:18:54 +08:00
|
|
|
! expr "$firstline" : "[a-zA-Z]" >/dev/null
|
2010-02-19 15:18:58 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
test_expect_success 'tests can detect color' '
|
2010-04-15 08:38:07 +08:00
|
|
|
rm -f colorful.log colorless.log ||
|
|
|
|
cleanup_fail &&
|
|
|
|
|
|
|
|
git log --no-color >colorless.log &&
|
|
|
|
git log --color >colorful.log &&
|
2010-02-19 15:18:58 +08:00
|
|
|
! colorful colorless.log &&
|
|
|
|
colorful colorful.log
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'no color when stdout is a regular file' '
|
2010-04-15 08:38:07 +08:00
|
|
|
rm -f colorless.log &&
|
|
|
|
git config color.ui auto ||
|
|
|
|
cleanup_fail &&
|
|
|
|
|
|
|
|
git log >colorless.log &&
|
2010-02-19 15:18:58 +08:00
|
|
|
! colorful colorless.log
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success TTY 'color when writing to a pager' '
|
2010-04-15 08:38:07 +08:00
|
|
|
rm -f paginated.out &&
|
|
|
|
git config color.ui auto ||
|
|
|
|
cleanup_fail &&
|
|
|
|
|
|
|
|
(
|
|
|
|
TERM=vt100 &&
|
|
|
|
export TERM &&
|
|
|
|
test_terminal git log
|
|
|
|
) &&
|
2010-02-19 15:18:58 +08:00
|
|
|
colorful paginated.out
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'color when writing to a file intended for a pager' '
|
2010-04-15 08:38:07 +08:00
|
|
|
rm -f colorful.log &&
|
|
|
|
git config color.ui auto ||
|
|
|
|
cleanup_fail &&
|
|
|
|
|
|
|
|
(
|
|
|
|
TERM=vt100 &&
|
|
|
|
GIT_PAGER_IN_USE=true &&
|
|
|
|
export TERM GIT_PAGER_IN_USE &&
|
|
|
|
git log >colorful.log
|
|
|
|
) &&
|
2010-02-19 15:18:58 +08:00
|
|
|
colorful colorful.log
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'determine default pager' '
|
2010-06-02 23:32:26 +08:00
|
|
|
unset PAGER GIT_PAGER;
|
2010-04-15 08:38:07 +08:00
|
|
|
test_might_fail git config --unset core.pager ||
|
|
|
|
cleanup_fail &&
|
|
|
|
|
2010-02-19 15:18:58 +08:00
|
|
|
less=$(git var GIT_PAGER) &&
|
|
|
|
test -n "$less"
|
|
|
|
'
|
|
|
|
|
2010-06-22 02:18:54 +08:00
|
|
|
if expr "$less" : '[a-z][a-z]*$' >/dev/null && test_have_prereq TTY
|
2010-02-19 15:18:58 +08:00
|
|
|
then
|
|
|
|
test_set_prereq SIMPLEPAGER
|
|
|
|
fi
|
|
|
|
|
2010-06-27 03:23:02 +08:00
|
|
|
# Use this helper to make it easy for the caller of your
|
|
|
|
# terminal-using function to specify whether it should fail.
|
|
|
|
# If you write
|
|
|
|
#
|
|
|
|
# your_test() {
|
|
|
|
# parse_args "$@"
|
|
|
|
#
|
|
|
|
# $test_expectation "$cmd - behaves well" "
|
|
|
|
# ...
|
|
|
|
# $full_command &&
|
|
|
|
# ...
|
|
|
|
# "
|
|
|
|
# }
|
|
|
|
#
|
|
|
|
# then your test can be used like this:
|
|
|
|
#
|
|
|
|
# your_test expect_(success|failure) [test_must_fail] 'git foo'
|
|
|
|
#
|
|
|
|
parse_args() {
|
|
|
|
test_expectation="test_$1"
|
|
|
|
shift
|
|
|
|
if test "$1" = test_must_fail
|
|
|
|
then
|
|
|
|
full_command="test_must_fail test_terminal "
|
|
|
|
shift
|
|
|
|
else
|
|
|
|
full_command="test_terminal "
|
|
|
|
fi
|
|
|
|
cmd=$1
|
|
|
|
full_command="$full_command $1"
|
|
|
|
}
|
|
|
|
|
2010-06-27 03:24:50 +08:00
|
|
|
test_default_pager() {
|
|
|
|
parse_args "$@"
|
|
|
|
|
|
|
|
$test_expectation SIMPLEPAGER "$cmd - default pager is used by default" "
|
|
|
|
unset PAGER GIT_PAGER;
|
|
|
|
test_might_fail git config --unset core.pager &&
|
|
|
|
rm -f default_pager_used ||
|
|
|
|
cleanup_fail &&
|
|
|
|
|
|
|
|
cat >\$less <<-\EOF &&
|
|
|
|
#!/bin/sh
|
|
|
|
wc >default_pager_used
|
|
|
|
EOF
|
|
|
|
chmod +x \$less &&
|
|
|
|
(
|
|
|
|
PATH=.:\$PATH &&
|
|
|
|
export PATH &&
|
|
|
|
$full_command
|
|
|
|
) &&
|
|
|
|
test -e default_pager_used
|
|
|
|
"
|
|
|
|
}
|
2010-04-15 08:38:07 +08:00
|
|
|
|
2010-06-27 03:24:50 +08:00
|
|
|
test_PAGER_overrides() {
|
|
|
|
parse_args "$@"
|
2010-02-19 15:18:58 +08:00
|
|
|
|
2010-06-27 03:24:50 +08:00
|
|
|
$test_expectation TTY "$cmd - PAGER overrides default pager" "
|
|
|
|
unset GIT_PAGER;
|
|
|
|
test_might_fail git config --unset core.pager &&
|
|
|
|
rm -f PAGER_used ||
|
|
|
|
cleanup_fail &&
|
2010-04-15 08:38:07 +08:00
|
|
|
|
2010-06-27 03:24:50 +08:00
|
|
|
PAGER='wc >PAGER_used' &&
|
|
|
|
export PAGER &&
|
|
|
|
$full_command &&
|
|
|
|
test -e PAGER_used
|
|
|
|
"
|
|
|
|
}
|
2010-04-15 08:38:07 +08:00
|
|
|
|
2010-06-27 03:24:50 +08:00
|
|
|
test_core_pager_overrides() {
|
|
|
|
parse_args "$@"
|
|
|
|
|
|
|
|
$test_expectation TTY "$cmd - core.pager overrides PAGER" "
|
|
|
|
unset GIT_PAGER;
|
|
|
|
rm -f core.pager_used ||
|
|
|
|
cleanup_fail &&
|
|
|
|
|
|
|
|
PAGER=wc &&
|
|
|
|
export PAGER &&
|
|
|
|
git config core.pager 'wc >core.pager_used' &&
|
|
|
|
$full_command &&
|
|
|
|
test -e core.pager_used
|
|
|
|
"
|
|
|
|
}
|
|
|
|
|
2010-06-27 03:25:37 +08:00
|
|
|
test_core_pager_subdir() {
|
|
|
|
parse_args "$@"
|
|
|
|
|
|
|
|
$test_expectation TTY "$cmd - core.pager from subdirectory" "
|
|
|
|
unset GIT_PAGER;
|
|
|
|
rm -f core.pager_used &&
|
|
|
|
rm -fr sub ||
|
|
|
|
cleanup_fail &&
|
|
|
|
|
|
|
|
PAGER=wc &&
|
|
|
|
stampname=\$(pwd)/core.pager_used &&
|
|
|
|
export PAGER stampname &&
|
|
|
|
git config core.pager 'wc >\"\$stampname\"' &&
|
|
|
|
mkdir sub &&
|
|
|
|
(
|
|
|
|
cd sub &&
|
|
|
|
$full_command
|
|
|
|
) &&
|
|
|
|
test -e core.pager_used
|
|
|
|
"
|
|
|
|
}
|
|
|
|
|
2010-06-27 03:24:50 +08:00
|
|
|
test_GIT_PAGER_overrides() {
|
|
|
|
parse_args "$@"
|
|
|
|
|
|
|
|
$test_expectation TTY "$cmd - GIT_PAGER overrides core.pager" "
|
|
|
|
rm -f GIT_PAGER_used ||
|
|
|
|
cleanup_fail &&
|
|
|
|
|
|
|
|
git config core.pager wc &&
|
|
|
|
GIT_PAGER='wc >GIT_PAGER_used' &&
|
|
|
|
export GIT_PAGER &&
|
|
|
|
$full_command &&
|
|
|
|
test -e GIT_PAGER_used
|
|
|
|
"
|
|
|
|
}
|
2010-04-15 08:38:07 +08:00
|
|
|
|
2010-06-27 03:24:50 +08:00
|
|
|
test_default_pager expect_success 'git log'
|
|
|
|
test_PAGER_overrides expect_success 'git log'
|
|
|
|
test_core_pager_overrides expect_success 'git log'
|
2010-06-27 03:25:37 +08:00
|
|
|
test_core_pager_subdir expect_success 'git log'
|
2010-06-27 03:24:50 +08:00
|
|
|
test_GIT_PAGER_overrides expect_success 'git log'
|
|
|
|
|
|
|
|
test_default_pager expect_success 'git -p log'
|
|
|
|
test_PAGER_overrides expect_success 'git -p log'
|
|
|
|
test_core_pager_overrides expect_success 'git -p log'
|
2010-06-27 03:25:37 +08:00
|
|
|
test_core_pager_subdir expect_failure 'git -p log'
|
2010-06-27 03:24:50 +08:00
|
|
|
test_GIT_PAGER_overrides expect_success 'git -p log'
|
|
|
|
|
|
|
|
test_default_pager expect_success test_must_fail 'git -p'
|
|
|
|
test_PAGER_overrides expect_success test_must_fail 'git -p'
|
|
|
|
test_core_pager_overrides expect_success test_must_fail 'git -p'
|
2010-06-27 03:25:37 +08:00
|
|
|
test_core_pager_subdir expect_failure test_must_fail 'git -p'
|
2010-06-27 03:24:50 +08:00
|
|
|
test_GIT_PAGER_overrides expect_success test_must_fail 'git -p'
|
|
|
|
|
|
|
|
test_default_pager expect_success test_must_fail 'git -p nonsense'
|
|
|
|
test_PAGER_overrides expect_success test_must_fail 'git -p nonsense'
|
|
|
|
test_core_pager_overrides expect_success test_must_fail 'git -p nonsense'
|
2010-06-27 03:25:37 +08:00
|
|
|
test_core_pager_subdir expect_failure test_must_fail 'git -p nonsense'
|
2010-06-27 03:24:50 +08:00
|
|
|
test_GIT_PAGER_overrides expect_success test_must_fail 'git -p nonsense'
|
2010-02-19 15:18:58 +08:00
|
|
|
|
|
|
|
test_done
|