]> git.vpit.fr Git - perl/modules/indirect.git/commitdiff
Port threads tests to the new VPIT::TestHelpers interface
authorVincent Pit <vince@profvince.com>
Tue, 24 Mar 2015 15:13:15 +0000 (12:13 -0300)
committerVincent Pit <vince@profvince.com>
Tue, 24 Mar 2015 15:13:28 +0000 (12:13 -0300)
The new 'force threads test' environment variable is
PERL_FORCE_TEST_THREADS.

MANIFEST
t/40-threads.t
t/41-threads-teardown.t
t/42-threads-global.t
t/lib/indirect/TestThreads.pm [deleted file]

index f131bffbada7631ac7aa640de9c08e3f74f24629..c7765c19a1cb5b0919161467561d8b8ee5e1f9bc 100644 (file)
--- a/MANIFEST
+++ b/MANIFEST
@@ -50,4 +50,3 @@ t/lib/indirect/TestRequired5/c0.pm
 t/lib/indirect/TestRequired5/d0.pm
 t/lib/indirect/TestRequired6.pm
 t/lib/indirect/TestRequiredGlobal.pm
-t/lib/indirect/TestThreads.pm
index 3f2fe250dd9bd88e4253720d83096263c10513c4..41ce0a51494f8f10e53f97d510fd8f7ec031c4b2 100644 (file)
@@ -3,8 +3,12 @@
 use strict;
 use warnings;
 
+BEGIN { require indirect; }
+
 use lib 't/lib';
-use indirect::TestThreads;
+use VPIT::TestHelpers (
+ threads => [ 'indirect' => indirect::I_THREADSAFE ],
+);
 
 use Test::Leaner;
 
index 6c4814c0057da6a6987f3c16c2ff34c3f1ca4c8f..a4a005f6370a62bf9791dcf5bb2ed5ab131f34d9 100644 (file)
@@ -3,9 +3,12 @@
 use strict;
 use warnings;
 
+BEGIN { require indirect; }
+
 use lib 't/lib';
-use VPIT::TestHelpers;
-use indirect::TestThreads;
+use VPIT::TestHelpers (
+ threads => [ 'indirect' => indirect::I_THREADSAFE ],
+);
 
 use Test::Leaner tests => 3;
 
index c2c4d83f7e2906e58e511bb3a198b4eca2b98d2f..b3e0bff156d30e8ab673e59f568b6b57e23d50da 100644 (file)
@@ -3,8 +3,12 @@
 use strict;
 use warnings;
 
+BEGIN { require indirect; }
+
 use lib 't/lib';
-use indirect::TestThreads;
+use VPIT::TestHelpers (
+ threads => [ 'indirect' => indirect::I_THREADSAFE ],
+);
 
 use Test::Leaner;
 
diff --git a/t/lib/indirect/TestThreads.pm b/t/lib/indirect/TestThreads.pm
deleted file mode 100644 (file)
index 1b6c6da..0000000
+++ /dev/null
@@ -1,51 +0,0 @@
-package indirect::TestThreads;
-
-use strict;
-use warnings;
-
-use Config qw<%Config>;
-
-use VPIT::TestHelpers;
-
-sub import {
- shift;
-
- require indirect;
-
- skip_all 'This indirect isn\'t thread safe' unless indirect::I_THREADSAFE();
-
- my $force = $ENV{PERL_INDIRECT_TEST_THREADS} ? 1 : !1;
- skip_all 'This perl wasn\'t built to support threads'
-                                                    unless $Config{useithreads};
- skip_all 'perl 5.13.4 required to test thread safety'
-                                             unless $force or "$]" >= 5.013_004;
-
- load_or_skip_all('threads', $force ? '0' : '1.67', [ ]);
-
- my %exports = (
-  spawn => \&spawn,
- );
-
- my $pkg = caller;
- while (my ($name, $code) = each %exports) {
-  no strict 'refs';
-  *{$pkg.'::'.$name} = $code;
- }
-}
-
-sub spawn {
- local $@;
- my @diag;
- my $thread = eval {
-  local $SIG{__WARN__} = sub { push @diag, "Thread creation warning: @_" };
-  threads->create(@_);
- };
- push @diag, "Thread creation error: $@" if $@;
- if (@diag) {
-  require Test::Leaner;
-  Test::Leaner::diag($_) for @diag;
- }
- return $thread ? $thread : ();
-}
-
-1;