X-Git-Url: http://git.vpit.fr/?a=blobdiff_plain;f=t%2F18-opinfo.t;h=70b5f746dfd731f8e9418e1202e6f3aebff73b2d;hb=9ad970e109ea4caa9767db1bda9d475444920c7a;hp=a67021e47286fbf1ae7b9ebb42f00b771b755420;hpb=90ca07f2bcc731f8a3118fecdfffbd8975686eaa;p=perl%2Fmodules%2FVariable-Magic.git diff --git a/t/18-opinfo.t b/t/18-opinfo.t index a67021e..70b5f74 100644 --- a/t/18-opinfo.t +++ b/t/18-opinfo.t @@ -3,16 +3,21 @@ use strict; use warnings; -use Test::More tests => 17 * (3 + 4) + 5; +use Test::More tests => 17 * (3 + 4) + 5 + 1; -use Config qw/%Config/; +use Config qw<%Config>; -use Variable::Magic qw/wizard cast dispell VMG_OP_INFO_NAME VMG_OP_INFO_OBJECT/; +use Variable::Magic qw; sub Variable::Magic::TestPkg::foo { } -my $aelem = $] <= 5.008003 ? 'aelem' : $] < 5.013 ? 'aelemfast' : 'sassign'; -my $aelemf = $] < 5.013 ? 'aelemfast' : 'sassign'; +my $is_5130_release = ("$]" == 5.013 && !$Config{git_describe}) ? 1 : 0; + +my $aelem = "$]" <= 5.008_003 ? 'aelem' + : ("$]" < 5.013 or $is_5130_release) + ? 'aelemfast' + : 'sassign'; +my $aelemf = ("$]" < 5.013 or $is_5130_release) ? 'aelemfast' : 'sassign'; my $aelemf_op = $aelemf eq 'sassign' ? 'B::BINOP' : $Config{useithreads} ? 'B::PADOP' : 'B::SVOP'; @@ -102,3 +107,13 @@ for (@tests) { eval { dispell $c, $wiz }; is $@, '', "get dispell with out of bounds op_info doesn't croak"; } + +{ + local $@; + my $wiz = eval { + local $SIG{__WARN__} = sub { die @_ }; + wizard op_info => "hlagh"; + }; + like $@, qr/^Argument "hlagh" isn't numeric in subroutine entry at \Q$0\E/, + 'wizard(op_info => "text") throws numeric warnings'; +}