X-Git-Url: http://git.vpit.fr/?a=blobdiff_plain;f=t%2F60-uplevel-target.t;h=87444ba701299b695bd5c26f26096a04ccf5eafb;hb=44b173f9220cfdd1afd01ae4baf414f885d2f0b2;hp=c605299bcf8d1efadecc3f2814b20640cdbd4bd3;hpb=8afcc751a1eb6d635f6a1a015711ecc674072a38;p=perl%2Fmodules%2FScope-Upper.git diff --git a/t/60-uplevel-target.t b/t/60-uplevel-target.t index c605299..87444ba 100644 --- a/t/60-uplevel-target.t +++ b/t/60-uplevel-target.t @@ -3,7 +3,8 @@ use strict; use warnings; -use Test::More tests => (1 * 3 + 2 * 4 + 3 * 5) * 2 + 7 + 5 + 6 + 5 + 6 + 5; +use Test::More + tests => (1 * 3 + 2 * 4 + 3 * 5) * 2 + 7 + 7 + (5 + 6 + 5 + 6 + 5); use Scope::Upper qw; @@ -120,6 +121,39 @@ sub four { like $@, qr/^Can't uplevel to an eval frame/, "$desc: dies"; } +# XS + +{ + my $desc = 'uplevel to XS 1'; + local $@; + eval { + sub { + my $cxt = HERE; + pass "$desc: before"; + &uplevel(\&HERE => $cxt); + is HERE, $cxt, "$desc: after"; + }->(); + }; + is $@, '', "$desc: no error"; +} + +{ + my $desc = 'uplevel to XS 1'; + local $@; + eval { + sub { + my $up = HERE; + sub { + is UP, $up, "$desc: before"; + &uplevel(\&HERE => $up); + isnt HERE, $up, "$desc: after 1"; + }->(); + is HERE, $up, "$desc: after 2"; + }->(); + }; + is $@, '', "$desc: no error"; +} + # Target destruction {