aboutsummaryrefslogtreecommitdiffstats
path: root/actionmailer/test/message_delivery_test.rb
blob: 49b63d7675fc608966dadb53350fa637ad0b7592 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
# encoding: utf-8
gem 'activejob'
require 'active_job'
require 'abstract_unit'
require 'minitest/mock'
require_relative 'mailers/delayed_mailer'

class MessageDeliveryTest < ActiveSupport::TestCase

  setup do
    @previous_logger = ActiveJob::Base.logger
    @previous_delivery_method = ActionMailer::Base.delivery_method
    ActionMailer::Base.delivery_method = :test
    ActiveJob::Base.logger = Logger.new(nil)
    @mail = DelayedMailer.test_message(1, 2, 3)
    ActionMailer::Base.deliveries.clear
  end

  teardown do
    ActiveJob::Base.logger = @previous_logger
    ActionMailer::Base.delivery_method = @previous_delivery_method
  end

  test 'should have a message' do
    assert @mail.message
  end

  test 'its message should be a Mail::Message' do
    assert_equal Mail::Message , @mail.message.class
  end

  test 'should respond to .deliver' do
    assert_respond_to @mail, :deliver
  end

  test 'should respond to .deliver!' do
    assert_respond_to @mail, :deliver!
  end

  test '.deliver is deprecated' do
    assert_deprecated do
      @mail.deliver
    end
  end
  test '.deliver! is deprecated' do
    assert_deprecated do
      @mail.deliver!
    end
  end

  test 'should respond to .deliver_later' do
    assert_respond_to @mail, :deliver_later
  end

  test 'should respond to .deliver_later!' do
    assert_respond_to @mail, :deliver_later!
  end

  test 'should respond to .deliver_now' do
    assert_respond_to @mail, :deliver_now
  end

  test 'should respond to .deliver_now!' do
    assert_respond_to @mail, :deliver_now!
  end

  test 'should enqueue and run correctly in activejob' do
    @mail.deliver_later!
    assert_equal 1, ActionMailer::Base.deliveries.size
  ensure
    ActionMailer::Base.deliveries.clear
  end

  test 'should enqueue the email with :deliver delivery method' do
    ret = ActionMailer::DeliveryJob.stub :enqueue, ->(*args){ args } do
      @mail.deliver_later
    end
    assert_equal ['DelayedMailer', 'test_message', 'deliver_now', 1, 2, 3], ret
  end

  test 'should enqueue the email with :deliver! delivery method' do
    ret = ActionMailer::DeliveryJob.stub :enqueue, ->(*args){ args } do
      @mail.deliver_later!
    end
    assert_equal ['DelayedMailer', 'test_message', 'deliver_now!', 1, 2, 3], ret
  end

  test 'should enqueue a delivery with a delay' do
    ret = ActionMailer::DeliveryJob.stub :enqueue_in, ->(*args){ args } do
      @mail.deliver_later in: 600
    end
    assert_equal [600, 'DelayedMailer', 'test_message', 'deliver_now', 1, 2, 3], ret
  end

  test 'should enqueue a delivery at a specific time' do
    later_time = Time.now.to_i + 3600
    ret = ActionMailer::DeliveryJob.stub :enqueue_at, ->(*args){ args } do
      @mail.deliver_later at: later_time
    end
    assert_equal [later_time, 'DelayedMailer', 'test_message', 'deliver_now', 1, 2, 3], ret
  end

end