… | |
… | |
21 | sub { |
21 | sub { |
22 | my ($fh, $host, $port) = @_; |
22 | my ($fh, $host, $port) = @_; |
23 | |
23 | |
24 | $hdl = AnyEvent::Handle->new (fh => $fh, on_eof => sub { $cv->broadcast }); |
24 | $hdl = AnyEvent::Handle->new (fh => $fh, on_eof => sub { $cv->broadcast }); |
25 | |
25 | |
26 | $hdl->push_read_chunk (6, sub { |
26 | $hdl->push_read (chunk => 6, sub { |
27 | my ($hdl, $data) = @_; |
27 | my ($hdl, $data) = @_; |
28 | |
28 | |
29 | if ($data eq "TEST\015\012") { |
29 | if ($data eq "TEST\015\012") { |
30 | print "ok 1 - server received client data\n"; |
30 | print "ok 1 - server received client data\n"; |
31 | } else { |
31 | } else { |
… | |
… | |
33 | } |
33 | } |
34 | |
34 | |
35 | $hdl->push_write ("BLABLABLA\015\012"); |
35 | $hdl->push_write ("BLABLABLA\015\012"); |
36 | }); |
36 | }); |
37 | }, sub { |
37 | }, sub { |
38 | ($port) = Socket::unpack_sockaddr_in getsockname $_[0]; |
38 | $port = $_[2]; |
39 | |
39 | |
40 | 0 |
40 | 0 |
41 | }; |
41 | }; |
42 | |
|
|
43 | |
42 | |
44 | my $clhdl; |
43 | my $clhdl; |
45 | my $wc = tcp_connect localhost => $port, sub { |
44 | my $wc = tcp_connect localhost => $port, sub { |
46 | my ($fh) = @_ |
45 | my ($fh) = @_ |
47 | or die "connect: $!"; |
46 | or die "connect: $!"; |
48 | |
47 | |
49 | $clhdl = AnyEvent::Handle->new (fh => $fh, on_eof => sub { $cv->broadcast }); |
48 | $clhdl = AnyEvent::Handle->new (fh => $fh, on_eof => sub { $cv->broadcast }); |
50 | |
49 | |
51 | $clhdl->push_write ("TEST\015\012"); |
50 | $clhdl->push_write ("TEST\015\012"); |
52 | $clhdl->push_read_line (sub { |
51 | $clhdl->push_read (line => sub { |
53 | my ($clhdl, $line) = @_; |
52 | my ($clhdl, $line) = @_; |
54 | |
53 | |
55 | if ($line eq 'BLABLABLA') { |
54 | if ($line eq 'BLABLABLA') { |
56 | print "ok 2 - client received response\n"; |
55 | print "ok 2 - client received response\n"; |
57 | } else { |
56 | } else { |