X-Git-Url: http://git.vpit.fr/?a=blobdiff_plain;f=t%2F30-threads.t;h=3f46124d0792b71fca8f3d3512ffe63fe125ba53;hb=b56734d8bae611bf89f0c65a084de7079d119d96;hp=c3db6c15c8c21fb94eab99524ea35ac6e6c0a1f4;hpb=29249d65c1e4c2712ad16c72543cf98d5905102e;p=perl%2Fmodules%2FLexical-Types.git diff --git a/t/30-threads.t b/t/30-threads.t index c3db6c1..3f46124 100644 --- a/t/30-threads.t +++ b/t/30-threads.t @@ -15,9 +15,17 @@ BEGIN { use threads; -use Test::More tests => 10 * 2 * 2 * (1 + 2); +use Test::More; -defined and diag "Using threads $_" for $threads::VERSION; +BEGIN { + require Lexical::Types; + if (Lexical::Types::LT_THREADSAFE()) { + plan tests => 10 * 2 * 3 * (1 + 2); + defined and diag "Using threads $_" for $threads::VERSION; + } else { + plan skip_all => 'This Lexical::Types isn\'t thread safe'; + } +} { package Lexical::Types::Test::Tag; @@ -50,6 +58,16 @@ sub try { is $t2, $tid, "typed lexical correctly initialized in eval at run $_ in thread $tid"; EVALD diag $@ if $@; + +SKIP: + { + skip 'Hints aren\'t propagated into eval STRING below perl 5.10' => 3 + unless $] >= 5.010; + eval <<'EVALD'; + my Tag $t3; + is $t3, $tid, "typed lexical correctly initialized in eval (propagated) at run $_ in thread $tid" +EVALD + } } }