]> git.vpit.fr Git - perl/modules/Lexical-Types.git/blobdiff - t/30-threads.t
Correct failing tests locations
[perl/modules/Lexical-Types.git] / t / 30-threads.t
index 5c4b8d1710a3f587a552b6f3e1d8dfa404bf3edc..aa42d69f98c19ef1daa793b6fdfb3048a148956b 100644 (file)
@@ -15,7 +15,17 @@ BEGIN {
 
 use threads;
 
-use Test::More tests => 10 * 2 * 2 * (1 + 2);
+use Test::More;
+
+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';
+ }
+}
 
 {
  package Lexical::Types::Test::Tag;
@@ -24,6 +34,7 @@ use Test::More tests => 10 * 2 * 2 * (1 + 2);
   my $tid = threads->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;
@@ -48,6 +59,16 @@ sub try {
    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
+  }
  }
 }