Mercurial > hg > nginx-tests
view proxy_bind_transparent.t @ 967:eb111c5f7556
Tests: stream ssl tests with variables.
author | Sergey Kandaurov <pluknet@nginx.com> |
---|---|
date | Tue, 05 Jul 2016 20:33:54 +0300 |
parents | e9064d691790 |
children | 882267679006 |
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:%%PORT_0%%; server_name localhost; location / { proxy_bind 127.0.0.2 transparent; proxy_pass http://127.0.0.1:%%PORT_1%%/; } } server { listen 127.0.0.1:%%PORT_1%%; server_name localhost; location / { add_header X-IP $remote_addr; } } } EOF $t->write_file('index.html', ''); $t->try_run('no proxy_bind transparent')->plan(1); ############################################################################### like(http_get('/'), qr/X-IP: 127.0.0.2/, 'transparent'); ###############################################################################