#!/usr/bin/perl -w
use strict;
use warnings;
use autodie::hints;
use FindBin;
use lib "$FindBin::Bin/lib";
use File::Copy qw(copy move cp mv);
use Test::More 'no_plan';
use constant NO_SUCH_FILE => "this_file_had_better_not_exist";
use constant NO_SUCH_FILE2 => "this_file_had_better_not_exist_xyzzy";
use constant PERL510 => ( $] >= 5.0100 );
use constant PERL5101 => ( $] >= 5.0101 );
use constant PERL5102 => ( $] >= 5.0102 );
# File::Copy states that all subroutines return '0' on failure.
# However both Windows and VMS may return other false values
# (notably empty-string) on failure. This constant indicates
# whether we should skip some tests because the return values
# from File::Copy may not be what's in the documentation.
use constant WEIRDO_FILE_COPY =>
( ! PERL5102 and ( $^O eq "MSWin32" or $^O eq "VMS" ));
use Hints_test qw(
fail_on_empty fail_on_false fail_on_undef
);
use autodie qw(fail_on_empty fail_on_false fail_on_undef);
diag("Sub::Identify ", exists( $INC{'Sub/Identify.pm'} ) ? "is" : "is not",
" loaded") if (! $ENV{PERL_CORE});
my $hints = "autodie::hints";
# Basic hinting tests
is( $hints->sub_fullname(\©), 'File::Copy::copy' , "Id: copy" );
is(
$hints->sub_fullname(\&cp),
PERL5101 ? 'File::Copy::cp' : 'File::Copy::copy' , "Id: cp"
);
is( $hints->sub_fullname(\&move), 'File::Copy::move' , "Id: move" );
is( $hints->sub_fullname(\&mv),
PERL5101 ? 'File::Copy::mv' : 'File::Copy::move' , "Id: mv"
);
if (PERL510) {
ok( $hints->get_hints_for(\©)->{scalar}->(0) ,
"copy() hints should fail on 0 for scalars."
);
ok( $hints->get_hints_for(\©)->{list}->(0) ,
"copy() hints should fail on 0 for lists."
);
}
# Scalar context test
eval {
use autodie qw(copy);
my $scalar_context = copy(NO_SUCH_FILE, NO_SUCH_FILE2);
};
isnt("$@", "", "Copying in scalar context should throw an error.");
isa_ok($@, "autodie::exception");
is($@->function, "File::Copy::copy", "Function should be original name");
SKIP: {
skip("File::Copy is weird on Win32/VMS before 5.10.1", 1)
if WEIRDO_FILE_COPY;
is($@->return, 0, "File::Copy returns zero on failure");
}
is($@->context, "scalar", "File::Copy called in scalar context");
# List context test.
eval {
use autodie qw(copy);
my @list_context = copy(NO_SUCH_FILE, NO_SUCH_FILE2);
};
isnt("$@", "", "Copying in list context should throw an error.");
isa_ok($@, "autodie::exception");
is($@->function, "File::Copy::copy", "Function should be original name");
SKIP: {
skip("File::Copy is weird on Win32/VMS before 5.10.1", 1)
if WEIRDO_FILE_COPY;
is_deeply($@->return, [0], "File::Copy returns zero on failure");
}
is($@->context, "list", "File::Copy called in list context");
# Tests on loaded funcs.
my %tests = (
# Test code # Exception expected?
'fail_on_empty()' => 1,
'fail_on_empty(0)' => 0,
'fail_on_empty(undef)' => 0,
'fail_on_empty(1)' => 0,
'fail_on_false()' => 1,
'fail_on_false(0)' => 1,
'fail_on_false(undef)' => 1,
'fail_on_false(1)' => 0,
'fail_on_undef()' => 1,
'fail_on_undef(0)' => 0,
'fail_on_undef(undef)' => 1,
'fail_on_undef(1)' => 0,
);
# On Perl 5.8, autodie doesn't correctly propagate into string evals.
# The following snippet forces the use of autodie inside the eval if
# we really really have to. For 5.10+, we don't want to include this
# fix, because the tests will act as a canary if we screw up string
# eval propagation.
my $perl58_fix = (
$] >= 5.010 ?
"" :
"use autodie qw(fail_on_empty fail_on_false fail_on_undef); "
);
while (my ($test, $exception_expected) = each %tests) {
eval "
$perl58_fix
my \@array = $test;
";
if ($exception_expected) {
isnt("$@", "", $test);
}
else {
is($@, "", $test);
}
}
1;