File: 32tickit-timer.t

package info (click to toggle)
libtickit-perl 0.73-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, forky, sid, trixie
  • size: 660 kB
  • sloc: perl: 4,944; makefile: 5
file content (71 lines) | stat: -rw-r--r-- 1,425 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
#!/usr/bin/perl

use v5.14;
use warnings;

use Test::More;

use Time::HiRes qw( time );

use Tickit;

pipe my( $term_rd, $my_wr ) or die "Cannot pipepair - $!";
pipe my( $my_rd, $term_wr ) or die "Cannot pipepair - $!";

my $tickit = Tickit->new(
   term_in  => $term_rd,
   term_out => $term_wr,
);

# timer after
{
   my $now = time;

   my $called;
   $tickit->watch_timer_after( 0.1, sub { $called++ } );

   # because poll and gettimeofday aren't synchronised, this may not work the first time
   while( !$called ) {
      die "Test timed out" if time > $now + 2;
      $tickit->tick;
   }

   ok( $called, '->watch_timer_after invokes code block' );
}

# timer at
{
   my $now = time;

   my $called;
   $tickit->watch_timer_at( $now + 0.1, sub { $called++ } );

   # because poll and gettimeofday aren't synchronised, this may not work the first time
   while( !$called ) {
      die "Test timed out" if time > $now + 2;
      $tickit->tick;
   }

   ok( $called, '->watch_timer_at invokes code block' );
}

# watch_cancel
{
   my $now = time;

   my $done;
   $tickit->watch_timer_at(  $now + 0.2, sub { $done++ } );

   my $called;
   my $id = $tickit->watch_timer_at( $now + 0.1, sub { $called++ } );
   $tickit->watch_cancel( $id );

   while( !$done ) {
      die "Test timed out" if time > $now + 2;
      $tickit->tick;
   }

   ok( !$called, '->watch_cancel stops code block being invoked' );
}

done_testing;