DEV: Remove the use of stubs on `Rails.logger` in our test suite.
This commit is contained in:
parent
9b01e2b855
commit
f26804394a
|
@ -62,17 +62,25 @@ module DiscourseHub
|
||||||
}.merge(connect_opts)
|
}.merge(connect_opts)
|
||||||
)
|
)
|
||||||
|
|
||||||
if response.status != 200
|
if (status = response.status) != 200
|
||||||
Rails.logger.warn("Discourse Hub (#{hub_base_url}#{rel_url}) returned a bad status #{response.status}.")
|
Rails.logger.warn(response_status_log_message(rel_url, status))
|
||||||
end
|
end
|
||||||
|
|
||||||
begin
|
begin
|
||||||
JSON.parse(response.body)
|
JSON.parse(response.body)
|
||||||
rescue JSON::ParserError
|
rescue JSON::ParserError
|
||||||
Rails.logger.error("Discourse Hub returned a bad response body: " + response.body)
|
Rails.logger.error(response_body_log_message(response.body))
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def self.response_status_log_message(rel_url, status)
|
||||||
|
"Discourse Hub (#{hub_base_url}#{rel_url}) returned a bad status #{status}."
|
||||||
|
end
|
||||||
|
|
||||||
|
def self.response_body_log_message(body)
|
||||||
|
"Discourse Hub returned a bad response body: #{body}"
|
||||||
|
end
|
||||||
|
|
||||||
def self.connect_opts(params = {})
|
def self.connect_opts(params = {})
|
||||||
params.delete(:connect_opts)&.except(:body, :headers, :query) || {}
|
params.delete(:connect_opts)&.except(:body, :headers, :query) || {}
|
||||||
end
|
end
|
||||||
|
|
|
@ -77,23 +77,28 @@ describe DiscourseHub do
|
||||||
end
|
end
|
||||||
|
|
||||||
describe '.collection_action' do
|
describe '.collection_action' do
|
||||||
|
before do
|
||||||
it 'should log a warning if status is not 200' do
|
@orig_logger = Rails.logger
|
||||||
stub_request(:get, (ENV['HUB_BASE_URL'] || "http://local.hub:3000/api")).
|
Rails.logger = @fake_logger = FakeLogger.new
|
||||||
to_return(status: 500, body: "", headers: {})
|
|
||||||
|
|
||||||
Rails.logger.expects(:warn)
|
|
||||||
|
|
||||||
DiscourseHub.collection_action(:get, "")
|
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'should log an error if response is invalid JSON' do
|
after do
|
||||||
stub_request(:get, (ENV['HUB_BASE_URL'] || "http://local.hub:3000/api")).
|
Rails.logger = @orig_logger
|
||||||
to_return(status: 200, body: "this is not valid JSON", headers: {})
|
end
|
||||||
|
|
||||||
Rails.logger.expects(:error)
|
it 'should log correctly on error' do
|
||||||
|
stub_request(:get, (ENV['HUB_BASE_URL'] || "http://local.hub:3000/api/test")).
|
||||||
|
to_return(status: 500, body: "", headers: {})
|
||||||
|
|
||||||
DiscourseHub.collection_action(:get, "")
|
DiscourseHub.collection_action(:get, '/test')
|
||||||
|
|
||||||
|
expect(Rails.logger.warnings).to eq([
|
||||||
|
DiscourseHub.response_status_log_message('/test', 500),
|
||||||
|
])
|
||||||
|
|
||||||
|
expect(Rails.logger.errors).to eq([
|
||||||
|
DiscourseHub.response_body_log_message("")
|
||||||
|
])
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -275,15 +275,6 @@ describe Discourse do
|
||||||
end
|
end
|
||||||
|
|
||||||
context '#deprecate' do
|
context '#deprecate' do
|
||||||
|
|
||||||
class FakeLogger
|
|
||||||
attr_reader :warnings
|
|
||||||
def warn(m)
|
|
||||||
@warnings ||= []
|
|
||||||
@warnings << m
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
def old_method(m)
|
def old_method(m)
|
||||||
Discourse.deprecate(m)
|
Discourse.deprecate(m)
|
||||||
end
|
end
|
||||||
|
@ -307,7 +298,7 @@ describe Discourse do
|
||||||
expect(old_method_caller(k)).to include("discourse_spec")
|
expect(old_method_caller(k)).to include("discourse_spec")
|
||||||
expect(old_method_caller(k)).to include(k)
|
expect(old_method_caller(k)).to include(k)
|
||||||
|
|
||||||
expect(@fake_logger.warnings).to eq([old_method_caller(k)])
|
expect(Rails.logger.warnings).to eq([old_method_caller(k)])
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -103,14 +103,27 @@ describe Email::Processor do
|
||||||
let(:mail2) { "From: #{from}\nTo: foo@foo.com\nSubject: BAR BAR\n\nBar bar bar bar?" }
|
let(:mail2) { "From: #{from}\nTo: foo@foo.com\nSubject: BAR BAR\n\nBar bar bar bar?" }
|
||||||
|
|
||||||
it "sends a rejection email on an unrecognized error" do
|
it "sends a rejection email on an unrecognized error" do
|
||||||
Email::Processor.any_instance.stubs(:can_send_rejection_email?).returns(true)
|
begin
|
||||||
Email::Receiver.any_instance.stubs(:process_internal).raises("boom")
|
@orig_logger = Rails.logger
|
||||||
Rails.logger.expects(:error)
|
Rails.logger = @fake_logger = FakeLogger.new
|
||||||
|
|
||||||
Email::Processor.process!(mail)
|
Email::Processor.any_instance.stubs(:can_send_rejection_email?).returns(true)
|
||||||
expect(IncomingEmail.last.error).to eq("boom")
|
Email::Receiver.any_instance.stubs(:process_internal).raises("boom")
|
||||||
expect(IncomingEmail.last.rejection_message).to be_present
|
|
||||||
expect(EmailLog.last.email_type).to eq("email_reject_unrecognized_error")
|
Email::Processor.process!(mail)
|
||||||
|
|
||||||
|
errors = Rails.logger.errors
|
||||||
|
expect(errors.size).to eq(1)
|
||||||
|
expect(errors.first).to include("boom")
|
||||||
|
|
||||||
|
incoming_email = IncomingEmail.last
|
||||||
|
expect(incoming_email.error).to eq("boom")
|
||||||
|
expect(incoming_email.rejection_message).to be_present
|
||||||
|
|
||||||
|
expect(EmailLog.last.email_type).to eq("email_reject_unrecognized_error")
|
||||||
|
ensure
|
||||||
|
Rails.logger = @orig_logger
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
it "sends more than one rejection email per day" do
|
it "sends more than one rejection email per day" do
|
||||||
|
|
|
@ -814,18 +814,27 @@ describe Report do
|
||||||
end
|
end
|
||||||
|
|
||||||
describe "unexpected error on report initialization" do
|
describe "unexpected error on report initialization" do
|
||||||
|
before do
|
||||||
|
@orig_logger = Rails.logger
|
||||||
|
Rails.logger = @fake_logger = FakeLogger.new
|
||||||
|
end
|
||||||
|
|
||||||
|
after do
|
||||||
|
Rails.logger = @orig_logger
|
||||||
|
end
|
||||||
|
|
||||||
it "returns no report" do
|
it "returns no report" do
|
||||||
class ReportInitError < StandardError; end
|
class ReportInitError < StandardError; end
|
||||||
|
|
||||||
Report.stubs(:new).raises(ReportInitError.new("x"))
|
Report.stubs(:new).raises(ReportInitError.new("x"))
|
||||||
|
|
||||||
Rails.logger.expects(:error)
|
|
||||||
.with('Couldn’t create report `signups`: <ReportInitError x>')
|
|
||||||
.once
|
|
||||||
|
|
||||||
report = Report.find('signups')
|
report = Report.find('signups')
|
||||||
|
|
||||||
expect(report).to be_nil
|
expect(report).to be_nil
|
||||||
|
|
||||||
|
expect(Rails.logger.errors).to eq([
|
||||||
|
'Couldn’t create report `signups`: <ReportInitError x>'
|
||||||
|
])
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,16 @@
|
||||||
|
class FakeLogger
|
||||||
|
attr_reader :warnings, :errors
|
||||||
|
|
||||||
|
def initialize
|
||||||
|
@warnings = []
|
||||||
|
@errors = []
|
||||||
|
end
|
||||||
|
|
||||||
|
def warn(message)
|
||||||
|
@warnings << message
|
||||||
|
end
|
||||||
|
|
||||||
|
def error(message)
|
||||||
|
@errors << message
|
||||||
|
end
|
||||||
|
end
|
Loading…
Reference in New Issue