Skip to content

Commit 34b4808

Browse files
committed
Tests: optionally skip redirecting stdin/stdout/stderr
There is a really useful debugging technique developed by Sverre Rabbelier that inserts "bash &&" somewhere in the test scripts, letting the developer interact at given points with the current state. Another debugging technique, used a lot by this here coder, is to run certain executables via gdb by guarding a "gdb -args" call in bin-wrappers/git. Both techniques were disabled by 781f76b(test-lib: redirect stdin of tests). Let's reinstate the ability to run an interactive shell by making the redirection optional: setting the TEST_NO_REDIRECT environment variable will skip the redirection. Signed-off-by: Johannes Schindelin <[email protected]>
1 parent ae9f9f8 commit 34b4808

File tree

1 file changed

+14
-0
lines changed

1 file changed

+14
-0
lines changed

t/test-lib.sh

Lines changed: 14 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -555,6 +555,20 @@ test_eval_ () {
555555
#
556556
# The test itself is run with stderr put back to &4 (so either to
557557
# /dev/null, or to the original stderr if --verbose was used).
558+
if test -n "$TEST_NO_REDIRECT"
559+
then
560+
test_eval_inner_ "$@"
561+
test_eval_ret_=$?
562+
if test "$trace" = t
563+
then
564+
set +x
565+
if test "$test_eval_ret_" != 0
566+
then
567+
say_color error >&4 "error: last command exited with \$?=$test_eval_ret_"
568+
fi
569+
fi
570+
return $test_eval_ret_
571+
fi
558572
{
559573
test_eval_inner_ "$@" </dev/null >&3 2>&4
560574
test_eval_ret_=$?

0 commit comments

Comments
 (0)