Mercurial > hg > nginx-tests
changeset 114:44b281ac4bc6
Tests: add server name tests, including fancy regex ones.
With test config nginx will fail to start as of 0.8.28 due to incorrect
conversion of regular expressions to lowercase. Patch was discussed on
mailing list and will be included in next release.
author | Maxim Dounin <mdounin@mdounin.ru> |
---|---|
date | Mon, 30 Nov 2009 14:47:17 +0300 |
parents | 5d31f920eda9 |
children | cb1b04d8de29 |
files | http-server-name.t |
diffstat | 1 files changed, 140 insertions(+), 0 deletions(-) [+] |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/http-server-name.t Mon Nov 30 14:47:17 2009 +0300 @@ -0,0 +1,140 @@ +#!/usr/bin/perl + +# (C) Maxim Dounin + +# Tests for server_name 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('rewrite') + ->write_file_expand('nginx.conf', <<'EOF'); + +%%TEST_GLOBALS%% + +master_process off; +daemon off; + +events { +} + +http { + %%TEST_GLOBALS_HTTP%% + + server { + listen 127.0.0.1:8080; + server_name localhost; + + location / { + add_header X-Server $server_name; + return 204; + } + } + + server { + listen 127.0.0.1:8080; + server_name www.example.com; + + location / { + add_header X-Server $server_name; + return 204; + } + } + + server { + listen 127.0.0.1:8080; + server_name ~^EXAMPLE\.COM$; + + location / { + add_header X-Server $server_name; + return 204; + } + } + + server { + listen 127.0.0.1:8080; + server_name ~^(?P<name>.+)\Q.example.com\E$; + + location / { + add_header X-Server $server_name; + add_header X-Match $name; + return 204; + } + } + + server { + listen 127.0.0.1:8080; + server_name "~^(?<name>www\p{N}+)\.example\.com$"; + + location / { + add_header X-Server $server_name; + add_header X-Match $name; + return 204; + } + } +} + +EOF + +eval { + +$t->run(); + +}; + +if ($@) { + plan(skip_all => 'not patched yet'); +} + +$t->plan(9); + +############################################################################### + +sub http_server($) { + my ($host) = @_; + return http(<<EOF); +GET / HTTP/1.0 +Host: $host + +EOF +} + +############################################################################### + +like(http_server('xxx'), qr/X-Server: localhost/, 'default'); + +like(http_server('www.example.com'), qr/\QX-Server: www.example.com/, + 'www.example.com'); +like(http_server('WWW.EXAMPLE.COM'), qr/\QX-Server: www.example.com/, + 'www.example.com uppercase'); + +like(http_server('example.com'), qr/\QX-Server: ~^EXAMPLE\.COM$/, + 'example.com regex'); +like(http_server('EXAMPLE.COM'), qr/\QX-Server: ~^EXAMPLE\.COM$/, + 'example.com regex uppercase'); + +like(http_server('blah.example.com'), qr/X-Match: blah/, + '(P<name>.*).example.com named capture'); +like(http_server('BLAH.EXAMPLE.COM'), qr/X-Match: blah/, + '(P<name>.*).example.com named capture uppercase'); + +like(http_server('www01.example.com'), qr/X-Match: www01/, + '\p{N} in named capture'); +like(http_server('WWW01.EXAMPLE.COM'), qr/X-Match: www01/, + '\p{N} in named capture uppercase'); + +###############################################################################