FIX: show rejected emails with unrecognized errors (#5026)

Although 407a23663d will send rejection
messages for unrecognized errors, sometimes processing the email will
raise an error which has a blank message.

This commit:

1. Shows rejected emails which have already been processed and contain
   a blank error in /admin/email/rejected

2. Replaces new blank error messages with the error type
This commit is contained in:
Leo McArdle 2017-08-04 15:20:44 +01:00 committed by Régis Hanol
parent c0a2d9e671
commit 99527af38a
3 changed files with 10 additions and 2 deletions

View File

@ -3,7 +3,7 @@ class IncomingEmail < ActiveRecord::Base
belongs_to :topic belongs_to :topic
belongs_to :post belongs_to :post
scope :errored, -> { where("NOT is_bounce AND LENGTH(COALESCE(error,'')) > 0") } scope :errored, -> { where("NOT is_bounce AND error IS NOT NULL") }
end end
# == Schema Information # == Schema Information

View File

@ -49,7 +49,9 @@ module Email
@incoming_email = create_incoming_email @incoming_email = create_incoming_email
process_internal process_internal
rescue => e rescue => e
@incoming_email.update_columns(error: e.to_s) if @incoming_email error = e.to_s
error = e.class.name if error.blank?
@incoming_email.update_columns(error: error) if @incoming_email
raise raise
end end
end end

View File

@ -69,6 +69,12 @@ describe Email::Receiver do
expect(IncomingEmail.last.is_bounce).to eq(true) expect(IncomingEmail.last.is_bounce).to eq(true)
end end
it "logs a blank error" do
Email::Receiver.any_instance.stubs(:process_internal).raises(RuntimeError, "")
process(:existing_user) rescue RuntimeError
expect(IncomingEmail.last.error).to eq("RuntimeError")
end
context "bounces to VERP" do context "bounces to VERP" do
let(:bounce_key) { "14b08c855160d67f2e0c2f8ef36e251e" } let(:bounce_key) { "14b08c855160d67f2e0c2f8ef36e251e" }