mirror of
https://github.com/rails/rails.git
synced 2022-11-09 12:12:34 -05:00
Ensure ActionMailer doesn't blow up when a two argument proc is set for the asset host
Signed-off-by: Michael Koziarski <michael@koziarski.com> [#1394 state:committed]
This commit is contained in:
parent
bda55f82c6
commit
dab78e55cf
3 changed files with 56 additions and 1 deletions
54
actionmailer/test/asset_host_test.rb
Normal file
54
actionmailer/test/asset_host_test.rb
Normal file
|
@ -0,0 +1,54 @@
|
||||||
|
require 'abstract_unit'
|
||||||
|
|
||||||
|
class AssetHostMailer < ActionMailer::Base
|
||||||
|
def email_with_asset(recipient)
|
||||||
|
recipients recipient
|
||||||
|
subject "testing email containing asset path while asset_host is set"
|
||||||
|
from "tester@example.com"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
class AssetHostTest < Test::Unit::TestCase
|
||||||
|
def setup
|
||||||
|
set_delivery_method :test
|
||||||
|
ActionMailer::Base.perform_deliveries = true
|
||||||
|
ActionMailer::Base.deliveries = []
|
||||||
|
|
||||||
|
@recipient = 'test@localhost'
|
||||||
|
end
|
||||||
|
|
||||||
|
def teardown
|
||||||
|
restore_delivery_method
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_asset_host_as_string
|
||||||
|
ActionController::Base.asset_host = "http://www.example.com"
|
||||||
|
mail = AssetHostMailer.deliver_email_with_asset(@recipient)
|
||||||
|
assert_equal "<img alt=\"Somelogo\" src=\"http://www.example.com/images/somelogo.png\" />", mail.body.strip
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_asset_host_as_one_arguement_proc
|
||||||
|
ActionController::Base.asset_host = Proc.new { |source|
|
||||||
|
if source.starts_with?('/images')
|
||||||
|
"http://images.example.com"
|
||||||
|
else
|
||||||
|
"http://assets.example.com"
|
||||||
|
end
|
||||||
|
}
|
||||||
|
mail = AssetHostMailer.deliver_email_with_asset(@recipient)
|
||||||
|
assert_equal "<img alt=\"Somelogo\" src=\"http://images.example.com/images/somelogo.png\" />", mail.body.strip
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_asset_host_as_two_arguement_proc
|
||||||
|
ActionController::Base.asset_host = Proc.new {|source,request|
|
||||||
|
if request && request.ssl?
|
||||||
|
"https://www.example.com"
|
||||||
|
else
|
||||||
|
"http://www.example.com"
|
||||||
|
end
|
||||||
|
}
|
||||||
|
mail = nil
|
||||||
|
assert_nothing_raised { mail = AssetHostMailer.deliver_email_with_asset(@recipient) }
|
||||||
|
assert_equal "<img alt=\"Somelogo\" src=\"http://www.example.com/images/somelogo.png\" />", mail.body.strip
|
||||||
|
end
|
||||||
|
end
|
1
actionmailer/test/fixtures/asset_host_mailer/email_with_asset.html.erb
vendored
Normal file
1
actionmailer/test/fixtures/asset_host_mailer/email_with_asset.html.erb
vendored
Normal file
|
@ -0,0 +1 @@
|
||||||
|
<%= image_tag "somelogo.png" %>
|
|
@ -574,7 +574,7 @@ module ActionView
|
||||||
|
|
||||||
private
|
private
|
||||||
def request
|
def request
|
||||||
@controller.request
|
request? && @controller.request
|
||||||
end
|
end
|
||||||
|
|
||||||
def request?
|
def request?
|
||||||
|
|
Loading…
Reference in a new issue