aboutsummaryrefslogtreecommitdiffstats
path: root/actionmailer
diff options
context:
space:
mode:
authorJoshua Peek <josh@joshpeek.com>2010-01-26 09:37:20 -0600
committerJoshua Peek <josh@joshpeek.com>2010-01-26 09:37:20 -0600
commit31b538df6457ba723668afc62e85056e3bca9413 (patch)
tree699e70c3e9a5fd311a59c09cc60bc7f7e640b7e3 /actionmailer
parent9f7190187cd755345557009a0b0ca9eec679b415 (diff)
downloadrails-31b538df6457ba723668afc62e85056e3bca9413.tar.gz
rails-31b538df6457ba723668afc62e85056e3bca9413.tar.bz2
rails-31b538df6457ba723668afc62e85056e3bca9413.zip
Failing AM test for legacy multipart alternative rendering
Diffstat (limited to 'actionmailer')
-rw-r--r--actionmailer/test/fixtures/test_mailer/multipart_alternative.html.erb1
-rw-r--r--actionmailer/test/fixtures/test_mailer/multipart_alternative.plain.erb1
-rw-r--r--actionmailer/test/old_base/mail_render_test.rb37
3 files changed, 39 insertions, 0 deletions
diff --git a/actionmailer/test/fixtures/test_mailer/multipart_alternative.html.erb b/actionmailer/test/fixtures/test_mailer/multipart_alternative.html.erb
new file mode 100644
index 0000000000..73ea14f82f
--- /dev/null
+++ b/actionmailer/test/fixtures/test_mailer/multipart_alternative.html.erb
@@ -0,0 +1 @@
+<strong>foo</strong> <%= @foo %> \ No newline at end of file
diff --git a/actionmailer/test/fixtures/test_mailer/multipart_alternative.plain.erb b/actionmailer/test/fixtures/test_mailer/multipart_alternative.plain.erb
new file mode 100644
index 0000000000..779fe4c1ea
--- /dev/null
+++ b/actionmailer/test/fixtures/test_mailer/multipart_alternative.plain.erb
@@ -0,0 +1 @@
+foo: <%= @foo %> \ No newline at end of file
diff --git a/actionmailer/test/old_base/mail_render_test.rb b/actionmailer/test/old_base/mail_render_test.rb
index 804200fd36..7ba55b1bd2 100644
--- a/actionmailer/test/old_base/mail_render_test.rb
+++ b/actionmailer/test/old_base/mail_render_test.rb
@@ -62,6 +62,33 @@ class RenderMailer < ActionMailer::Base
super
mailer_name "test_mailer"
end
+
+ def multipart_alternative
+ recipients 'test@localhost'
+ subject 'multipart/alternative'
+ from 'tester@example.com'
+
+ build_multipart_message(:foo => "bar")
+ end
+
+ private
+ def build_multipart_message(assigns = {})
+ content_type "multipart/alternative"
+
+ part "text/plain" do |p|
+ p.body = build_body_part('plain', assigns, :layout => false)
+ end
+
+ part "text/html" do |p|
+ p.body = build_body_part('html', assigns)
+ p.transfer_encoding = "base64"
+ end
+ end
+
+ def build_body_part(content_type, assigns, options = {})
+ render "#{template}.#{content_type}", :body => assigns
+ # render options.merge(:file => "#{template}.#{content_type}", :body => assigns)
+ end
end
class FirstMailer < ActionMailer::Base
@@ -129,6 +156,16 @@ class RenderHelperTest < Test::Unit::TestCase
mail = RenderMailer.no_instance_variable.deliver
assert_equal "Look, subject.nil? is true!", mail.body.to_s.strip
end
+
+ def test_legacy_multipart_alternative
+ mail = RenderMailer.multipart_alternative.deliver
+ assert_equal(2, email.parts.size)
+ assert_equal("multipart/alternative", email.mime_type)
+ assert_equal("text/plain", email.parts[0].mime_type)
+ assert_equal("foo: bar", email.parts[0].body.encoded)
+ assert_equal("text/html", email.parts[1].mime_type)
+ assert_equal("<strong>foo</strong> bar", email.parts[1].body.encoded)
+ end
end
class FirstSecondHelperTest < Test::Unit::TestCase