send_email
matcher
The send_email
matcher is used to check if an email with the given parameters has been sent inside the expectation block.
NOTE: This matcher implies that the example(s) actually send email(s) using the test adapter, and not scheduled as a job to be sent in the background later.
To have an email sent in tests make sure:
ActionMailer
performs deliveries -Rails.application.config.action_mailer.perform_deliveries = true
- If the email is sent asynchronously (with
.deliver_later
call), ActiveJob uses the inline adapter -Rails.application.config.active_job.queue_adapter = :inline
- ActionMailer uses the test adapter -
Rails.application.config.action_mailer.delivery_method = :test
If you want to check an email has been scheduled as a job, use the have_enqueued_email
matcher.
Checking email sent with the given multiple parameters
Given a file named "spec/mailers/notifications_mailer_spec.rb" with:
require "rails_helper"
RSpec.describe NotificationsMailer do
it "checks email sending by multiple params" do
expect {
NotificationsMailer.signup.deliver_now
}.to send_email(
from: 'from@example.com',
to: 'to@example.org',
subject: 'Signup'
)
end
end
When I run rspec spec/mailers/notifications_mailer_spec.rb
Then the examples should all pass.
Checking email sent with matching parameters
Given a file named "spec/mailers/notifications_mailer_spec.rb" with:
require "rails_helper"
RSpec.describe NotificationsMailer do
it "checks email sending by one param only" do
expect {
NotificationsMailer.signup.deliver_now
}.to send_email(
to: 'to@example.org'
)
end
end
When I run rspec spec/mailers/notifications_mailer_spec.rb
Then the examples should all pass.
Checking email not sent with the given parameters
Given a file named "spec/mailers/notifications_mailer_spec.rb" with:
require "rails_helper"
RSpec.describe NotificationsMailer do
it "checks email not sent" do
expect {
NotificationsMailer.signup.deliver_now
}.to_not send_email(
to: 'no@example.org'
)
end
end
When I run rspec spec/mailers/notifications_mailer_spec.rb
Then the examples should all pass.