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:
parent
c0a2d9e671
commit
99527af38a
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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" }
|
||||||
|
|
Loading…
Reference in New Issue