# HG changeset patch # User Sergey Kandaurov # Date 1570628763 -10800 # Node ID 420aaeb40c09b6eb79d6dab1923c1d7c04de1eee # Parent eb33558f731dfdaed3060dce20f4a5fd8e649f57 Tests: merge_slashes tests. diff --git a/merge_slashes.t b/merge_slashes.t new file mode 100644 --- /dev/null +++ b/merge_slashes.t @@ -0,0 +1,60 @@ +#!/usr/bin/perl + +# (C) Sergey Kandaurov +# (C) Nginx, Inc. + +# Tests for URI normalization, merge_slashes off. + +############################################################################### + +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 rewrite/)->plan(2) + ->write_file_expand('nginx.conf', <<'EOF')->run(); + +%%TEST_GLOBALS%% + +daemon off; + +events { +} + +http { + %%TEST_GLOBALS_HTTP%% + + server { + listen 127.0.0.1:8080; + server_name localhost; + + merge_slashes off; + + location / { + add_header X-URI "x $uri x"; + return 204; + } + } +} + +EOF + +############################################################################### + +local $TODO = 'not yet' unless $t->has_version('1.17.5'); + +like(http_get('/foo//../bar'), qr!x /foo/bar x!, 'merge slashes'); +like(http_get('/foo///../bar'), qr!x /foo//bar x!, 'merge slashes 2'); + +###############################################################################