X-Git-Url: http://git.vpit.fr/?a=blobdiff_plain;f=t%2F18-opinfo.t;h=6cf87680ad31fe2912f988e0936b3e2d4b79afd5;hb=bdc2a15aa5ca3f57b45d2c6e560f110c91b2ae87;hp=a67021e47286fbf1ae7b9ebb42f00b771b755420;hpb=90ca07f2bcc731f8a3118fecdfffbd8975686eaa;p=perl%2Fmodules%2FVariable-Magic.git diff --git a/t/18-opinfo.t b/t/18-opinfo.t index a67021e..6cf8768 100644 --- a/t/18-opinfo.t +++ b/t/18-opinfo.t @@ -3,7 +3,7 @@ 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/; @@ -11,8 +11,12 @@ use Variable::Magic qw/wizard cast dispell VMG_OP_INFO_NAME VMG_OP_INFO_OBJECT/; 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.008003 ? '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 +106,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'; +}