Mercurial > hg > nginx-tests
view proxy_intercept_errors.t @ 1951:1867428f1673
Tests: fixed h3_limit_req.t spurious failures.
In the "reset stream - cancellation" test, HTTP/3 stream is closed without
sending the request body when the request is waiting in the limit_req
module, and this results in error 444. However, when the request is received
with some minor delay due to system load, it is not delayed by limit_req,
and the stream is closed during reading the request body, which results
in error 400 instead, breaking the test.
Fix is to introduce yet another request before the "reset stream" test,
so the stream in question is always delayed by limit_req.
author | Maxim Dounin <mdounin@mdounin.ru> |
---|---|
date | Thu, 14 Mar 2024 02:25:49 +0300 |
parents | 83ec64929612 |
children |
line wrap: on
line source
#!/usr/bin/perl # (C) Maxim Dounin # Tests for http proxy module, proxy_intercept_errors directive. ############################################################################### use warnings; use strict; use Test::More; 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 proxy rewrite/)->plan(4); $t->write_file_expand('nginx.conf', <<'EOF'); %%TEST_GLOBALS%% daemon off; events { } http { %%TEST_GLOBALS_HTTP%% server { listen 127.0.0.1:8080; server_name localhost; location / { proxy_pass http://127.0.0.1:8081; proxy_intercept_errors on; error_page 401 500 /intercepted; } location = /intercepted { return 200 "intercepted\n"; } } server { listen 127.0.0.1:8081; server_name localhost; location / { return 404 "SEE-THIS"; } location /500 { return 500; } location /auth { add_header WWW-Authenticate foo always; return 401; } location /auth-multi { add_header WWW-Authenticate foo always; add_header WWW-Authenticate bar always; return 401; } } } EOF $t->run(); ############################################################################### # make sure errors without error_page set are not intercepted like(http_get('/'), qr/SEE-THIS/, 'not intercepted'); # make sure errors with error_page are intercepted like(http_get('/500'), qr/500.*intercepted/s, 'intercepted 500'); like(http_get('/auth'), qr/401.*WWW-Authenticate.*intercepted/s, 'intercepted 401'); # make sure multiple WWW-Authenticate headers are returned # along with intercepted response (ticket #485) TODO: { local $TODO = 'not yet' unless $t->has_version('1.23.0'); like(http_get('/auth-multi'), qr/401.*WWW-Authenticate: foo.*bar.*intercept/s, 'intercepted 401 multi'); } ###############################################################################