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
|