mirror of https://github.com/rails/rails
Fixed that send_file would "remember" all the files sent by adding to the headers again and again #458 [bitsweat]
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@400 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
This commit is contained in:
parent
5f5b053ce8
commit
96e54780b3
|
@ -1,5 +1,7 @@
|
|||
*SVN*
|
||||
|
||||
* Fixed that send_file would "remember" all the files sent by adding to the headers again and again #458 [bitsweat]
|
||||
|
||||
* Fixed url rewriter confusion when the controller or action name was a substring of the controller_prefix or action_prefix
|
||||
|
||||
* Added conditional layouts like <tt>layout "weblog_standard", :except => :rss</tt> #452 [Marcel Molina]
|
||||
|
|
|
@ -178,11 +178,11 @@ module ActionController #:nodoc:
|
|||
DEFAULT_RENDER_STATUS_CODE = "200 OK"
|
||||
|
||||
DEFAULT_SEND_FILE_OPTIONS = {
|
||||
:type => 'application/octet_stream',
|
||||
:disposition => 'attachment',
|
||||
:type => 'application/octet_stream'.freeze,
|
||||
:disposition => 'attachment'.freeze,
|
||||
:stream => true,
|
||||
:buffer_size => 4096
|
||||
}
|
||||
}.freeze
|
||||
|
||||
# Determines whether the view has access to controller internals @request, @response, @session, and @template.
|
||||
# By default, it does.
|
||||
|
@ -664,7 +664,7 @@ module ActionController #:nodoc:
|
|||
raise ArgumentError, ":#{arg} option required" if options[arg].nil?
|
||||
end
|
||||
|
||||
disposition = options[:disposition] || 'attachment'
|
||||
disposition = options[:disposition].dup || 'attachment'
|
||||
disposition <<= %(; filename="#{options[:filename]}") if options[:filename]
|
||||
|
||||
@headers.update(
|
||||
|
|
|
@ -65,4 +65,28 @@ class SendFileTest < Test::Unit::TestCase
|
|||
assert_kind_of String, response.body
|
||||
assert_equal file_data, response.body
|
||||
end
|
||||
|
||||
# Test that send_file_headers! is setting the correct HTTP headers.
|
||||
def test_send_file_headers!
|
||||
options = {
|
||||
:length => 1,
|
||||
:type => 'type',
|
||||
:disposition => 'disposition',
|
||||
:filename => 'filename'
|
||||
}
|
||||
|
||||
# Do it a few times: the resulting headers should be identical
|
||||
# no matter how many times you send with the same options.
|
||||
# Test resolving Ticket #458.
|
||||
@controller.headers = {}
|
||||
@controller.send(:send_file_headers!, options)
|
||||
@controller.send(:send_file_headers!, options)
|
||||
@controller.send(:send_file_headers!, options)
|
||||
|
||||
h = @controller.headers
|
||||
assert_equal 1, h['Content-Length']
|
||||
assert_equal 'type', h['Content-Type']
|
||||
assert_equal 'disposition; filename="filename"', h['Content-Disposition']
|
||||
assert_equal 'binary', h['Content-Transfer-Encoding']
|
||||
end
|
||||
end
|
||||
|
|
Loading…
Reference in New Issue