From 4fd84aae90e940b1a33429c4c5f9872fec777b80 Mon Sep 17 00:00:00 2001 From: Jeremy Kemper Date: Sun, 18 Feb 2007 00:47:18 +0000 Subject: [PATCH] Etagging ignores appended and block responses. git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@6160 5ecf4fe2-1ee6-0310-87b1-e25e094e27de --- actionpack/lib/action_controller/base.rb | 20 +++++++++++--------- actionpack/test/controller/render_test.rb | 10 +++++----- 2 files changed, 16 insertions(+), 14 deletions(-) diff --git a/actionpack/lib/action_controller/base.rb b/actionpack/lib/action_controller/base.rb index e870dc30455b9..524d11de50000 100755 --- a/actionpack/lib/action_controller/base.rb +++ b/actionpack/lib/action_controller/base.rb @@ -7,7 +7,7 @@ require 'action_controller/status_codes' require 'drb' require 'set' -require 'md5' +require 'digest/md5' module ActionController #:nodoc: class ActionControllerError < StandardError #:nodoc: @@ -876,17 +876,19 @@ def render_text(text = nil, status = nil, append_response = false) #:nodoc: response.body << text else response.body = text - end - if response.headers['Status'] == "200 OK" && response.body.size > 0 - response.headers['Etag'] = "\"#{MD5.new(text).to_s}\"" - - if request.headers['HTTP_IF_NONE_MATCH'] == response.headers['Etag'] - response.headers['Status'] = "304 Not Modified" - response.body = '' + if text.is_a?(String) + if response.headers['Status'][0..2] == '200' && !response.body.empty? + response.headers['Etag'] = %("#{Digest::MD5.hexdigest(text)}") + + if request.headers['HTTP_IF_NONE_MATCH'] == response.headers['Etag'] + response.headers['Status'] = "304 Not Modified" + response.body = '' + end + end end end - + response.body end diff --git a/actionpack/test/controller/render_test.rb b/actionpack/test/controller/render_test.rb index fc40d0ae7ff2b..dd5255ce35f18 100644 --- a/actionpack/test/controller/render_test.rb +++ b/actionpack/test/controller/render_test.rb @@ -311,13 +311,13 @@ def test_render_against_etag_request_should_200_when_no_match def test_render_with_etag get :render_hello_world_from_variable - expected_etag = "\"#{MD5.new("hello david").to_s}\"" + expected_etag = etag_for('hello david') assert_equal expected_etag, @response.headers['Etag'] - + @request.headers["HTTP_IF_NONE_MATCH"] = expected_etag get :render_hello_world_from_variable assert_equal "304 Not Modified", @response.headers['Status'] - + @request.headers["HTTP_IF_NONE_MATCH"] = "\"diftag\"" get :render_hello_world_from_variable assert_equal "200 OK", @response.headers['Status'] @@ -332,8 +332,8 @@ def render_with_404_shouldnt_have_etag def assert_deprecated_render(&block) assert_deprecated(/render/, &block) end - + def etag_for(text) - "\"#{MD5.new(text).to_s}\"" + %("#{Digest::MD5.hexdigest(text)}") end end