# frozen_string_literal: true require 'spec_helper' RSpec.describe 'getting a detailed sentry error' do include GraphqlHelpers let_it_be(:project) { create(:project, :repository) } let_it_be(:project_setting) { create(:project_error_tracking_setting, project: project) } let_it_be(:current_user) { project.first_owner } let_it_be(:sentry_detailed_error) { build(:error_tracking_sentry_detailed_error) } let(:sentry_gid) { sentry_detailed_error.to_global_id.to_s } let(:fields) do <<~QUERY #{all_graphql_fields_for('SentryDetailedError'.classify)} QUERY end let(:query) do graphql_query_for( 'project', { 'fullPath' => project.full_path }, query_graphql_field('sentryDetailedError', { id: sentry_gid }, fields) ) end let(:error_data) { graphql_data['project']['sentryDetailedError'] } it_behaves_like 'a working graphql query' do before do post_graphql(query, current_user: current_user) end end context 'when data is loading via reactive cache' do before do expect(Gitlab::UsageDataCounters::HLLRedisCounter).not_to receive(:track_event) post_graphql(query, current_user: current_user) end it "is expected to return an empty error" do expect(error_data).to eq nil end end context 'reactive cache returns data' do before do expect_any_instance_of(ErrorTracking::ProjectErrorTrackingSetting) .to receive(:issue_details) .and_return({ issue: sentry_detailed_error }) expect(Gitlab::UsageDataCounters::HLLRedisCounter) .to receive(:track_event) .with('error_tracking_view_details', values: current_user.id) post_graphql(query, current_user: current_user) end it "is expected to return a valid error" do expect(error_data['id']).to eql sentry_gid expect(error_data['sentryId']).to eql sentry_detailed_error.id.to_s expect(error_data['status']).to eql sentry_detailed_error.status.upcase expect(error_data['firstSeen']).to eql sentry_detailed_error.first_seen expect(error_data['lastSeen']).to eql sentry_detailed_error.last_seen expect(error_data['gitlabCommit']).to be nil expect(error_data['externalBaseUrl']).to eq sentry_detailed_error.external_base_url expect(error_data['gitlabIssuePath']).to eq sentry_detailed_error.gitlab_issue expect(error_data['tags']['logger']).to eq sentry_detailed_error.tags[:logger] expect(error_data['tags']['level']).to eq sentry_detailed_error.tags[:level] end it 'is expected to return the frequency correctly' do expect(error_data['frequency'].count).to eql sentry_detailed_error.frequency.count first_frequency = error_data['frequency'].first expect(Time.parse(first_frequency['time'])).to eql Time.at(sentry_detailed_error.frequency[0][0], in: 0) expect(first_frequency['count']).to eql sentry_detailed_error.frequency[0][1] end end end