From 313c46c9d7305f80c324a81d042edbd2f34aedc2 Mon Sep 17 00:00:00 2001 From: Dmitry Volyntsev Date: Mon, 25 Nov 2024 21:43:44 -0800 Subject: [PATCH] HTTP: fixed limit rated output. Previously, when r.return(code, body) was called from a subrequest handler with a body size larger than the sendfile_max_chunk value connection hanging might occur. --- nginx/ngx_http_js_module.c | 7 +++++-- nginx/t/js_return.t | 22 ++++++++++++++++++++-- nginx/t/js_subrequests.t | 21 +++++++++++++++++++-- 3 files changed, 44 insertions(+), 6 deletions(-) diff --git a/nginx/ngx_http_js_module.c b/nginx/ngx_http_js_module.c index 3e43ac7d7..e900b7162 100644 --- a/nginx/ngx_http_js_module.c +++ b/nginx/ngx_http_js_module.c @@ -1230,14 +1230,17 @@ ngx_http_js_content_write_event_handler(ngx_http_request_t *r) ngx_log_debug0(NGX_LOG_DEBUG_HTTP, r->connection->log, 0, "http js content write event handler"); + c = r->connection; ctx = ngx_http_get_module_ctx(r, ngx_http_js_module); if (!ngx_js_ctx_pending(ctx)) { ngx_http_js_content_finalize(r, ctx); - return; + + if (!c->buffered) { + return; + } } - c = r->connection; wev = c->write; if (wev->timedout) { diff --git a/nginx/t/js_return.t b/nginx/t/js_return.t index 6f8c4a93a..1ecf5a504 100644 --- a/nginx/t/js_return.t +++ b/nginx/t/js_return.t @@ -47,6 +47,11 @@ http { js_content test.returnf; } + location /limit { + sendfile_max_chunk 5; + js_content test.returnf; + } + location /njs { js_content test.njs; } @@ -61,14 +66,19 @@ $t->write_file('test.js', <try_run('no njs return')->plan(6); +$t->try_run('no njs return')->plan(7); ############################################################################### @@ -85,6 +95,14 @@ unlike(http_get('/?c=404&t='), qr/Not.*html/s, 'return empty body'); } +TODO: { +local $TODO = 'not yet' unless has_version('0.8.8'); + +like(http_get('/limit?c=200&t=X&repeat=50'), qr/200 OK.*X{50}/s, + 'return limited'); + +} + ############################################################################### sub has_version { diff --git a/nginx/t/js_subrequests.t b/nginx/t/js_subrequests.t index d38573ba6..bebc7c511 100644 --- a/nginx/t/js_subrequests.t +++ b/nginx/t/js_subrequests.t @@ -139,6 +139,11 @@ http { js_content test.sr_cache; } + location /sr_limit { + sendfile_max_chunk 5; + js_content test.sr_limit; + } + location /sr_unavail { js_content test.sr_unavail; @@ -385,6 +390,12 @@ $t->write_file('test.js', <write_file('test.js', <write_file('t', '["SEE-THIS"]'); -$t->try_run('no njs available')->plan(33); +$t->try_run('no njs available')->plan(34); $t->run_daemon(\&http_daemon); ############################################################################### @@ -597,6 +608,12 @@ ok(index($t->read_file('error.log'), 'subrequest can only be created for') > 0, } +TODO: { +local $TODO = 'not yet' unless has_version('0.8.8'); + +like(http_get('/sr_limit'), qr/x{100}/, 'sr_limit'); +} + $t->stop(); ok(index($t->read_file('error.log'), 'callback is not a function') > 0,