Blame t/08-stdin-closed.t

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 Utils qw/save_std restore_std next_fd/;
Packit Service 44c065
use Cases qw/run_test/;
Packit Service 44c065
Packit Service 44c065
use Config;
Packit Service 44c065
my $no_fork = $^O ne 'MSWin32' && ! $Config{d_fork};
Packit Service 44c065
Packit Service 44c065
plan 'no_plan';
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
# XXX work around a bug in perl; this needs to be called early-ish
Packit Service 44c065
# to avoid some sort of filehandle leak when combined with Capture::Tiny
Packit Service 44c065
my $qm = quotemeta("\x{263a}");
Packit Service 44c065
Packit Service 44c065
save_std(qw/stdin/);
Packit Service 44c065
ok( close STDIN, "closed STDIN" );
Packit Service 44c065
Packit Service 44c065
my $fd = next_fd;
Packit Service 44c065
Packit Service 44c065
run_test($_) for qw(
Packit Service 44c065
  capture
Packit Service 44c065
  capture_scalar
Packit Service 44c065
  capture_stdout
Packit Service 44c065
  capture_stderr
Packit Service 44c065
  capture_merged
Packit Service 44c065
);
Packit Service 44c065
Packit Service 44c065
if ( ! $no_fork ) {
Packit Service 44c065
  # prior to 5.12, PERL_UNICODE=D causes problems when STDIN is closed
Packit Service 44c065
  # before capturing.  No idea why.  Documented as a known issue.
Packit Service 44c065
  if ( $] lt '5.012' && ${^UNICODE} & 24 ) {
Packit Service 44c065
    diag 'Skipping tee() tests because PERL_UNICODE=D not supported';
Packit Service 44c065
  }
Packit Service 44c065
  else {
Packit Service 44c065
    run_test($_) for qw(
Packit Service 44c065
      tee
Packit Service 44c065
      tee_scalar
Packit Service 44c065
      tee_stdout
Packit Service 44c065
      tee_stderr
Packit Service 44c065
      tee_merged
Packit Service 44c065
    );
Packit Service 44c065
  }
Packit Service 44c065
}
Packit Service 44c065
Packit Service 44c065
if ( $] lt '5.012' && ${^UNICODE} & 24 ) {
Packit Service 44c065
  diag 'Skipping leak test because PERL_UNICODE=D not supported';
Packit Service 44c065
}
Packit Service 44c065
else {
Packit Service 44c065
  is( next_fd, $fd, "no file descriptors leaked" );
Packit Service 44c065
}
Packit Service 44c065
Packit Service 44c065
restore_std(qw/stdin/);
Packit Service 44c065
Packit Service 44c065
exit 0;