summaryrefslogtreecommitdiff
path: root/dist/Thread-Semaphore/t/06_timed.t
diff options
context:
space:
mode:
Diffstat (limited to 'dist/Thread-Semaphore/t/06_timed.t')
-rw-r--r--dist/Thread-Semaphore/t/06_timed.t76
1 files changed, 76 insertions, 0 deletions
diff --git a/dist/Thread-Semaphore/t/06_timed.t b/dist/Thread-Semaphore/t/06_timed.t
new file mode 100644
index 0000000000..11f675981f
--- /dev/null
+++ b/dist/Thread-Semaphore/t/06_timed.t
@@ -0,0 +1,76 @@
+use strict;
+use warnings;
+
+BEGIN {
+ use Config;
+ if (! $Config{'useithreads'}) {
+ print("1..0 # SKIP Perl not compiled with 'useithreads'\n");
+ exit(0);
+ }
+}
+
+use threads;
+use threads::shared;
+use Thread::Semaphore;
+
+if ($] == 5.008) {
+ require 't/test.pl'; # Test::More work-alike for Perl 5.8.0
+} else {
+ require Test::More;
+}
+Test::More->import();
+plan('tests' => 10);
+
+### Basic usage with multiple threads ###
+
+my $sm = Thread::Semaphore->new();
+my $st = Thread::Semaphore->new(0);
+ok($sm, 'New Semaphore');
+ok($st, 'New Semaphore');
+
+my $token :shared = 0;
+
+my @threads;
+
+push @threads, threads->create(sub {
+ $st->down_timed(3);
+ is($token++, 1, 'Thread 1 got semaphore');
+ $sm->up();
+
+ $st->down_timed(3, 4);
+ is($token, 5, 'Thread 1 done');
+ $sm->up();
+});
+
+push @threads, threads->create(sub {
+ $st->down_timed(3, 2);
+ is($token++, 3, 'Thread 2 got semaphore');
+ $sm->up();
+
+ # Force timeout by asking for more than will ever show up
+ ok(! $st->down_timed(1, 10), 'Thread 2 timed out');
+ $sm->up();
+});
+
+$sm->down();
+is($token++, 0, 'Main has semaphore');
+$st->up();
+
+$sm->down();
+is($token++, 2, 'Main got semaphore');
+$st->up(2);
+
+$sm->down();
+is($token++, 4, 'Main re-got semaphore');
+$st->up(5);
+
+$sm->down(2);
+$st->down();
+
+$_->join for @threads;
+
+ok(1, 'Main done');
+
+exit(0);
+
+# EOF