ご閲覧いただきまして、誠にありがとうございます。
Railsでユーザー登録型のアプリケーションを作っています。
現在、取り組んでいるのが、12時間に1回、ユーザー全員に対してお知らせメールを通知するシステムです。
gem whenever
をcron管理に使用しているのですが
なぜか、tasks配下でMailerが機能しなくて困っています。
エラー
cron.log
にも、サーバー側にもエラーは表示されていません。
config/environments/development.rb
Ruby
1 config.action_mailer.raise_delivery_errors = true
上記のようにメールエラーは表示されるように設定しています。
ソースコード
apps/mailers/user_mailer.rb
Ruby
1class UserMailer < ApplicationMailer 2 default from: "noreply@xxx.com" 3 4 def notify_user(user) 5 @user = user 6 mail( 7 subject: "時間になりました!", 8 to: @user.email, 9 ) 10 end 11end
apps/views/user_mailer/notify_user.text.erb
Ruby
1<p>時間になりました!</p>
config/schedule.rb
Ruby
1require File.expand_path(File.dirname(__FILE__) + "/environment") 2set :environment, Rails.env.to_sym 3set :output, "#{Rails.root.to_s}/log/cron.log" 4 5every 12.hours do 6 begin 7 rake "notify:user" 8 rescue => e 9 raise e 10 end 11end
lib/tasks/notify.rake
Ruby
1namespace :notify do 2 task :user => :environment do 3 notify_user = NotifyUser.new 4 notify_user.message 5 end 6end
lib/tasks/notify_user.rb
Ruby
1class NotifyUser 2 def message 3 @users = User.all 4 5 @users.each do |user| 6 @user = user 7 puts "メールスタート" 8 puts @user 9 UserMailer.notify_user(user).deliver_later 10 puts "メール終了" 11 end 12 end 13end
試してみたこと
- 現在、「メールスタート」、@user情報、「メール終了」は、cron.logに表示されておりますので、cron自体は機能しています
- userのメールアドレスが入っていないのかも確認しましたが、確かに入っていました
すみませんが、お知恵を拝借させていただければと思います。
tasks配下ではMailer設定できないのでしょうか?
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。