Blame t/110_ntest.t

Packit 7ef13a
# Before `make install' is performed this script should be runnable with
Packit 7ef13a
# `make test'. After `make install' it should work as `perl test.t'
Packit 7ef13a
Packit 7ef13a
######################### We start with some black magic to print on failure.
Packit 7ef13a
Packit 7ef13a
# Change 1..1 below to 1..last_test_to_print.
Packit 7ef13a
# Testing syswrite() to a MUX handle
Packit 7ef13a
Packit 7ef13a
use strict;
Packit 7ef13a
BEGIN { $| = 1; print "1..8\n";}
Packit 7ef13a
my $loaded;
Packit 7ef13a
END {print "not ok 1\n" unless $loaded;}
Packit 7ef13a
use IO::Socket;
Packit 7ef13a
use IO::Multiplex;
Packit 7ef13a
use Fcntl qw(F_GETFL F_SETFL O_NONBLOCK);
Packit 7ef13a
$loaded = 1;
Packit 7ef13a
Packit 7ef13a
my $test_msg = "Hello\n";
Packit 7ef13a
Packit 7ef13a
print "ok 1\n";
Packit 7ef13a
Packit 7ef13a
######################### End of black magic.
Packit 7ef13a
Packit 7ef13a
# Insert your test code below (better if it prints "ok 13"
Packit 7ef13a
# (correspondingly "not ok 13") depending on the success of chunk 13
Packit 7ef13a
# of the test code):
Packit 7ef13a
Packit 7ef13a
my $mux = new IO::Multiplex;
Packit 7ef13a
Packit 7ef13a
print $mux ? "ok 2\n" : "not ok 2\n";
Packit 7ef13a
Packit 7ef13a
my $client_socket;
Packit 7ef13a
my $listen_socket = IO::Socket::INET->new(Proto     => 'tcp',
Packit 7ef13a
                                          Listen    => 4);
Packit 7ef13a
Packit 7ef13a
print $listen_socket ? "ok 3\n" : "not ok 3\n";
Packit 7ef13a
Packit 7ef13a
my $port = $listen_socket->sockport;
Packit 7ef13a
Packit 7ef13a
my $test_no = 4;
Packit 7ef13a
Packit 7ef13a
$SIG{ALRM} = sub { print "not ok $test_no\n"; exit };
Packit 7ef13a
Packit 7ef13a
alarm(20);
Packit 7ef13a
Packit 7ef13a
$mux->listen($listen_socket);
Packit 7ef13a
$mux->set_callback_object(__PACKAGE__);
Packit 7ef13a
$mux->set_timeout($listen_socket, 5);
Packit 7ef13a
#print STDERR "DEBUG: Doing loop...\n";
Packit 7ef13a
$mux->loop;
Packit 7ef13a
Packit 7ef13a
sub mux_timeout
Packit 7ef13a
{
Packit 7ef13a
    #print STDERR "DEBUG: mux_timeout reached!\n";
Packit 7ef13a
    print "ok 4\n";
Packit 7ef13a
Packit 7ef13a
    $test_no = 5;
Packit 7ef13a
    $client_socket = IO::Socket::INET->new(PeerAddr => "127.0.0.1",
Packit 7ef13a
                                           PeerPort => $port,
Packit 7ef13a
                                           Proto    => 'tcp');
Packit 7ef13a
Packit 7ef13a
    print $client_socket ? "ok 5\n" : "not ok 5\n";
Packit 7ef13a
    $test_no = 6;
Packit 7ef13a
}
Packit 7ef13a
Packit 7ef13a
sub mux_connection
Packit 7ef13a
{
Packit 7ef13a
    my $package    = shift;
Packit 7ef13a
    my $mux        = shift;
Packit 7ef13a
    my $fh         = shift;
Packit 7ef13a
Packit 7ef13a
    print "ok 6\n";
Packit 7ef13a
    $test_no++;
Packit 7ef13a
Packit 7ef13a
    syswrite($client_socket, $test_msg, length $test_msg);
Packit 7ef13a
}
Packit 7ef13a
Packit 7ef13a
sub mux_input
Packit 7ef13a
{
Packit 7ef13a
    print "ok 7\n";
Packit 7ef13a
    shift; shift; shift;
Packit 7ef13a
    my $input = shift;
Packit 7ef13a
Packit 7ef13a
    return unless $$input =~ /\n/;
Packit 7ef13a
Packit 7ef13a
    print $$input eq $test_msg ? "ok 8\n" : "not ok 8\n";
Packit 7ef13a
Packit 7ef13a
    exit;
Packit 7ef13a
}