BEGIN {
chdir 't' if -d 't';
- @INC = '../lib';
+ @INC = ('../lib', 'lib');
$INC{"feature.pm"} = 1; # so we don't attempt to load feature.pm
}
-print "1..63\n";
+print "1..73\n";
# Can't require test.pl, as we're testing the use/require mechanism here.
} else {
print "not ok $test\n";
}
- my @caller = caller(2);
+ my @caller = caller(1);
print "# Failed test at $caller[1] line $caller[2]\n";
print "# Got '$got'\n";
if ($type eq 'is') {
_ok ('isnt', @_);
}
+eval "use 5"; # implicit semicolon
+is ($@, '');
+
+eval "use 5;";
+is ($@, '');
+
+eval "{use 5}"; # [perl #70884]
+is ($@, '');
+
+eval "{use 5 }"; # [perl #70884]
+is ($@, '');
+
+# new style version numbers
+
+eval q{ use v5.5.630; };
+is ($@, '');
+
+eval q{ use 10.0.2; };
+like ($@, qr/^Perl v10\.0\.2 required/);
+
eval "use 5.000"; # implicit semicolon
is ($@, '');
eval "use 5.10;";
like ($@, qr/Perl v5\.100\.0 required \(did you mean v5\.10\.0\?\)--this is only \Q$^V\E, stopped/);
+eval "use 5.11;";
+like ($@, qr/Perl v5\.110\.0 required \(did you mean v5\.11\.0\?\)--this is only \Q$^V\E, stopped/);
+
eval sprintf "use %.6f;", $];
is ($@, '');
eval sprintf "use %.6f;", $] + 0.00001;
like ($@, qr/Perl v5.\d+.\d+ required--this is only \Q$^V\E, stopped/);
-{ use lib } # check that subparse saves pending tokens
+# check that "use 5.11.0" (and higher) loads strictures
+eval 'use 5.11.0; ${"foo"} = "bar";';
+like ($@, qr/Can't use string \("foo"\) as a SCALAR ref while "strict refs" in use/);
+# but that they can be disabled
+eval 'use 5.11.0; no strict "refs"; ${"foo"} = "bar";';
+is ($@, "");
+# and they are properly scoped
+eval '{use 5.11.0;} ${"foo"} = "bar";';
+is ($@, "");
-local $lib::VERSION = 1.0;
+{ use test_use } # check that subparse saves pending tokens
-eval "use lib 0.9";
+local $test_use::VERSION = 1.0;
+
+eval "use test_use 0.9";
is ($@, '');
-eval "use lib 1.0";
+eval "use test_use 1.0";
is ($@, '');
-eval "use lib 1.01";
+eval "use test_use 1.01";
isnt ($@, '');
-
-eval "use lib 0.9 qw(fred)";
+eval "use test_use 0.9 qw(fred)";
is ($@, '');
-if ($^O eq 'MacOS') {
- is($INC[0], ":fred:");
-} else {
- is($INC[0], "fred");
-}
+is("@test_use::got", "fred");
-eval "use lib 1.0 qw(joe)";
+eval "use test_use 1.0 qw(joe)";
is ($@, '');
+is("@test_use::got", "joe");
-if ($^O eq 'MacOS') {
- is($INC[0], ":joe:");
-} else {
- is($INC[0], "joe");
-}
-
-
-eval "use lib 1.01 qw(freda)";
+eval "use test_use 1.01 qw(freda)";
isnt($@, '');
-if ($^O eq 'MacOS') {
- isnt($INC[0], ":freda:");
-} else {
- isnt($INC[0], "freda");
-}
+is("@test_use::got", "joe");
{
- local $lib::VERSION = 35.36;
- eval "use lib v33.55";
+ local $test_use::VERSION = 35.36;
+ eval "use test_use v33.55";
is ($@, '');
- eval "use lib v100.105";
- like ($@, qr/lib version v100.105.0 required--this is only version v35\.360\.0/);
+ eval "use test_use v100.105";
+ like ($@, qr/test_use version v100.105.0 required--this is only version v35\.360\.0/);
- eval "use lib 33.55";
+ eval "use test_use 33.55";
is ($@, '');
- eval "use lib 100.105";
- like ($@, qr/lib version 100.105 required--this is only version 35.36/);
+ eval "use test_use 100.105";
+ like ($@, qr/test_use version 100.105 required--this is only version 35.36/);
- local $lib::VERSION = '35.36';
- eval "use lib v33.55";
+ local $test_use::VERSION = '35.36';
+ eval "use test_use v33.55";
like ($@, '');
- eval "use lib v100.105";
- like ($@, qr/lib version v100.105.0 required--this is only version v35\.360\.0/);
+ eval "use test_use v100.105";
+ like ($@, qr/test_use version v100.105.0 required--this is only version v35\.360\.0/);
- eval "use lib 33.55";
+ eval "use test_use 33.55";
is ($@, '');
- eval "use lib 100.105";
- like ($@, qr/lib version 100.105 required--this is only version 35.36/);
+ eval "use test_use 100.105";
+ like ($@, qr/test_use version 100.105 required--this is only version 35.36/);
- local $lib::VERSION = v35.36;
- eval "use lib v33.55";
+ local $test_use::VERSION = v35.36;
+ eval "use test_use v33.55";
is ($@, '');
- eval "use lib v100.105";
- like ($@, qr/lib version v100.105.0 required--this is only version v35\.36\.0/);
+ eval "use test_use v100.105";
+ like ($@, qr/test_use version v100.105.0 required--this is only version v35\.36\.0/);
- eval "use lib 33.55";
+ eval "use test_use 33.55";
is ($@, '');
- eval "use lib 100.105";
- like ($@, qr/lib version 100.105 required--this is only version v35.36/);
+ eval "use test_use 100.105";
+ like ($@, qr/test_use version 100.105 required--this is only version v35.36/);
}
{
# Regression test for patch 14937:
# Check that a .pm file with no package or VERSION doesn't core.
- open F, ">xxx$$.pm" or die "Cannot open xxx$$.pm: $!\n";
- print F "1;\n";
- close F;
- eval "use lib '.'; use xxx$$ 3;";
- like ($@, qr/^xxx$$ defines neither package nor VERSION--version check failed at/);
- unlink "xxx$$.pm";
+ # (git commit 2658f4d9934aba5f8b23afcc078dc12b3a40223)
+ eval "use test_use_14937 3";
+ like ($@, qr/^test_use_14937 defines neither package nor VERSION--version check failed at/);
}
my @ver = split /\./, sprintf "%vd", $^V;