我正在使用TAP::Harness运行测试,当我在Linux系统上从命令行运行测试时,我在运行时在STDOUT上获得了测试结果,但是当我尝试使用以下命令将输出捕获到文件以及STDOUT时: perl线束| tee out.tap,结果仅在最后缓冲并显示,我尝试将文件句柄传递给新的,但是结果在写入文件之前仍被缓冲,有没有办法不缓冲输出,我有一个长期运行的套件,希望在测试运行时查看结果以及捕获输出。
TAP::Harness 3.22版和perl 5.8.8版
这是示例代码
线束
#!/usr/bin/perl
use strict;
use warnings;
use TAP::Harness;
$|++;
my @tests = ('del.t',);
my $harness = TAP::Harness->new( {
verbosity => 1,
} );
$harness->runtests(@tests);
和测试delt
use Test::More qw /no_plan/;
$|++;
my $count =1;
for (1 ..20 ) {
ok ( $count ++ == $_, "Pass $_");
sleep 1 if ( $count % 5 == 0 ) ;
}
最佳答案
使用script
而不是tee
可以满足您的要求:
script -c 'perl harness.pl' file
找到一个简单的更改以使tee也能正常工作:指定一个
formatter_class
:my $harness = TAP::Harness->new( {
verbosity => 1,
formatter_class => 'TAP::Formatter::Console',
} );
这是因为如果输出不是tty,则
TAP::Harness
通常使用不同的默认值,这就是导致您看到缓冲的原因。