blob: 5f27e05500e32e6a1a510a49cc304d8aa8794d6e [file] [log] [blame]
use strict;
use warnings FATAL => 'all';
use Apache::Test;
use Apache::TestRequest;
use Apache::TestUtil;
use Apache::TestConfig ();
my @test_cases = ( "ping0", "ping1" x 10, "ping2" x 100, "ping3" x 1024, "ping4" x 4000, "sendquit");
my $total_tests = 2;
plan tests => $total_tests, need 'AnyEvent::WebSocket::Client',
need_module('ssl', 'proxy_http', 'lua'), need_min_apache_version('2.4.47');
require AnyEvent;
require AnyEvent::WebSocket::Client;
my $config = Apache::Test::config();
#my $hostport = $config->{vhosts}->{proxy_https_https}->{hostport};
my $hostport = $config->{vhosts}->{$config->{vars}->{ssl_module_name}}->{hostport};
my $client = AnyEvent::WebSocket::Client->new(timeout => 5, ssl_ca_file => $config->{vars}->{sslca} . "/" . $config->{vars}->{sslcaorg} . "/certs/ca.crt");
my $quit_program = AnyEvent->condvar;
my $responses = 0;
my $surprised = 0;
t_debug("wss://$hostport/modules/lua/websockets.lua");
# $client->connect("wss://$hostport/proxy/wsoc")->cb(sub {
$client->connect("wss://$hostport/modules/lua/websockets.lua")->cb(sub {
our $connection = eval { shift->recv };
t_debug("wsoc connected");
if($@) {
# handle error...
warn $@;
$quit_program->send();
return;
}
# AnyEvent::WebSocket::Connection does not pass the PONG message down to the callback
# my $actualpingmsg = AnyEvent::WebSocket::Message->new(opcode => 0x09, body => "xxx");
# $connection->send($actualpingmsg);
foreach (@test_cases){
$connection->send($_);
}
$connection->on(finish => sub {
t_debug("finish");
$quit_program->send();
});
# recieve message from the websocket...
$connection->on(each_message => sub {
# $connection is the same connection object
# $message isa AnyEvent::WebSocket::Message
my($connection, $message) = @_;
$responses++;
t_debug("wsoc msg received: " . substr($message->body, 0, 5). " opcode " . $message->opcode);
if ("sendquit" eq $message->body) {
$connection->send('quit');
t_debug("closing");
$connection->close; # doesn't seem to close TCP.
$quit_program->send();
}
elsif ($message->body =~ /^ping(\d)/) {
my $offset = $1;
if ($message->body ne $test_cases[$offset]) {
t_debug("wrong data");
$surprised++;
}
}
else {
$surprised++;
}
});
});
$quit_program->recv;
ok t_cmp($surprised, 0);
# We don't expect the 20k over SSL to work, and we won't read the "sendquit" echoed back either.
ok t_cmp($responses, scalar(@test_cases)-2 );