Mercurial > hg > nginx-tests
view userid_flags.t @ 1973:94e0390dc64f
Tests: guarded ssl_certificates.t for old OpenSSL versions.
The ssl_certificates.t test uses ECDSA ciphers, which are only available
starting with OpenSSL 0.9.8b. In previous versions, notably in OpenSSL 0.9.8
and 0.9.8a, only non-standard example ciphers where available, which cannot
be used with any other clients.
The same applies to ssl_stapling.t, but it also requires the certificate
status TLS extension, which is only available since OpenSSL 0.9.8h, and
therefore no additional checks are needed.
author | Maxim Dounin <mdounin@mdounin.ru> |
---|---|
date | Mon, 06 May 2024 00:04:24 +0300 |
parents | 5ac6efbe5552 |
children |
line wrap: on
line source
#!/usr/bin/perl # (C) Sergey Kandaurov # (C) Nginx, Inc. # Tests for the userid_flags 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 userid/); $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; userid on; userid_name test; userid_path /0123456789; userid_domain test.domain; location / { userid_flags samesite=strict; location /many { userid_flags httponly samesite=none secure; } location /off { userid_flags off; } } location /lax { userid_flags samesite=lax; } location /unset { } } } EOF $t->write_file('index.html', ''); $t->write_file('lax', ''); $t->write_file('many', ''); $t->run()->plan(5); ############################################################################### like(http_get('/'), qr/samesite=strict/i, 'strict'); like(http_get('/lax'), qr/samesite=lax/i, 'lax'); like(http_get('/many'), qr/secure; httponly; samesite=none/i, 'many'); unlike(http_get('/off'), qr/(secure|httponly|samesite)/i, 'off'); unlike(http_get('/unset'), qr/(secure|httponly|samesite)/i, 'unset'); ###############################################################################