aboutsummaryrefslogtreecommitdiffstats
path: root/actionpack/test/dispatch
diff options
context:
space:
mode:
authorJeremy Kemper <jeremykemper@gmail.com>2014-08-24 14:38:12 -0700
committerJeremy Kemper <jeremykemper@gmail.com>2014-08-24 14:38:12 -0700
commitae66fda444218452dc6d029841190d3a6d17e7a4 (patch)
tree171f8136b9693d19db0a6478c050a558ca25c58f /actionpack/test/dispatch
parentcb62f922589c724deafc6e6dbe3ffb69c5f7c25e (diff)
parent8e31fa3b72892f7421b85b5a79d71a2d726ccddd (diff)
downloadrails-ae66fda444218452dc6d029841190d3a6d17e7a4.tar.gz
rails-ae66fda444218452dc6d029841190d3a6d17e7a4.tar.bz2
rails-ae66fda444218452dc6d029841190d3a6d17e7a4.zip
Merge pull request #16616 from schneems/schneems/jeremy-comments
Address comments on Gzip implementation
Diffstat (limited to 'actionpack/test/dispatch')
-rw-r--r--actionpack/test/dispatch/static_test.rb26
1 files changed, 24 insertions, 2 deletions
diff --git a/actionpack/test/dispatch/static_test.rb b/actionpack/test/dispatch/static_test.rb
index f4b3a8cb93..97affc7b21 100644
--- a/actionpack/test/dispatch/static_test.rb
+++ b/actionpack/test/dispatch/static_test.rb
@@ -115,8 +115,30 @@ module StaticTests
assert_equal 'Accept-Encoding', response.headers["Vary"]
assert_equal 'gzip', response.headers["Content-Encoding"]
+ response = get(file_name, 'HTTP_ACCEPT_ENCODING' => 'Gzip')
+ assert_gzip file_name, response
+
+ response = get(file_name, 'HTTP_ACCEPT_ENCODING' => 'GZIP')
+ assert_gzip file_name, response
+
response = get(file_name, 'HTTP_ACCEPT_ENCODING' => '')
- refute_equal 'gzip', response.headers["Content-Encoding"]
+ assert_not_equal 'gzip', response.headers["Content-Encoding"]
+ end
+
+ def test_does_not_modify_path_info
+ file_name = "/gzip/application-a71b3024f80aea3181c09774ca17e712.js"
+ env = {'PATH_INFO' => file_name, 'HTTP_ACCEPT_ENCODING' => 'gzip'}
+ @app.call(env)
+ assert_equal file_name, env['PATH_INFO']
+ end
+
+ def test_serves_gzip_with_propper_content_type_fallback
+ file_name = "/gzip/foo.zoo"
+ response = get(file_name, 'HTTP_ACCEPT_ENCODING' => 'gzip')
+ assert_gzip file_name, response
+
+ default_response = get(file_name) # no gzip
+ assert_equal default_response.headers['Content-Type'], response.headers['Content-Type']
end
# Windows doesn't allow \ / : * ? " < > | in filenames
@@ -147,7 +169,7 @@ module StaticTests
def assert_html(body, response)
assert_equal body, response.body
assert_equal "text/html", response.headers["Content-Type"]
- refute response.headers.key?("Vary")
+ assert_nil response.headers["Vary"]
end
def get(path, headers = {})