AnyEvent-Eris

 view release on metacpan or  search on metacpan

t/server/dispatching_messages.t  view on Meta::CPAN

use t::lib::Eris::Test tests => 4;

my ( $registered_fullfeed, $msg_arrived );
my ( $server, $cv ) = new_server;
my ( $addr, $port ) = @{$server}{qw<ListenAddress ListenPort>};
my $SID = '';
my $c = tcp_connect $addr, $port, sub {
    my ($fh) = @_
        or BAIL_OUT("Connect failed: $!");

    my $hdl; $hdl = AnyEvent::Handle->new(
        fh       => $fh,
        on_error => sub { AE::log error => $_[2]; $_[0]->destroy },
        on_eof   => sub { $hdl->destroy; AE::log info => 'Done.' },
        on_read  => sub {
            my ($hdl) = @_;
            chomp( my $line = delete $hdl->{'rbuf'} );

            if ( $line =~ /^EHLO/ ) {
                ($SID) = $line =~ /\(KERNEL:\s\d+:([a-fA-F0-9]+)\)/;
                $hdl->push_write("fullfeed\n");
            } elsif ( $line =~ /^Full feed enabled/ ) {
                is(
                    $server->clients->{$SID}{'full'},
                    1,
                    'Full feed registered for client',
                );
                $registered_fullfeed++;
            } else {
                $msg_arrived++;
                $cv->send('OK');
            }
        },
    );
};

my $timer; $timer = AE::timer 0.05, 0, sub {
    undef $timer;
    $server->dispatch_message('Hello world');
};

is( $server->run($cv), 'OK', 'Server closed' );
is( $registered_fullfeed, 1, 'Fullfeed registered' );
is( $msg_arrived, 1, 'Message arrived (msg dispatching)' );



( run in 0.547 second using v1.01-cache-2.11-cpan-13bb782fe5a )