diff options
author | GitLab Bot <gitlab-bot@gitlab.com> | 2021-07-20 12:55:51 +0300 |
---|---|---|
committer | GitLab Bot <gitlab-bot@gitlab.com> | 2021-07-20 12:55:51 +0300 |
commit | e8d2c2579383897a1dd7f9debd359abe8ae8373d (patch) | |
tree | c42be41678c2586d49a75cabce89322082698334 /spec/services/error_tracking | |
parent | fc845b37ec3a90aaa719975f607740c22ba6a113 (diff) |
Add latest changes from gitlab-org/gitlab@14-1-stable-eev14.1.0-rc42
Diffstat (limited to 'spec/services/error_tracking')
-rw-r--r-- | spec/services/error_tracking/collect_error_service_spec.rb | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/spec/services/error_tracking/collect_error_service_spec.rb b/spec/services/error_tracking/collect_error_service_spec.rb new file mode 100644 index 00000000000..14cd588f40b --- /dev/null +++ b/spec/services/error_tracking/collect_error_service_spec.rb @@ -0,0 +1,44 @@ +# frozen_string_literal: true + +require 'spec_helper' + +RSpec.describe ErrorTracking::CollectErrorService do + let_it_be(:project) { create(:project) } + let_it_be(:parsed_event) { Gitlab::Json.parse(fixture_file('error_tracking/parsed_event.json')) } + + subject { described_class.new(project, nil, event: parsed_event) } + + describe '#execute' do + it 'creates Error and creates ErrorEvent' do + expect { subject.execute } + .to change { ErrorTracking::Error.count }.by(1) + .and change { ErrorTracking::ErrorEvent.count }.by(1) + end + + it 'updates Error and created ErrorEvent on second hit' do + subject.execute + + expect { subject.execute }.not_to change { ErrorTracking::Error.count } + expect { subject.execute }.to change { ErrorTracking::ErrorEvent.count }.by(1) + end + + it 'has correct values set' do + subject.execute + + event = ErrorTracking::ErrorEvent.last + error = event.error + + expect(error.name).to eq 'ActionView::MissingTemplate' + expect(error.description).to start_with 'Missing template posts/error2' + expect(error.actor).to eq 'PostsController#error2' + expect(error.platform).to eq 'ruby' + expect(error.last_seen_at).to eq '2021-07-08T12:59:16Z' + + expect(event.description).to eq 'ActionView::MissingTemplate' + expect(event.occurred_at).to eq '2021-07-08T12:59:16Z' + expect(event.level).to eq 'error' + expect(event.environment).to eq 'development' + expect(event.payload).to eq parsed_event + end + end +end |