# HG changeset patch # User Sergey Kandaurov # Date 1547652750 -10800 # Node ID bba26f4b40ef7af7ac51a5141ee6471ce435f214 # Parent f7f387086278460a9598100066d88a69f91db53e Tests: stream limit rate tests with datagrams. diff --git a/stream_udp_limit_rate.t b/stream_udp_limit_rate.t new file mode 100644 --- /dev/null +++ b/stream_udp_limit_rate.t @@ -0,0 +1,135 @@ +#!/usr/bin/perl + +# (C) Sergey Kandaurov +# (C) Nginx, Inc. + +# Tests for stream proxy module with datagrams, limit rate directives. + +############################################################################### + +use warnings; +use strict; + +use Test::More; + +BEGIN { use FindBin; chdir($FindBin::Bin); } + +use lib 'lib'; +use Test::Nginx; +use Test::Nginx::Stream qw/ dgram /; + +############################################################################### + +select STDERR; $| = 1; +select STDOUT; $| = 1; + +my $t = Test::Nginx->new()->has(qw/stream udp/) + ->write_file_expand('nginx.conf', <<'EOF'); + +%%TEST_GLOBALS%% + +daemon off; + +events { +} + +stream { + proxy_requests 2; + proxy_responses 1; + + server { + listen 127.0.0.1:%%PORT_8982_UDP%% udp; + proxy_pass 127.0.0.1:%%PORT_8980_UDP%%; + } + + server { + listen 127.0.0.1:%%PORT_8983_UDP%% udp; + proxy_pass 127.0.0.1:%%PORT_8980_UDP%%; + proxy_download_rate 500; + } + + server { + listen 127.0.0.1:%%PORT_8984_UDP%% udp; + proxy_pass 127.0.0.1:%%PORT_8980_UDP%%; + proxy_upload_rate 1000; + } +} + +EOF + +$t->run_daemon(\&udp_daemon, port(8980), $t); +$t->try_run('no proxy_requests')->plan(8); + +$t->waitforfile($t->testdir . '/' . port(8980)); + +############################################################################### + +my $str = '1234567890' x 100; + +# unlimited + +my $s = dgram('127.0.0.1:' . port(8982)); +is($s->io($str), $str, 'unlimited'); +is($s->io($str), $str, 'unlimited 2'); + +# datagram doesn't get split + +my $t1; + +TODO: { +local $TODO = 'split datagram'; + +$s = dgram('127.0.0.1:' . port(8983)); +is($s->io($str), $str, 'download'); +$t1 = time(); +is($s->io($str), $str, 'download 2'); + +} + +my $t2 = time(); +cmp_ok($t1, '<', $t2, 'download 2 delayed'); + +TODO: { +todo_skip 'infinite event report', 3; + +$s = dgram('127.0.0.1:' . port(8984)); +is($s->io($str), $str, 'upload'); + +is($s->io($str, read_timeout => 0.5), '', 'upload limited'); + +select undef, undef, undef, 0.6; + +is($s->io($str), $str, 'upload passed'); + +} + +############################################################################### + +sub udp_daemon { + my ($port, $t) = @_; + + my $server = IO::Socket::INET->new( + Proto => 'udp', + LocalAddr => "127.0.0.1:$port", + ) + or die "Can't create listening socket: $!\n"; + + # signal we are ready + + open my $fh, '>', $t->testdir() . "/$port"; + close $fh; + + while (1) { + $server->recv(my $buffer, 65536); + log2i("$server $buffer"); + + log2o("$server $buffer"); + $server->send($buffer); + } +} + +sub log2i { Test::Nginx::log_core('|| <<', @_); } +sub log2o { Test::Nginx::log_core('|| >>', @_); } +sub log2c { Test::Nginx::log_core('||', @_); } + +###############################################################################