diff options
author | MQuy <sugiacupit@gmail.com> | 2016-11-30 21:54:44 +0800 |
---|---|---|
committer | MQuy <sugiacupit@gmail.com> | 2016-11-30 22:18:14 +0800 |
commit | c4639b77378675f16c28660f43a23f2805ee6392 (patch) | |
tree | 3a6ceaec13a7f75340007b4aff9d9ecfc27ec5cc /actionmailer | |
parent | 162e889f16ceb47978fe9bc81ac0b46672f05ff0 (diff) | |
download | rails-c4639b77378675f16c28660f43a23f2805ee6392.tar.gz rails-c4639b77378675f16c28660f43a23f2805ee6392.tar.bz2 rails-c4639b77378675f16c28660f43a23f2805ee6392.zip |
allow context type when set body mail
Diffstat (limited to 'actionmailer')
-rw-r--r-- | actionmailer/lib/action_mailer/base.rb | 12 | ||||
-rw-r--r-- | actionmailer/test/base_test.rb | 5 |
2 files changed, 13 insertions, 4 deletions
diff --git a/actionmailer/lib/action_mailer/base.rb b/actionmailer/lib/action_mailer/base.rb index 1f5738bbab..2cb5c5514d 100644 --- a/actionmailer/lib/action_mailer/base.rb +++ b/actionmailer/lib/action_mailer/base.rb @@ -900,15 +900,19 @@ module ActionMailer yield(collector) collector.responses elsif headers[:body] - [{ - body: headers.delete(:body), - content_type: self.class.default[:content_type] || "text/plain" - }] + collect_responses_from_text(headers) else collect_responses_from_templates(headers) end end + def collect_responses_from_text(headers) + [{ + body: headers.delete(:body), + content_type: headers[:content_type] || self.class.default[:content_type] || "text/plain" + }] + end + def collect_responses_from_templates(headers) templates_path = headers[:template_path] || self.class.mailer_name templates_name = headers[:template_name] || action_name diff --git a/actionmailer/test/base_test.rb b/actionmailer/test/base_test.rb index 3bca69890d..76f558a961 100644 --- a/actionmailer/test/base_test.rb +++ b/actionmailer/test/base_test.rb @@ -140,6 +140,11 @@ class BaseTest < ActiveSupport::TestCase assert_equal("multipart/mixed", email.mime_type) end + test "set mime type to text/html when attachment is inclued and body is set" do + email = BaseMailer.attachment_with_content(body: "Hello there", content_type: "text/html") + assert_equal("text/html", email.mime_type) + end + test "adds the rendered template as part" do email = BaseMailer.attachment_with_content assert_equal(2, email.parts.length) |