X-Git-Url: http://git.vpit.fr/?a=blobdiff_plain;f=t%2F30-threads.t;h=73359c3da8c727c364c7eecd9f01b92eed6ce327;hb=a838a3bf0d49fcb56ea57da58771d2e2c77bfc26;hp=aa42d69f98c19ef1daa793b6fdfb3048a148956b;hpb=1a89808e0eb3e27e0d2b61d0bfa84fa8ab94b9cb;p=perl%2Fmodules%2FLexical-Types.git diff --git a/t/30-threads.t b/t/30-threads.t index aa42d69..73359c3 100644 --- a/t/30-threads.t +++ b/t/30-threads.t @@ -3,29 +3,13 @@ use strict; use warnings; -use Config qw/%Config/; +use lib 't/lib'; +use Lexical::Types::TestThreads; -BEGIN { - if (!$Config{useithreads}) { - require Test::More; - Test::More->import; - plan(skip_all => 'This perl wasn\'t built to support threads'); - } -} - -use threads; - -use Test::More; +use Test::More 'no_plan'; -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'; - } -} +my $threads = 10; +my $runs = 2; { package Lexical::Types::Test::Tag; @@ -49,7 +33,7 @@ use Lexical::Types as => 'Lexical::Types::Test::'; sub try { my $tid = threads->tid(); - for (1 .. 2) { + for (1 .. $runs) { my Tag $t; is $t, $tid, "typed lexical correctly initialized at run $_ in thread $tid"; @@ -63,7 +47,7 @@ EVALD SKIP: { skip 'Hints aren\'t propagated into eval STRING below perl 5.10' => 3 - unless $] >= 5.010; + unless "$]" >= 5.010; eval <<'EVALD'; my Tag $t3; is $t3, $tid, "typed lexical correctly initialized in eval (propagated) at run $_ in thread $tid" @@ -72,5 +56,8 @@ EVALD } } -my @t = map threads->create(\&try), 1 .. 10; +my @t = map spawn(\&try), 1 .. $threads; + $_->join for @t; + +pass 'done';