Skip to content

Commit

Permalink
enable Rails 7 error reporter via Rollbar config
Browse files Browse the repository at this point in the history
  • Loading branch information
waltjones committed Aug 26, 2024
1 parent aa4ab80 commit c6d966f
Show file tree
Hide file tree
Showing 7 changed files with 117 additions and 2 deletions.
16 changes: 16 additions & 0 deletions lib/rollbar/configuration.rb
Original file line number Diff line number Diff line change
Expand Up @@ -76,6 +76,7 @@ class Configuration
:web_base,
:write_to_file
attr_reader :before_process,
:enable_rails_error_subscriber,
:logger_level,
:project_gem_paths,
:send_extra_frame_data,
Expand Down Expand Up @@ -104,6 +105,7 @@ def initialize
@disable_core_monkey_patch = false
@disable_rack_monkey_patch = false
@enable_error_context = true
@enable_rails_error_subscriber = false
@dj_threshold = 0
@dj_use_scoped_block = false
@async_skip_report_handler = nil
Expand Down Expand Up @@ -337,6 +339,20 @@ def send_extra_frame_data=(value)
@send_extra_frame_data = value
end

def enable_rails_error_subscriber=(enable)
return if !defined?(::Rails) || ::Rails::VERSION::MAJOR < 7

if @enable_rails_error_subscriber && !enable
::Rails.error.unsubscribe(Rollbar::ErrorSubscriber)
end

if !@enable_rails_error_subscriber && enable
::Rails.error.subscribe(Rollbar::ErrorSubscriber.new)
end

@enable_rails_error_subscriber = enable
end

# allow params to be read like a hash
def [](option)
send(option)
Expand Down
3 changes: 2 additions & 1 deletion lib/rollbar/exception_reporter.rb
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,8 @@ def report_exception_to_rollbar(env, exception)
end

def capture_uncaught?
Rollbar.configuration.capture_uncaught != false
Rollbar.configuration.capture_uncaught != false &&
!Rollbar.configuration.enable_rails_error_subscriber
end

def log_exception_message(exception)
Expand Down
8 changes: 8 additions & 0 deletions lib/rollbar/plugins/rails.rb
Original file line number Diff line number Diff line change
Expand Up @@ -79,3 +79,11 @@ def secure_headers_middleware?
Rollbar::Js::Frameworks::Rails.new.load(self)
end
end

Rollbar.plugins.define('rails-error-subscriber') do
dependency { defined?(Rails::VERSION) && Rails::VERSION::MAJOR >= 7 }

execute! do
require 'rollbar/plugins/rails/error_subscriber'
end
end
9 changes: 9 additions & 0 deletions lib/rollbar/plugins/rails/error_subscriber.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
module Rollbar
class ErrorSubscriber
def report(error, handled:, severity:, context:, source: nil)
extra = context.is_a?(Hash) ? context.deep_dup : {}
extra[:custom_data_method_context] = source
Rollbar.log(severity, error, extra)
end
end
end
65 changes: 65 additions & 0 deletions spec/controllers/home_controller_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -297,6 +297,71 @@ def send_req(meth, path, args)
end
end

describe 'rails error subscriber', :type => 'request' do
let(:notifier) { Rollbar.notifier }

before do
Rollbar.configure do |config|
config.enable_rails_error_subscriber = true
end
end

after do
Rollbar.configure do |config|
config.enable_rails_error_subscriber = false
end
end

context 'when Rails Error Subscriber is enabled', :if => Rails::VERSION::MAJOR >= 7 do
it '`handle` should not raise an error and report a warning via rails error subscriber' do
logger_mock.should_receive(:info).with('[Rollbar] Success').never

expect(Rollbar).to receive(:log) do |level, _, extra|
expect(extra[:custom_data_method_context]).to be_eql('application')
expect(level.to_s).to be_eql('warning')
end

get '/handle_rails_error'
end

it '`report` should raise an error and report an error via rails error subscriber' do
logger_mock.should_receive(:info).with('[Rollbar] Success').never

expect(Rollbar).to receive(:log) do |level, _, extra|
expect(extra[:custom_data_method_context]).to be_eql('application')
expect(level.to_s).to be_eql('error')
end

expect do
get '/record_rails_error'
end.to raise_exception(RuntimeError, 'Record Rails error')
end

it 'uncaught exception should raise an error and report an error via rails error subscriber' do
logger_mock.should_receive(:info).with('[Rollbar] Success').never

expect(Rollbar).to receive(:log) do |level, _, extra|
expect(extra[:custom_data_method_context]).to be_eql('application.action_dispatch')
expect(level.to_s).to be_eql('error')
end

expect do
get '/cause_exception'
end.to raise_exception(NameError, 'Uncaught Rails error')
end
end

context 'when Rails Error Subscriber is enabled in unsupported Rails', :if => Rails::VERSION::MAJOR < 7 do
it 'uncaught exception should raise an error and report via middleware' do
logger_mock.should_receive(:info).with('[Rollbar] Success').once

expect do
get '/cause_exception'
end.to raise_exception(NameError, 'Uncaught Rails error')
end
end
end

describe 'configuration.locals', :type => 'request',
:if => RUBY_VERSION >= '2.3.0' &&
!(defined?(RUBY_ENGINE) &&
Expand Down
16 changes: 15 additions & 1 deletion spec/dummyapp/app/controllers/home_controller.rb
Original file line number Diff line number Diff line change
Expand Up @@ -22,8 +22,22 @@ def deprecated_report_exception
render :json => {}
end

def handle_rails_error
Rails.error.handle do
raise 'Handle Rails error'
end

render :json => {}
end

def record_rails_error
Rails.error.record do
raise 'Record Rails error'
end
end

def cause_exception
_foo = bar
raise NameError, 'Uncaught Rails error'
end

def cause_exception_with_locals
Expand Down
2 changes: 2 additions & 0 deletions spec/dummyapp/config/routes.rb
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,8 @@
member { post :start_session }
end

match '/handle_rails_error' => 'home#handle_rails_error', :via => [:get, :post]
match '/record_rails_error' => 'home#record_rails_error', :via => [:get, :post]
match '/cause_exception' => 'home#cause_exception', :via => [:get, :post]
match '/cause_exception_with_locals' => 'home#cause_exception_with_locals',
:via => [:get, :post]
Expand Down

0 comments on commit c6d966f

Please sign in to comment.