blob: 05310cc420f99bc00aa01a9d0a7a4bcb07cf205e [file] [log] [blame]
package Test::Nginx::POP3;
# (C) Maxim Dounin
# Module for nginx pop3 tests.
###############################################################################
use warnings;
use strict;
use Test::More qw//;
use IO::Select;
use IO::Socket;
use Socket qw/ CRLF /;
use Test::Nginx;
sub new {
my $self = {};
bless $self, shift @_;
$self->{_socket} = IO::Socket::INET->new(
Proto => "tcp",
PeerAddr => "127.0.0.1:" . port(8110),
@_
)
or die "Can't connect to nginx: $!\n";
if ({@_}->{'SSL'}) {
require IO::Socket::SSL;
IO::Socket::SSL->start_SSL($self->{_socket}, @_)
or die $IO::Socket::SSL::SSL_ERROR . "\n";
}
$self->{_socket}->autoflush(1);
return $self;
}
sub eof {
my $self = shift;
return $self->{_socket}->eof();
}
sub print {
my ($self, $cmd) = @_;
log_out($cmd);
$self->{_socket}->print($cmd);
}
sub send {
my ($self, $cmd) = @_;
log_out($cmd);
$self->{_socket}->print($cmd . CRLF);
}
sub read {
my ($self) = @_;
my $socket = $self->{_socket};
eval {
local $SIG{ALRM} = sub { die "timeout\n" };
alarm(8);
while (<$socket>) {
log_in($_);
# XXX
next if m/^\d\d\d-/;
last;
}
alarm(0);
};
alarm(0);
if ($@) {
log_in("died: $@");
return undef;
}
return $_;
}
sub check {
my ($self, $regex, $name) = @_;
Test::More->builder->like($self->read(), $regex, $name);
}
sub ok {
my $self = shift;
Test::More->builder->like($self->read(), qr/^\+OK/, @_);
}
sub can_read {
my ($self, $timo) = @_;
IO::Select->new($self->{_socket})->can_read($timo || 3);
}
###############################################################################
sub pop3_test_daemon {
my ($port) = @_;
my $server = IO::Socket::INET->new(
Proto => 'tcp',
LocalAddr => '127.0.0.1:' . ($port || port(8111)),
Listen => 5,
Reuse => 1
)
or die "Can't create listening socket: $!\n";
while (my $client = $server->accept()) {
$client->autoflush(1);
print $client "+OK fake pop3 server ready" . CRLF;
while (<$client>) {
if (/^quit/i) {
print $client '+OK quit ok' . CRLF;
} elsif (/^user test\@example.com/i) {
print $client '+OK user ok' . CRLF;
} elsif (/^pass secret/i) {
print $client '+OK pass ok' . CRLF;
} else {
print $client "-ERR unknown command" . CRLF;
}
}
close $client;
}
}
###############################################################################
1;
###############################################################################