Commit 97a94ae7 authored by Quang-Minh Nguyen's avatar Quang-Minh Nguyen

Remove all direct accesses to Raven

Issue https://gitlab.com/gitlab-com/gl-infra/scalability/-/issues/846
parent dc99ae29
...@@ -59,7 +59,7 @@ module Gitlab ...@@ -59,7 +59,7 @@ module Gitlab
rescue => error rescue => error
# Any exceptions that might occur should be reported to # Any exceptions that might occur should be reported to
# Sentry, instead of silently terminating this thread. # Sentry, instead of silently terminating this thread.
Raven.capture_exception(error) Gitlab::ErrorTracking.track_exception(error)
Gitlab::AppLogger.error( Gitlab::AppLogger.error(
"Service discovery encountered an error: #{error.message}" "Service discovery encountered an error: #{error.message}"
......
...@@ -66,8 +66,8 @@ RSpec.describe Gitlab::Database::LoadBalancing::ServiceDiscovery do ...@@ -66,8 +66,8 @@ RSpec.describe Gitlab::Database::LoadBalancing::ServiceDiscovery do
.to receive(:refresh_if_necessary) .to receive(:refresh_if_necessary)
.and_raise(error) .and_raise(error)
expect(Raven) expect(Gitlab::ErrorTracking)
.to receive(:capture_exception) .to receive(:track_exception)
.with(error) .with(error)
expect(service) expect(service)
......
...@@ -221,7 +221,7 @@ RSpec.describe Upload do ...@@ -221,7 +221,7 @@ RSpec.describe Upload do
it 'does not send a message to Sentry' do it 'does not send a message to Sentry' do
upload = described_class.new(path: "#{__FILE__}-nope", store: ObjectStorage::Store::LOCAL) upload = described_class.new(path: "#{__FILE__}-nope", store: ObjectStorage::Store::LOCAL)
expect(Raven).not_to receive(:capture_message) expect(Gitlab::ErrorTracking).not_to receive(:track_exception)
upload.exist? upload.exist?
end end
......
...@@ -314,14 +314,13 @@ RSpec.describe API::Helpers do ...@@ -314,14 +314,13 @@ RSpec.describe API::Helpers do
expect(Gitlab::ErrorTracking).to receive(:sentry_dsn).and_return(Gitlab.config.sentry.dsn) expect(Gitlab::ErrorTracking).to receive(:sentry_dsn).and_return(Gitlab.config.sentry.dsn)
Gitlab::ErrorTracking.configure Gitlab::ErrorTracking.configure
Raven.client.configuration.encoding = 'json'
end end
it 'does not report a MethodNotAllowed exception to Sentry' do it 'does not report a MethodNotAllowed exception to Sentry' do
exception = Grape::Exceptions::MethodNotAllowed.new({ 'X-GitLab-Test' => '1' }) exception = Grape::Exceptions::MethodNotAllowed.new({ 'X-GitLab-Test' => '1' })
allow(exception).to receive(:backtrace).and_return(caller) allow(exception).to receive(:backtrace).and_return(caller)
expect(Raven).not_to receive(:capture_exception).with(exception) expect(Gitlab::ErrorTracking).not_to receive(:track_exception).with(exception)
handle_api_exception(exception) handle_api_exception(exception)
end end
...@@ -330,8 +329,7 @@ RSpec.describe API::Helpers do ...@@ -330,8 +329,7 @@ RSpec.describe API::Helpers do
exception = RuntimeError.new('test error') exception = RuntimeError.new('test error')
allow(exception).to receive(:backtrace).and_return(caller) allow(exception).to receive(:backtrace).and_return(caller)
expect(Raven).to receive(:capture_exception).with(exception, tags: expect(Gitlab::ErrorTracking).to receive(:track_exception).with(exception)
a_hash_including(correlation_id: 'new-correlation-id'), extra: {})
Labkit::Correlation::CorrelationId.use_id('new-correlation-id') do Labkit::Correlation::CorrelationId.use_id('new-correlation-id') do
handle_api_exception(exception) handle_api_exception(exception)
...@@ -357,20 +355,6 @@ RSpec.describe API::Helpers do ...@@ -357,20 +355,6 @@ RSpec.describe API::Helpers do
expect(json_response['message']).to start_with("\nRuntimeError (Runtime Error!):") expect(json_response['message']).to start_with("\nRuntimeError (Runtime Error!):")
end end
end end
context 'extra information' do
# Sentry events are an array of the form [auth_header, data, options]
let(:event_data) { Raven.client.transport.events.first[1] }
it 'sends the params, excluding confidential values' do
expect(ProjectsFinder).to receive(:new).and_raise('Runtime Error!')
get api('/projects', user), params: { password: 'dont_send_this', other_param: 'send_this' }
expect(event_data).to include('other_param=send_this')
expect(event_data).to include('password=********')
end
end
end end
describe '.authenticate_non_get!' do describe '.authenticate_non_get!' do
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment