1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132
|
#!/usr/bin/perl
# (C) Dmitry Volyntsev
# (C) Nginx, Inc.
# Tests for http njs module, fetch method timeout.
###############################################################################
use warnings;
use strict;
use Test::More;
use Socket qw/ CRLF /;
BEGIN { use FindBin; chdir($FindBin::Bin); }
use lib 'lib';
use Test::Nginx;
###############################################################################
select STDERR; $| = 1;
select STDOUT; $| = 1;
my $t = Test::Nginx->new()->has(qw/http/)
->write_file_expand('nginx.conf', <<'EOF');
%%TEST_GLOBALS%%
daemon off;
events {
}
http {
%%TEST_GLOBALS_HTTP%%
js_import test.js;
server {
listen 127.0.0.1:8080;
server_name localhost;
location /njs {
js_content test.njs;
}
location /engine {
js_content test.engine;
}
location /normal_timeout {
js_content test.timeout_test;
}
location /short_timeout {
js_fetch_timeout 200ms;
js_content test.timeout_test;
}
}
server {
listen 127.0.0.1:8081;
server_name localhost;
location /normal_reply {
js_content test.normal_reply;
}
location /delayed_reply {
js_content test.delayed_reply;
}
}
}
EOF
my $p1 = port(8081);
$t->write_file('test.js', <<EOF);
function test_njs(r) {
r.return(200, njs.version);
}
function engine(r) {
r.return(200, njs.engine);
}
async function timeout_test(r) {
let rs = await Promise.allSettled([
'http://127.0.0.1:$p1/normal_reply',
'http://127.0.0.1:$p1/delayed_reply',
].map(v => ngx.fetch(v)));
let bs = rs.map(v => ({s: v.status, v: v.value ? v.value.headers.X
: v.reason}));
r.return(200, njs.dump(bs));
}
function normal_reply(r) {
r.headersOut.X = 'N';
r.return(200);
}
function delayed_reply(r) {
r.headersOut.X = 'D';
setTimeout((r) => { r.return(200); }, 250, r, 0);
}
export default {njs: test_njs, engine, timeout_test, normal_reply,
delayed_reply};
EOF
$t->try_run('no js_fetch_timeout');
plan(skip_all => 'not yet') if http_get('/engine') =~ /QuickJS$/m;
$t->plan(2);
###############################################################################
like(http_get('/normal_timeout'),
qr/\[\{s:'fulfilled',v:'N'},\{s:'fulfilled',v:'D'}]$/s,
'normal timeout');
like(http_get('/short_timeout'),
qr/\[\{s:'fulfilled',v:'N'},\{s:'rejected',v:Error: read timed out}]$/s,
'short timeout');
###############################################################################
|