]> git.vpit.fr Git - perl/modules/autovivification.git/blobdiff - t/50-threads.t
Update VPIT::TestHelpers to 2a6ac0f1
[perl/modules/autovivification.git] / t / 50-threads.t
index 99aa1ada3ca263c932c851f4cccf20f252ae47f8..63688758a9cdb8d203db028f83940ef3d47604d6 100644 (file)
@@ -1,31 +1,17 @@
-#!perl -T
+#!perl
 
 use strict;
 use warnings;
 
-use Config qw/%Config/;
+use lib 't/lib';
+use VPIT::TestHelpers (
+ threads => [ 'autovivification' => 'autovivification::A_THREADSAFE()' ],
+);
 
-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::Leaner;
 
-use Test::More;
-
-BEGIN {
- require autovivification;
- if (autovivification::A_THREADSAFE()) {
-  plan tests => 10 * 2 * 3 * (1 + 2);
-  defined and diag "Using threads $_" for $threads::VERSION;
- } else {
-  plan skip_all => 'This autovivification isn\'t thread safe';
- }
-}
+my $threads = 10;
+my $runs    = 2;
 
 {
  no autovivification;
@@ -33,7 +19,7 @@ BEGIN {
  sub try {
   my $tid = threads->tid();
 
-  for my $run (1 .. 2) {
+  for my $run (1 .. $runs) {
    {
     my $x;
     my $y = $x->{foo};
@@ -53,7 +39,7 @@ BEGIN {
 SKIP:
    {
     skip 'Hints aren\'t propagated into eval STRING below perl 5.10' => 3 * 2
-                                                             unless $] >= 5.010;
+                                                           unless "$]" >= 5.010;
     {
      my $x;
      eval 'my $y = $x->{foo}';
@@ -77,5 +63,10 @@ SKIP:
  }
 }
 
-my @t = map threads->create(\&try), 1 .. 10;
-$_->join for @t;
+my @threads = map spawn(\&try), 1 .. $threads;
+
+$_->join for @threads;
+
+pass 'done';
+
+done_testing(scalar(@threads) * $runs * 3 * (1 + 2) + 1);