2

我正在使用 TAP::Harness 运行我的测试,当我在 Linux 系统上从命令行运行测试时,我会在 STDOUT 运行时获得测试结果,但是当我尝试将输出捕获到文件以及使用 STDOUT 时perl 线束.pl | tee out.tap 结果被缓冲并仅在最后显示,我尝试将文件句柄传递给新的但结果在写入文件之前仍然被缓冲,有没有办法不缓冲输出,我有一个长时间运行的套件,并希望在测试运行时查看结果并捕获输出。

TAP::Harness 3.22 版和 perl 5.8.8 版

这是示例代码harness.pl

#!/usr/bin/perl
use strict;
use warnings;
use TAP::Harness;
$|++;

my @tests = ('del.t',);


my $harness = TAP::Harness->new( {
    verbosity => 1,
 } );
$harness->runtests(@tests);

和测试 del.t

use Test::More qw /no_plan/;
$|++;

my $count =1;
for (1 ..20 ) {
   ok ( $count ++ == $_, "Pass  $_");
   sleep 1 if ( $count % 5 == 0 ) ;
}
4

1 回答 1

5

使用script而不是tee做你想要的:

script -c 'perl harness.pl' file

找到了一个简单的更改来使 tee 也能正常工作:指定 a formatter_class

my $harness = TAP::Harness->new( {
    verbosity => 1,
    formatter_class => 'TAP::Formatter::Console',
 } );

这是因为TAP::Harness如果输出不是 tty,通常使用不同的默认值,这就是导致您看到的缓冲的原因。

于 2011-02-23T22:10:26.600 回答