Sending mail with Rails 3 in development environment

34,364

Solution 1

Well I have resolved the issue, but quite why this works and the other methods did not, I don't know.

The solution was to create an initialiser in config/initialisers/setup_mail.rb containing the following

if Rails.env != 'test'
  email_settings = YAML::load(File.open("#{Rails.root.to_s}/config/email.yml"))
  ActionMailer::Base.smtp_settings = email_settings[Rails.env] unless email_settings[Rails.env].nil?
end

I then added config/email.yml containing the details of the dev and production email accounts

development:
  :address: smtp.gmail.com
  :port: 587
  :authentication: plain
  :user_name: xxx
  :password: yyy
  :enable_starttls_auto: true
production:
  :address: smtp.gmail.com
  :port: 587
  :authentication: plain
  :user_name: xxx
  :password: yyy
  :enable_starttls_auto: true

Like I say, no idea why, but this seemed to do the trick. Thanks all for the pointers

Solution 2

I have the following in config/environments/development.rb

config.action_mailer.raise_delivery_errors = true
config.action_mailer.perform_deliveries = true

The actual mail-configuration, config.actionmailer.* i have placed in config\application.rb.

Hope this helps :)

Solution 3

Try using 'sendmail' instead of 'smtp'.

ActionMailer::Base.delivery_method = :sendmail
ActionMailer::Base.sendmail_settings = {
  :address              => "smtp.gmail.com",
  :port                 => "587",
  :domain               => "gmail.com",
  :user_name            => "[email protected]",
  :password             => "yyy",
  :authentication       => "plain",
  :enable_starttls_auto => true
}

Solution 4

Three things.

First, the port is an integer and does not need quotes, as in your first example. (But I think a string should still work.)

Second, don't forget to restart your server each time you modify this (or any) initializer file. This could explain why you didn't see an error after adding:

config.action_mailer.raise_delivery_errors = true

Without having that error message, it's hard to determine why the mail wasn't going but now is. One possiblity is your use of double quotes around the password. If you were using a strong password and had a token in your password that wasn't escaped it could have been reinterpreted. (i.e. "P@ssw\0rd" would become P@ssrd). For just this reason, I always use single quotes in my code unless I specifically need the syntactic sugar.

Lastly, enable_starttls_auto: true is the default and unnecessary.

Solution 5

ActionMailer::Base.delivery_method = :sendmail
and
config.action_mailer.perform_deliveries = true

were the two necessary steps that got me over this issue

Share:
34,364
Addsy
Author by

Addsy

Updated on July 09, 2022

Comments

  • Addsy
    Addsy almost 2 years

    I'm sure this has been asked a million times before but I can't find anything that works for me so I'm asking again!

    I just need a way of sending emails using ActionMailer in rails 3. I have followed numerous tutorials including the Railscasts tutorial on the new ActionMailer and I can see the mails being generated but I don't receive them.

    I have tried a bunch of different ways but they generally amount to configuring the following settings

    ActionMailer::Base.delivery_method = :smtp
    
    ActionMailer::Base.smtp_settings = {
      :address              => "smtp.gmail.com",
      :port                 => "587",
      :domain               => "gmail.com",
      :user_name            => "[email protected]",
      :password             => "yyy",
      :authentication       => "plain",
      :enable_starttls_auto => true
    }
    

    I have tried the above code (with valid gmail details of course) in my config/environment.rb, config/environments/development.rb and currently have it in its own initialiser config/initialisers/setup_mail.rb

    I have also tried with a few different smtp servers including Gmail and Sendgrid, adjusting the smtp settings accordingly but still nothing. I can see the mail in the terminal and the development log and that's it.

    Does anyone know of any other gotcha's that I may have missed that need to be setup for ActionMailer to work? Failing that is there a way of getting more information about why the mails aren't being sent? I have

    config.action_mailer.raise_delivery_errors = true
    

    set in my config/development.rb but the development log still just shows the same as I see in the terminal.

    For what it's worth, I am developing on a Ubuntu 10.04 laptop just in case there's any specific setup needed for that.

    Many thanks

  • Addsy
    Addsy over 13 years
    Thanks for the suggestion. Unfortunately I have just tried it and I get exactly the same behaviour with sendmail
  • Addsy
    Addsy over 13 years
    Thanks guys, unfortunately they were both already there. Thanks for the suggestions tho
  • nathanvda
    nathanvda over 13 years
    In that case you should be getting errors why it is not working. Correct?
  • Addsy
    Addsy over 13 years
    Hi nathanvda, sorry I only just saw your comment. Part of the issue was that I wasn't getting any errors. I have posted below as to how I fixed the issue, tho to be quite honest I don't see any reason as to why the method below should work and none of the others did.
  • LondonGuy
    LondonGuy over 12 years
    This worked for and nothing else did. Quite confused as to why it works but thanks. Hours of googling has come to an end. I should have come here to begin with.
  • Matt McClure
    Matt McClure almost 12 years
    I looked around for a good solution to this for a while and this is exactly what I should have been doing in the first place. Thanks!
  • Scott Fister
    Scott Fister over 10 years
    perform_deliveries did it - you also need to restart the server.