Mercurial > hg > nginx-tests
view http_location.t @ 1847:a9704b9ed7a2
Tests: removed multiple server certificates from ssl_ocsp.t.
Multiple server certificates are not needed to test OCSP verification of
client certificates (in contrast to OCSP stapling, where server certificates
are verified, and different staples should be correctly returned with
different server certificates). And using multiple server certificates
causes issues when testing with LibreSSL due to broken sigalgs-based
server certificate selection in LibreSSL with TLSv1.3.
Accordingly, the test is simplified to do not use multiple server
certificates.
author | Maxim Dounin <mdounin@mdounin.ru> |
---|---|
date | Thu, 23 Mar 2023 19:50:26 +0300 |
parents | 882267679006 |
children |
line wrap: on
line source
#!/usr/bin/perl # (C) Maxim Dounin # Tests for location selection. ############################################################################### 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 rewrite/)->plan(14) ->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 = / { add_header X-Location exactlyroot; return 204; } location / { add_header X-Location root; return 204; } location ^~ /images/ { add_header X-Location images; return 204; } location ~* \.(gif|jpg|jpeg)$ { add_header X-Location regex; return 204; } location ~ casefull { add_header X-Location casefull; return 204; } location = /foo { add_header X-Location "/foo exact"; return 204; } location /foo { add_header X-Location "/foo prefix"; return 204; } location = /foo/ { add_header X-Location "/foo/ exact"; return 204; } location /foo/ { add_header X-Location "/foo/ prefix"; return 204; } location /lowercase { add_header X-Location lowercase; return 204; } location /UPPERCASE { add_header X-Location uppercase; return 204; } } } EOF $t->run(); ############################################################################### like(http_get('/'), qr/X-Location: exactlyroot/, 'exactlyroot'); like(http_get('/x'), qr/X-Location: root/, 'root'); like(http_get('/images/t.gif'), qr/X-Location: images/, 'images'); like(http_get('/t.gif'), qr/X-Location: regex/, 'regex'); like(http_get('/t.GIF'), qr/X-Location: regex/, 'regex with mungled case'); like(http_get('/casefull/t.gif'), qr/X-Location: regex/, 'first regex wins'); like(http_get('/casefull/'), qr/X-Location: casefull/, 'casefull regex'); like(http_get('/foo'), qr!X-Location: /foo exact!, '/foo exact'); like(http_get('/foobar'), qr!X-Location: /foo prefix!, '/foo prefix'); like(http_get('/foo/'), qr!X-Location: /foo/ exact!, '/foo/ exact'); like(http_get('/foo/bar'), qr!X-Location: /foo/ prefix!, '/foo/ prefix'); SKIP: { skip 'caseless os', 1 if $^O eq 'MSWin32' or $^O eq 'darwin'; like(http_get('/CASEFULL/'), qr/X-Location: root/, 'casefull regex do not match wrong case'); } # on case-insensitive systems a request to "/UPPERCASE" might fail, # if location search tree is incorrectly sorted and uppercase # characters are used in location directives (ticket #90) like(http_get('/lowercase'), qr/X-Location: lowercase/, 'lowercase'); like(http_get('/UPPERCASE'), qr/X-Location: uppercase/, 'uppercase'); ###############################################################################