X-Git-Url: http://git.vpit.fr/?a=blobdiff_plain;f=t%2F30-threads.t;h=d48fa023032c4b5607433e873c464a307d0e4961;hb=bf1b09f4ab8df1710df549764d511b110c6cb396;hp=32bdf8039ae3205f903d791496204cd65c05ad05;hpb=d6f87656b13ebd4ff7b217704daf892642c58b6a;p=perl%2Fmodules%2FLexical-Types.git diff --git a/t/30-threads.t b/t/30-threads.t index 32bdf80..d48fa02 100644 --- a/t/30-threads.t +++ b/t/30-threads.t @@ -3,27 +3,44 @@ use strict; use warnings; -use Config qw/%Config/; +sub skipall { + my ($msg) = @_; + require Test::More; + Test::More::plan(skip_all => $msg); +} + +use Config qw<%Config>; BEGIN { - if (!$Config{useithreads}) { - require Test::More; - Test::More->import; - plan(skip_all => 'This perl wasn\'t built to support threads'); - } + my $force = $ENV{PERL_LEXICAL_TYPES_TEST_THREADS} ? 1 : !1; + skipall 'This perl wasn\'t built to support threads' + unless $Config{useithreads}; + skipall 'perl 5.13.4 required to test thread safety' + unless $force or $] >= 5.013004; } use threads; -use Test::More tests => 10 * 2 * (1 + 2); +use Test::More; + +BEGIN { + require Lexical::Types; + skipall 'This Lexical::Types isn\'t thread safe' + unless Lexical::Types::LT_THREADSAFE(); + plan tests => 10 * 2 * 3 * (1 + 2); + defined and diag "Using threads $_" for $threads::VERSION; +} { package Lexical::Types::Test::Tag; sub TYPEDSCALAR { my $tid = threads->tid(); - Test::More::is($_[0], __PACKAGE__, "base type is correct in thread $tid"); - Test::More::is($_[2], 'Tag', "original type is correct in thread $tid"); + my ($file, $line) = (caller(0))[1, 2]; + my $where = "at $file line $line in thread $tid"; + local $Test::Builder::Level = $Test::Builder::Level + 1; + Test::More::is($_[0], __PACKAGE__, "base type is correct $where"); + Test::More::is($_[2], 'Tag', "original type is correct $where"); $_[1] = $tid; (); } @@ -34,10 +51,28 @@ use Test::More tests => 10 * 2 * (1 + 2); use Lexical::Types as => 'Lexical::Types::Test::'; sub try { + my $tid = threads->tid(); + for (1 .. 2) { my Tag $t; - my $tid = threads->tid(); is $t, $tid, "typed lexical correctly initialized at run $_ in thread $tid"; + + eval <<'EVALD'; + use Lexical::Types as => "Lexical::Types::Test::"; + my Tag $t2; + 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 + } } }