Mercurial > hg > nginx-tests
view proxy_bind_transparent.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 | 5da72eaa893f |
children |
line wrap: on
line source
#!/usr/bin/perl # (C) Sergey Kandaurov # (C) Nginx, Inc. # Tests for http proxy_bind transparent. ############################################################################### 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; plan(skip_all => 'win32') if $^O eq 'MSWin32'; plan(skip_all => 'must be root') if $> != 0; plan(skip_all => '127.0.0.2 local address required') unless defined IO::Socket::INET->new( LocalAddr => '127.0.0.2' ); my $t = Test::Nginx->new()->has(qw/http proxy/) ->write_file_expand('nginx.conf', <<'EOF'); %%TEST_GLOBALS%% daemon off; user root wheel; events { } http { %%TEST_GLOBALS_HTTP%% server { listen 127.0.0.1:8080; server_name localhost; location / { proxy_bind 127.0.0.2 transparent; proxy_pass http://127.0.0.1:8081/; } } server { listen 127.0.0.1:8081; server_name localhost; location / { add_header X-IP $remote_addr always; } } } EOF $t->run()->plan(1); ############################################################################### like(http_get('/'), qr/X-IP: 127.0.0.2/, 'transparent'); ###############################################################################