Merge pull request #1105 from pagespeed/oschaaf-trunk-tracking-issue-1064
vary-header: Emit a single vary header in the IPRO flow
This commit is contained in:
@@ -576,6 +576,10 @@ ngx_int_t copy_response_headers_to_ngx(
|
|||||||
continue;
|
continue;
|
||||||
} else if (STR_EQ_LITERAL(name, "Transfer-Encoding")) {
|
} else if (STR_EQ_LITERAL(name, "Transfer-Encoding")) {
|
||||||
continue;
|
continue;
|
||||||
|
} else if (STR_EQ_LITERAL(name, "Vary") && value.len
|
||||||
|
&& STR_EQ_LITERAL(value, "Accept-Encoding")) {
|
||||||
|
ps_request_ctx_t* ctx = ps_get_request_context(r);
|
||||||
|
ctx->psol_vary_accept_only = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
ngx_table_elt_t* header = static_cast<ngx_table_elt_t*>(
|
ngx_table_elt_t* header = static_cast<ngx_table_elt_t*>(
|
||||||
@@ -1281,6 +1285,7 @@ ngx_int_t ps_decline_request(ngx_http_request_t* r) {
|
|||||||
ctx->driver->Cleanup();
|
ctx->driver->Cleanup();
|
||||||
ctx->driver = NULL;
|
ctx->driver = NULL;
|
||||||
ctx->location_field_set = false;
|
ctx->location_field_set = false;
|
||||||
|
ctx->psol_vary_accept_only = false;
|
||||||
|
|
||||||
// re init ctx
|
// re init ctx
|
||||||
ctx->html_rewrite = true;
|
ctx->html_rewrite = true;
|
||||||
@@ -1851,6 +1856,7 @@ ngx_int_t ps_resource_handler(ngx_http_request_t* r,
|
|||||||
ctx->recorder = NULL;
|
ctx->recorder = NULL;
|
||||||
ctx->url_string = url_string;
|
ctx->url_string = url_string;
|
||||||
ctx->location_field_set = false;
|
ctx->location_field_set = false;
|
||||||
|
ctx->psol_vary_accept_only = false;
|
||||||
|
|
||||||
// Set up a cleanup handler on the request.
|
// Set up a cleanup handler on the request.
|
||||||
ngx_http_cleanup_t* cleanup = ngx_http_cleanup_add(r, 0);
|
ngx_http_cleanup_t* cleanup = ngx_http_cleanup_add(r, 0);
|
||||||
@@ -2168,6 +2174,13 @@ ngx_int_t ps_etag_header_filter(ngx_http_request_t* r) {
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ps_request_ctx_t* ctx = ps_get_request_context(r);
|
||||||
|
#if (NGX_HTTP_GZIP)
|
||||||
|
if (ctx && ctx->psol_vary_accept_only) {
|
||||||
|
r->gzip_vary = 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
return ngx_http_ef_next_header_filter(r);
|
return ngx_http_ef_next_header_filter(r);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -108,6 +108,7 @@ typedef struct {
|
|||||||
// we should mirror that when we write it back. nginx may absolutify
|
// we should mirror that when we write it back. nginx may absolutify
|
||||||
// Location: headers that start with '/' without regarding X-Forwarded-Proto.
|
// Location: headers that start with '/' without regarding X-Forwarded-Proto.
|
||||||
bool location_field_set;
|
bool location_field_set;
|
||||||
|
bool psol_vary_accept_only;
|
||||||
} ps_request_ctx_t;
|
} ps_request_ctx_t;
|
||||||
|
|
||||||
ps_request_ctx_t* ps_get_request_context(ngx_http_request_t* r);
|
ps_request_ctx_t* ps_get_request_context(ngx_http_request_t* r);
|
||||||
|
|||||||
@@ -1268,6 +1268,22 @@ OUT=$(http_proxy=$SECONDARY_HOSTNAME $WGET_DUMP -O /dev/null -S $URL 2>&1) || tr
|
|||||||
# We ignored the exit code, check if we got a 404 response.
|
# We ignored the exit code, check if we got a 404 response.
|
||||||
check_from "$OUT" fgrep -qi '404'
|
check_from "$OUT" fgrep -qi '404'
|
||||||
|
|
||||||
|
start_test Single Vary: Accept-Encoding header in IPRO flow
|
||||||
|
URL=http://psol-vary.example.com/mod_pagespeed_example/styles/index_style.css
|
||||||
|
OUT=$(http_proxy=$SECONDARY_HOSTNAME $WGET_DUMP -O /dev/null -S $URL 2>&1)
|
||||||
|
# First hit will be recorded and passed on untouched
|
||||||
|
MATCHES=$(echo "$OUT" | grep -c "Vary: Accept-Encoding") || true
|
||||||
|
check [ $MATCHES -eq 1 ]
|
||||||
|
|
||||||
|
# Fetch until we get a fully optimized response
|
||||||
|
http_proxy=$SECONDARY_HOSTNAME \
|
||||||
|
fetch_until $URL "fgrep -c W/\"PSA" 1 --save-headers
|
||||||
|
|
||||||
|
# Test the optimized response.
|
||||||
|
OUT=$(http_proxy=$SECONDARY_HOSTNAME $WGET_DUMP -O /dev/null -S $URL 2>&1)
|
||||||
|
MATCHES=$(echo "$OUT" | grep -c "Vary: Accept-Encoding") || true
|
||||||
|
check [ $MATCHES -eq 1 ]
|
||||||
|
|
||||||
start_test Shutting down.
|
start_test Shutting down.
|
||||||
|
|
||||||
# Fire up some heavy load if ab is available to test a stressed shutdown
|
# Fire up some heavy load if ab is available to test a stressed shutdown
|
||||||
|
|||||||
@@ -1508,6 +1508,14 @@ http {
|
|||||||
pagespeed GlobalAdminDomains
|
pagespeed GlobalAdminDomains
|
||||||
Allow everything-explicitly-allowed.example.com;
|
Allow everything-explicitly-allowed.example.com;
|
||||||
}
|
}
|
||||||
|
server {
|
||||||
|
listen @@SECONDARY_PORT@@;
|
||||||
|
listen [::]:@@SECONDARY_PORT@@;
|
||||||
|
server_name psol-vary.example.com;
|
||||||
|
pagespeed on;
|
||||||
|
pagespeed InPlaceResourceOptimization on;
|
||||||
|
pagespeed FileCachePath "@@FILE_CACHE@@";
|
||||||
|
}
|
||||||
|
|
||||||
server {
|
server {
|
||||||
listen @@PRIMARY_PORT@@;
|
listen @@PRIMARY_PORT@@;
|
||||||
|
|||||||
Reference in New Issue
Block a user