ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/AnyEvent/t/handle/04_listen.t
(Generate patch)

Comparing AnyEvent/t/handle/04_listen.t (file contents):
Revision 1.5 by root, Fri May 2 09:07:02 2008 UTC vs.
Revision 1.7 by elmex, Thu May 15 13:32:19 2008 UTC

1#!/opt/perl/bin/perl 1#!/opt/perl/bin/perl
2
3use strict; 2use strict;
4use Test::More tests => 2;
5use AnyEvent::Impl::Perl; 3use AnyEvent::Impl::Perl;
4use AnyEvent::Handle;
6use AnyEvent; 5use AnyEvent::Util;
7use AnyEvent::Socket; 6use IO::Socket::INET;
8 7
9my $lbytes; 8my $lbytes;
10my $rbytes; 9my $rbytes;
11 10
11print "1..2\n";
12
12my $cv = AnyEvent->condvar; 13my $cv = AnyEvent->condvar;
13 14
15my $sock = IO::Socket::INET->new (
16 Listen => 5, ReuseAddr => 1, LocalAddr => 'localhost',
17) or die "Couldn't make socket: $!\n";
18
19my $hdl;
20
21my $w = AnyEvent::Util::listen ($sock, sub {
22 my ($cl, $claddr) = @_;
23 $hdl = AnyEvent::Handle->new (fh => $cl, on_eof => sub { $cv->broadcast });
24
25 $hdl->push_read_chunk (6, sub {
26 my ($hdl, $data) = @_;
27
28 if ($data eq "TEST\015\012") {
29 print "ok 1 - server received client data\n";
30 } else {
31 print "not ok 1 - server received bad client data\n";
32 }
33
34 $hdl->push_write ("BLABLABLA\015\012");
35 });
36
37}, sub {
38 warn "error on accept: $!";
39 $cv->broadcast;
40});
41
14my $lsock = 42my $clsock =
15 AnyEvent::Socket->new ( 43 IO::Socket::INET->new (
16 Listen => 1, 44 PeerHost => $sock->sockhost,
17 LocalPort => 32391, 45 PeerPort => $sock->sockport,
18 ReuseAddr => 1, 46 Blocking => 0,
19 ); 47 );
20 48
21my $ae_sock = 49my $clhdl;
22 AnyEvent::Socket->new ( 50my $wc = AnyEvent::Util::connect ($clsock, sub {
23 PeerAddr => "127.0.0.1:32391", 51 my ($clsock) = @_;
24 on_connect => sub { 52 $clhdl = AnyEvent::Handle->new (fh => $clsock, on_eof => sub { $cv->broadcast });
25 my ($ae_sock, $error) = @_;
26 if ($error) { diag "connection failed: $!"; $cv->broadcast; return }
27 53
28 print "connected to ".$ae_sock->fh->peerhost.":".$ae_sock->fh->peerport."\n"; 54 $clhdl->push_write ("TEST\015\012");
55 $clhdl->push_read_line (sub {
56 my ($clhdl, $line) = @_;
29 57
30 $ae_sock->on_read (sub { 58 if ($line eq 'BLABLABLA') {
31 my ($ae_sock) = @_; 59 print "ok 2 - client received response\n";
32 $rbytes = $ae_sock->rbuf; 60 } else {
33 }); 61 print "not ok 2 - client received bad response\n";
62 }
34 63
35 $ae_sock->write ("TEST\015\012"); 64 $cv->broadcast;
36 }
37 );
38
39$ae_sock->on_eof (sub { $cv->broadcast });
40
41$lsock->on_accept (sub {
42 my ($lsock, $cl, $paddr) = @_;
43
44 unless (defined $cl) {
45 diag "accept failed: $!";
46 return;
47 }
48
49 $cl->read (6, sub {
50 my ($cl, $data) = @_;
51 $lbytes = $data;
52 $cl->write ("BLABLABLA\015\012");
53 }); 65 });
54}); 66}, sub {
67 warn "couldn't connect: $!";
68 $cv->broadcast;
69}, 10);
55 70
56$cv->wait; 71$cv->wait;
57
58is ($lbytes, "TEST\015\012", 'listening end received data');
59is ($rbytes, "BLABLABLA\015\012", 'connecting received response');
60

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines