view proxy_bind_transparent_capability.t @ 1267:f94e79aad895

Tests: fixed proxy_cache_error.t with "tcp_nopush on". Added "postpone_output 0;" to ensure that the backend will return a response header immediately even if "tcp_nopush on;" is used in the configuration (e.g., via TEST_NGINX_GLOBALS_HTTP).
author Maxim Dounin <mdounin@mdounin.ru>
date Sat, 06 Jan 2018 23:32:33 +0300
parents b35037b3a9d0
children 97c8280de681
line wrap: on
line source

#!/usr/bin/perl

# (C) Sergey Kandaurov
# (C) Nginx, Inc.

# Tests for http proxy_bind transparent with Linux CAP_NET_RAW capability.
# Ensure that such configuration isn't broken under a non-priveleged user.

###############################################################################

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 => 'no linux capability') if $^O ne 'linux';
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;

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

plan(skip_all => 'no capability support yet') unless $t->has_version('1.13.8');

$t->run()->plan(1);

###############################################################################

like(http_get('/'), qr/X-IP: 127.0.0.2/, 'transparent');

###############################################################################