File: logger_delivery_spec.rb

package info (click to toggle)
ruby-mail 2.7.1%2Bdfsg1-2
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 5,732 kB
  • sloc: ruby: 71,628; makefile: 3
file content (90 lines) | stat: -rw-r--r-- 2,224 bytes parent folder | download | duplicates (4)
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
# encoding: utf-8
require 'spec_helper'
require 'logger'
require 'stringio'

describe "Logger Delivery Method" do
  before(:each) do
    # Reset all defaults back to original state
    Mail.defaults do
      delivery_method :smtp,
        :address              => "localhost",
        :port                 => 25,
        :domain               => 'localhost.localdomain',
        :user_name            => nil,
        :password             => nil,
        :authentication       => nil,
        :enable_starttls_auto => true
    end
  end

  let(:mail) do
    Mail.new do
      from    'dschrute@dm.com'
      to      'mscarn@dm.com'
      subject 'Beet Bandit'
    end
  end

  it "sends an email to $stdout with 'info' severity by default" do
    Mail.defaults do
      delivery_method :logger
    end

    logger = mail.delivery_method.logger

    expect(logger).to receive(:log).with(Logger::INFO) { mail.encoded }

    mail.deliver!
  end

  it "can be configured with a custom logger and severity" do
    custom_logger = double("custom_logger")

    Mail.defaults do
      delivery_method :logger, :logger => custom_logger, :severity => :debug
    end

    expect(custom_logger).to receive(:log).with(Logger::DEBUG) { mail.encoded }

    mail.deliver!
  end

  describe "sender and recipient validation" do
    it "should not raise errors if no sender is defined" do
      Mail.defaults do
        delivery_method :logger, :logger => Logger.new(StringIO.new)
      end

      mail = Mail.new do
        to "to@somemail.com"
        subject "Email with no sender"
        body "body"
      end

      expect(mail.smtp_envelope_from).to be_nil

      expect do
        mail.deliver
      end.to raise_error('SMTP From address may not be blank: nil')
    end

    it "should raise an error if no recipient if defined" do
      Mail.defaults do
        delivery_method :logger, :logger => Logger.new(StringIO.new)
      end

      mail = Mail.new do
        from "from@somemail.com"
        subject "Email with no recipient"
        body "body"
      end

      expect(mail.smtp_envelope_to).to eq([])

      expect do
        mail.deliver
      end.to raise_error('SMTP To address may not be blank: []')
    end
  end
end