X-Git-Url: http://git.vpit.fr/?p=perl%2Fmodules%2Findirect.git;a=blobdiff_plain;f=t%2F41-threads-teardown.t;fp=t%2F41-threads-teardown.t;h=d8a6fc92b916ae1ada2fde01d2112b69125fc9e4;hp=0000000000000000000000000000000000000000;hb=d237f88f7fb8be8d6836157872d5bf2b9ba02beb;hpb=175215d256b3ccb78ed48b5ad17c5e1d5ac3ba28 diff --git a/t/41-threads-teardown.t b/t/41-threads-teardown.t new file mode 100644 index 0000000..d8a6fc9 --- /dev/null +++ b/t/41-threads-teardown.t @@ -0,0 +1,59 @@ +#!perl + +use strict; +use warnings; + +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'); + } +} + +use threads; + +use Test::More; + +BEGIN { + delete $ENV{PERL_INDIRECT_PM_DISABLE}; + require indirect; + if (indirect::I_THREADSAFE()) { + plan tests => 1; + defined and diag "Using threads $_" for $threads::VERSION; + } else { + plan skip_all => 'This indirect isn\'t thread safe'; + } +} + +sub run_perl { + my $code = shift; + + local %ENV; + system { $^X } $^X, '-T', map("-I$_", @INC), '-e', $code; +} + +SKIP: +{ + skip 'Fails on 5.8.2 and lower' => 1 if $] <= 5.008002; + + my $status = run_perl <<' RUN'; + my ($code, @expected); + BEGIN { + $code = 2; + @expected = qw/X Z/; + } + sub cb { --$code if $_[0] eq shift(@expected) || q{DUMMY} } + use threads; + $code = threads->create(sub { + eval q{return; no indirect hook => \&cb; new X;}; + return $code; + })->join; + eval q{new Y;}; + eval q{return; no indirect hook => \&cb; new Z;}; + exit $code; + RUN + is $status, 0, 'loading the pragma in a thread and using it outside doesn\'t segfault'; +}