# HG changeset patch # User Sergey Kandaurov # Date 1600118879 -3600 # Node ID e682d5ad3861af0a2117892a1aefc17b1303a1fa # Parent f145dce55f322e0b8a180f4b200eda28b1011884 Tests: added two cache Vary cases fixed in 1.19.3. diff -r f145dce55f32 -r e682d5ad3861 proxy_cache_vary.t --- a/proxy_cache_vary.t Thu Sep 03 11:53:11 2020 +0300 +++ b/proxy_cache_vary.t Mon Sep 14 22:27:59 2020 +0100 @@ -22,7 +22,7 @@ select STDOUT; $| = 1; my $t = Test::Nginx->new()->has(qw/http proxy cache gzip rewrite/) - ->plan(42)->write_file_expand('nginx.conf', <<'EOF'); + ->plan(49)->write_file_expand('nginx.conf', <<'EOF'); %%TEST_GLOBALS%% @@ -81,6 +81,9 @@ if ($args = "novary") { return 200 "the only variant\n"; } + + add_header Vary $arg_vary; + add_header Xtra $arg_xtra; } location /asterisk { @@ -248,6 +251,49 @@ } +# keep c->body_start when Vary changes (ticket #2029) + +# before 1.19.3, this prevented updating c->body_start of a main key +# triggering "cache file .. has too long header" critical errors + +like(get1('/?vary=x,y', 'x:1'), qr/MISS/, 'change first'); + +TODO: { +local $TODO = 'not yet' unless $t->has_version('1.19.3'); + +like(get1('/?vary=x,y', 'x:1'), qr/HIT/, 'change first cached'); + +} + +like(get1('/?vary=x,y&xtra=1', 'x:2'), qr/MISS/, 'change second'); +like(get1('/?vary=x,y&xtra=1', 'x:2'), qr/HIT/, 'change second cached'); + +$t->stop(); +$t->run(); + +# reset c->body_start when loading a secondary key variant + +# before 1.19.3, it was loaded using a variant stored with a main key +# triggering "cache file .. has too long header" critical errors + +like(get1('/?vary=x,y', 'x:1'), qr/HIT/, 'cold first'); + +TODO: { +local $TODO = 'not yet' unless $t->has_version('1.19.3'); + +like(get1('/?vary=x,y&xtra=1', 'x:2'), qr/HIT/, 'cold second'); + +} + +$t->stop(); + +TODO: { +local $TODO = 'not yet' unless $t->has_version('1.19.3'); + +like(`grep -F '[crit]' ${\($t->testdir())}/error.log`, qr/^$/s, 'no crit'); + +} + ############################################################################### sub get { @@ -261,4 +307,15 @@ EOF } +sub get1 { + my ($url, $extra) = @_; + return http(<