|
Packit Service |
44c065 |
# Copyright (c) 2009 by David Golden. All rights reserved.
|
|
Packit Service |
44c065 |
# Licensed under Apache License, Version 2.0 (the "License").
|
|
Packit Service |
44c065 |
# You may not use this file except in compliance with the License.
|
|
Packit Service |
44c065 |
# A copy of the License was distributed with this file or you may obtain a
|
|
Packit Service |
44c065 |
# copy of the License from http://www.apache.org/licenses/LICENSE-2.0
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
use strict;
|
|
Packit Service |
44c065 |
use warnings;
|
|
Packit Service |
44c065 |
use Test::More;
|
|
Packit Service |
44c065 |
use lib 't/lib';
|
|
Packit Service |
44c065 |
use IO::Handle;
|
|
Packit Service |
44c065 |
use IO::File;
|
|
Packit Service |
44c065 |
use File::Temp qw/tmpnam/;
|
|
Packit Service |
44c065 |
use Utils qw/next_fd sig_num/;
|
|
Packit Service |
44c065 |
use Capture::Tiny ':all';
|
|
Packit Service |
44c065 |
use Config;
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
plan tests => 19;
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
local $ENV{PERL_CAPTURE_TINY_TIMEOUT} = 0; # no timeouts
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
my $builder = Test::More->builder;
|
|
Packit Service |
44c065 |
binmode($builder->failure_output, ':utf8') if $] >= 5.008;
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
my $fd = next_fd;
|
|
Packit Service |
44c065 |
my ($out, $err, $res, @res);
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
#--------------------------------------------------------------------------#
|
|
Packit Service |
44c065 |
# capture to custom IO::File
|
|
Packit Service |
44c065 |
#--------------------------------------------------------------------------#
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
my $temp_out = tmpnam();
|
|
Packit Service |
44c065 |
my $temp_err = tmpnam();
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
ok( !-e $temp_out, "Temp out '$temp_out' doesn't exist" );
|
|
Packit Service |
44c065 |
ok( !-e $temp_err, "Temp out '$temp_err' doesn't exist" );
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
my $out_fh = IO::File->new($temp_out, "w+");
|
|
Packit Service |
44c065 |
my $err_fh = IO::File->new($temp_err, "w+");
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
capture {
|
|
Packit Service |
44c065 |
print STDOUT "foo\n";
|
|
Packit Service |
44c065 |
print STDERR "bar\n";
|
|
Packit Service |
44c065 |
} stdout => $out_fh, stderr => $err_fh;
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
$out_fh->close;
|
|
Packit Service |
44c065 |
$err_fh->close;
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
is( scalar do {local (@ARGV,$/) = $temp_out; <>} , "foo\n",
|
|
Packit Service |
44c065 |
"captured STDOUT to custom handle (IO::File)"
|
|
Packit Service |
44c065 |
);
|
|
Packit Service |
44c065 |
is( scalar do {local (@ARGV,$/) = $temp_err; <>} , "bar\n",
|
|
Packit Service |
44c065 |
"captured STDERR to custom handle (IO::File)"
|
|
Packit Service |
44c065 |
);
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
unlink $_ for $temp_out, $temp_err;
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
#--------------------------------------------------------------------------#
|
|
Packit Service |
44c065 |
# capture to GLOB handle
|
|
Packit Service |
44c065 |
#--------------------------------------------------------------------------#
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
$temp_out = tmpnam();
|
|
Packit Service |
44c065 |
$temp_err = tmpnam();
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
ok( !-e $temp_out, "Temp out '$temp_out' doesn't exist" );
|
|
Packit Service |
44c065 |
ok( !-e $temp_err, "Temp out '$temp_err' doesn't exist" );
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
open $out_fh, "+>", $temp_out;
|
|
Packit Service |
44c065 |
open $err_fh, "+>", $temp_err;
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
capture {
|
|
Packit Service |
44c065 |
print STDOUT "foo\n";
|
|
Packit Service |
44c065 |
print STDERR "bar\n";
|
|
Packit Service |
44c065 |
} stdout => $out_fh, stderr => $err_fh;
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
$out_fh->close;
|
|
Packit Service |
44c065 |
$err_fh->close;
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
is( scalar do {local (@ARGV,$/) = $temp_out; <>} , "foo\n",
|
|
Packit Service |
44c065 |
"captured STDOUT to custom handle (GLOB)"
|
|
Packit Service |
44c065 |
);
|
|
Packit Service |
44c065 |
is( scalar do {local (@ARGV,$/) = $temp_err; <>} , "bar\n",
|
|
Packit Service |
44c065 |
"captured STDERR to custom handle (GLOB)"
|
|
Packit Service |
44c065 |
);
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
unlink $_ for $temp_out, $temp_err;
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
#--------------------------------------------------------------------------#
|
|
Packit Service |
44c065 |
# append to custom IO::File
|
|
Packit Service |
44c065 |
#--------------------------------------------------------------------------#
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
$temp_out = tmpnam();
|
|
Packit Service |
44c065 |
$temp_err = tmpnam();
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
ok( !-e $temp_out, "Temp out '$temp_out' doesn't exist" );
|
|
Packit Service |
44c065 |
ok( !-e $temp_err, "Temp out '$temp_err' doesn't exist" );
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
$out_fh = IO::File->new($temp_out, "w+");
|
|
Packit Service |
44c065 |
$err_fh = IO::File->new($temp_err, "w+");
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
$out_fh->autoflush(1);
|
|
Packit Service |
44c065 |
$err_fh->autoflush(1);
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
print $out_fh "Shouldn't see this in capture\n";
|
|
Packit Service |
44c065 |
print $err_fh "Shouldn't see this in capture\n";
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
my ($got_out, $got_err) = capture {
|
|
Packit Service |
44c065 |
print STDOUT "foo\n";
|
|
Packit Service |
44c065 |
print STDERR "bar\n";
|
|
Packit Service |
44c065 |
} stdout => $out_fh, stderr => $err_fh;
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
$out_fh->close;
|
|
Packit Service |
44c065 |
$err_fh->close;
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
is( $got_out, "foo\n",
|
|
Packit Service |
44c065 |
"captured appended STDOUT to custom handle"
|
|
Packit Service |
44c065 |
);
|
|
Packit Service |
44c065 |
is( $got_err, "bar\n",
|
|
Packit Service |
44c065 |
"captured appended STDERR to custom handle"
|
|
Packit Service |
44c065 |
);
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
unlink $_ for $temp_out, $temp_err;
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
#--------------------------------------------------------------------------#
|
|
Packit Service |
44c065 |
# repeated append to custom IO::File with no output
|
|
Packit Service |
44c065 |
#--------------------------------------------------------------------------#
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
$temp_out = tmpnam();
|
|
Packit Service |
44c065 |
$temp_err = tmpnam();
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
ok( !-e $temp_out, "Temp out '$temp_out' doesn't exist" );
|
|
Packit Service |
44c065 |
ok( !-e $temp_err, "Temp out '$temp_err' doesn't exist" );
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
$out_fh = IO::File->new($temp_out, "a+");
|
|
Packit Service |
44c065 |
$err_fh = IO::File->new($temp_err, "a+");
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
($got_out, $got_err) = capture {
|
|
Packit Service |
44c065 |
my $i = 0; $i++ for 1 .. 10; # no output, just busywork
|
|
Packit Service |
44c065 |
} stdout => $out_fh, stderr => $err_fh;
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
is( $got_out, "",
|
|
Packit Service |
44c065 |
"Try 1: captured empty appended STDOUT to custom handle"
|
|
Packit Service |
44c065 |
);
|
|
Packit Service |
44c065 |
is( $got_err, "",
|
|
Packit Service |
44c065 |
"Try 1: captured empty appended STDERR to custom handle"
|
|
Packit Service |
44c065 |
);
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
($got_out, $got_err) = capture {
|
|
Packit Service |
44c065 |
my $i = 0; $i++ for 1 .. 10; # no output, just busywork
|
|
Packit Service |
44c065 |
} stdout => $out_fh, stderr => $err_fh;
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
is( $got_out, "",
|
|
Packit Service |
44c065 |
"Try 2: captured empty appended STDOUT to custom handle"
|
|
Packit Service |
44c065 |
);
|
|
Packit Service |
44c065 |
is( $got_err, "",
|
|
Packit Service |
44c065 |
"Try 2: captured empty appended STDERR to custom handle"
|
|
Packit Service |
44c065 |
);
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
unlink $_ for $temp_out, $temp_err;
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
#--------------------------------------------------------------------------#
|
|
Packit Service |
44c065 |
# finish
|
|
Packit Service |
44c065 |
#--------------------------------------------------------------------------#
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
close ARGV; # opened by reading from <>
|
|
Packit Service |
44c065 |
is( next_fd, $fd, "no file descriptors leaked" );
|
|
Packit Service |
44c065 |
|
|
Packit Service |
44c065 |
exit 0;
|
|
Packit Service |
44c065 |
|