File: fileevent2.t

package info (click to toggle)
perl-tk 1%3A804.036%2Bdfsg1-5
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 35,284 kB
  • sloc: ansic: 349,560; perl: 52,292; sh: 12,678; makefile: 5,700; asm: 3,565; ada: 1,681; pascal: 1,082; cpp: 1,006; yacc: 883; cs: 879
file content (54 lines) | stat: -rwxr-xr-x 994 bytes parent folder | download | duplicates (5)
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
#!/usr/bin/perl -w
# -*- perl -*-

#
# $Id: $
# Author: Slaven Rezic
#

use strict;

use Tk;

BEGIN {
    if (!eval q{
	use 5.006; # three-arg open
	use Test::More;
	1;
    }) {
	print "1..0 # skip: no Test::More module\n";
	exit;
    }
}

plan tests => 2;

my @fh;
my $callback_called = 0;

my $mw = tkinit;
$mw->geometry("+10+10");
$mw->idletasks;

# A variant of the problem reported in
# http://rt.cpan.org/Ticket/Display.html?id=32034
#
# tclUnixNotify.c used to do bit-handling for the select() mask
# itself, but this was broken for 64bit machines.
my ($rpipe, $wpipe);
ok(pipe($rpipe, $wpipe), 'create blocking descriptors');
for (1..100) {
    open my $dup, "<&", $rpipe or die "Can't dup rpipe: $!";
    push @fh, $dup;
    $mw->fileevent($dup, "readable", sub { $callback_called++ });
}

$mw->after(300, sub { $mw->destroy });
MainLoop;

local $TODO;
$TODO = "Known to break on $^O" if $^O eq 'cygwin';

is($callback_called, 0, "Fileevent callback should never be called");

__END__