1
0
mirror of https://github.com/meineerde/redmine.git synced 2025-10-17 17:01:01 +00:00

Fixed that test_email raises an error with #deliver_later (#26791).

git-svn-id: http://svn.redmine.org/redmine/trunk@17587 e93f8b46-1217-0410-a6f0-8f06a7374b81
This commit is contained in:
Jean-Philippe Lang 2018-10-06 16:07:45 +00:00
parent e159928e6b
commit 5533eeff23
3 changed files with 13 additions and 41 deletions

View File

@ -107,48 +107,11 @@ class Mailer < ActionMailer::Base
"method*, or 3. use a custom Active Job instead of #deliver_later."
else
args = 'Mailer', @action.to_s, delivery_method.to_s, *@args
DeliveryJob.set(options).perform_later(*args)
::ActionMailer::DeliveryJob.set(options).perform_later(*args)
end
end
end
class DeliveryJob < ActionMailer::DeliveryJob
module Arguments
extend ActiveJob::Arguments
extend self
private
def serialize_argument(argument)
# Ensure that ActiveRecord::Base objects are fully serialized for mail
# sending. This circumvents the globalid gem for this job.
if argument.is_a?(ActiveRecord::Base)
argument.to_yaml
else
super
end
end
def deserialize_argument(argument)
if argument.is_a?(ActiveRecord::Base)
argument
else
super
end
end
end
private
def serialize_arguments(serialized_args)
Arguments.serialize(serialized_args)
end
def deserialize_arguments(serialized_args)
Arguments.deserialize(serialized_args)
end
end
def process(action, *args)
user = args.shift
raise ArgumentError, "First argument has to be a user, was #{user.inspect}" unless user.is_a?(User)
@ -701,9 +664,9 @@ class Mailer < ActionMailer::Base
#
# Example:
# test_email => Mail::Message object
def test_email
def test_email(user)
@url = url_for(:controller => 'welcome')
mail :to => User.current.mail,
mail :to => user.mail,
:subject => 'Redmine test'
end
@ -712,7 +675,7 @@ class Mailer < ActionMailer::Base
# Example:
# Mailer.test_email(user).deliver => send an email to the given user
def self.test_email(user)
MultiMessage.new(:test_email).for(user)
MultiMessage.new(:test_email, user).for(user)
end
# Sends reminders to issue assignees

View File

@ -22,6 +22,9 @@ Rails.application.configure do
# The :test delivery method accumulates sent emails in the
# ActionMailer::Base.deliveries array.
config.action_mailer.delivery_method = :test
# Disable Async delivery
config.active_job.queue_adapter = :inline
# Disable request forgery protection in test environment.
config.action_controller.allow_forgery_protection = false

View File

@ -605,6 +605,12 @@ class MailerTest < ActiveSupport::TestCase
end
end
def test_test_email_later
user = User.find(1)
assert Mailer.test_email(user).deliver_later
assert_equal 1, ActionMailer::Base.deliveries.size
end
def test_reminders
Mailer.reminders(:days => 42)
assert_equal 1, ActionMailer::Base.deliveries.size