2021-07-15 12:09:01 +00:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require 'spec_helper'
|
|
|
|
|
2021-09-27 21:09:27 +00:00
|
|
|
RSpec.describe API::ErrorTracking::Collector do
|
2021-07-15 12:09:01 +00:00
|
|
|
let_it_be(:project) { create(:project, :private) }
|
2021-08-16 21:11:02 +00:00
|
|
|
let_it_be(:setting) { create(:project_error_tracking_setting, :integrated, project: project) }
|
2021-07-24 18:09:18 +00:00
|
|
|
let_it_be(:client_key) { create(:error_tracking_client_key, project: project) }
|
2021-07-15 12:09:01 +00:00
|
|
|
|
2021-09-14 15:12:05 +00:00
|
|
|
RSpec.shared_examples 'not found' do
|
|
|
|
it 'reponds with 404' do
|
|
|
|
subject
|
|
|
|
|
|
|
|
expect(response).to have_gitlab_http_status(:not_found)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
RSpec.shared_examples 'bad request' do
|
|
|
|
it 'responds with 400' do
|
|
|
|
subject
|
|
|
|
|
|
|
|
expect(response).to have_gitlab_http_status(:bad_request)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
RSpec.shared_examples 'successful request' do
|
2021-10-26 18:09:19 +00:00
|
|
|
it 'writes to the database and returns OK' do
|
2021-09-14 15:12:05 +00:00
|
|
|
expect { subject }.to change { ErrorTracking::ErrorEvent.count }.by(1)
|
|
|
|
|
2021-10-26 18:09:19 +00:00
|
|
|
expect(response).to have_gitlab_http_status(:ok)
|
2021-09-14 15:12:05 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2021-07-15 12:09:01 +00:00
|
|
|
describe "POST /error_tracking/collector/api/:id/envelope" do
|
|
|
|
let_it_be(:raw_event) { fixture_file('error_tracking/event.txt') }
|
|
|
|
let_it_be(:url) { "/error_tracking/collector/api/#{project.id}/envelope" }
|
|
|
|
|
|
|
|
let(:params) { raw_event }
|
2021-07-24 18:09:18 +00:00
|
|
|
let(:headers) { { 'X-Sentry-Auth' => "Sentry sentry_key=#{client_key.public_key}" } }
|
2021-07-15 12:09:01 +00:00
|
|
|
|
2021-07-24 18:09:18 +00:00
|
|
|
subject { post api(url), params: params, headers: headers }
|
2021-07-15 12:09:01 +00:00
|
|
|
|
|
|
|
context 'error tracking feature is disabled' do
|
|
|
|
before do
|
|
|
|
setting.update!(enabled: false)
|
|
|
|
end
|
|
|
|
|
|
|
|
it_behaves_like 'not found'
|
|
|
|
end
|
|
|
|
|
2021-08-16 21:11:02 +00:00
|
|
|
context 'integrated error tracking is disabled' do
|
|
|
|
before do
|
|
|
|
setting.update!(integrated: false)
|
|
|
|
end
|
|
|
|
|
|
|
|
it_behaves_like 'not found'
|
|
|
|
end
|
|
|
|
|
2021-07-24 18:09:18 +00:00
|
|
|
context 'auth headers are missing' do
|
|
|
|
let(:headers) { {} }
|
|
|
|
|
|
|
|
it_behaves_like 'bad request'
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'public key is wrong' do
|
|
|
|
let(:headers) { { 'X-Sentry-Auth' => "Sentry sentry_key=glet_1fedb514e17f4b958435093deb02048c" } }
|
|
|
|
|
|
|
|
it_behaves_like 'not found'
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'public key is inactive' do
|
|
|
|
let(:client_key) { create(:error_tracking_client_key, :disabled, project: project) }
|
|
|
|
|
|
|
|
it_behaves_like 'not found'
|
|
|
|
end
|
|
|
|
|
2021-07-15 12:09:01 +00:00
|
|
|
context 'empty body' do
|
|
|
|
let(:params) { '' }
|
|
|
|
|
|
|
|
it_behaves_like 'bad request'
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'unknown request type' do
|
|
|
|
let(:params) { fixture_file('error_tracking/unknown.txt') }
|
|
|
|
|
|
|
|
it_behaves_like 'bad request'
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'transaction request type' do
|
|
|
|
let(:params) { fixture_file('error_tracking/transaction.txt') }
|
|
|
|
|
2021-10-26 18:09:19 +00:00
|
|
|
it 'does nothing and returns ok' do
|
2021-07-15 12:09:01 +00:00
|
|
|
expect { subject }.not_to change { ErrorTracking::ErrorEvent.count }
|
|
|
|
|
2021-10-26 18:09:19 +00:00
|
|
|
expect(response).to have_gitlab_http_status(:ok)
|
2021-07-15 12:09:01 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2021-09-14 15:12:05 +00:00
|
|
|
it_behaves_like 'successful request'
|
|
|
|
end
|
2021-07-15 12:09:01 +00:00
|
|
|
|
2021-09-14 15:12:05 +00:00
|
|
|
describe "POST /error_tracking/collector/api/:id/store" do
|
|
|
|
let_it_be(:raw_event) { fixture_file('error_tracking/parsed_event.json') }
|
|
|
|
let_it_be(:url) { "/error_tracking/collector/api/#{project.id}/store" }
|
|
|
|
|
|
|
|
let(:params) { raw_event }
|
|
|
|
let(:headers) { { 'X-Sentry-Auth' => "Sentry sentry_key=#{client_key.public_key}" } }
|
|
|
|
|
|
|
|
subject { post api(url), params: params, headers: headers }
|
|
|
|
|
|
|
|
it_behaves_like 'successful request'
|
|
|
|
|
|
|
|
context 'empty headers' do
|
|
|
|
let(:headers) { {} }
|
|
|
|
|
|
|
|
it_behaves_like 'bad request'
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'empty body' do
|
|
|
|
let(:params) { '' }
|
|
|
|
|
|
|
|
it_behaves_like 'bad request'
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'sentry_key as param and empty headers' do
|
|
|
|
let(:url) { "/error_tracking/collector/api/#{project.id}/store?sentry_key=#{sentry_key}" }
|
|
|
|
let(:headers) { {} }
|
|
|
|
|
|
|
|
context 'key is wrong' do
|
|
|
|
let(:sentry_key) { 'glet_1fedb514e17f4b958435093deb02048c' }
|
|
|
|
|
|
|
|
it_behaves_like 'not found'
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'key is empty' do
|
|
|
|
let(:sentry_key) { '' }
|
|
|
|
|
|
|
|
it_behaves_like 'bad request'
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'key is correct' do
|
|
|
|
let(:sentry_key) { client_key.public_key }
|
|
|
|
|
|
|
|
it_behaves_like 'successful request'
|
|
|
|
end
|
2021-07-15 12:09:01 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|