debian-mirror-gitlab/spec/models/error_tracking/error_event_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

66 lines
2.1 KiB
Ruby
Raw Normal View History

2021-09-30 23:02:18 +05:30
# frozen_string_literal: true
require 'spec_helper'
RSpec.describe ErrorTracking::ErrorEvent, type: :model do
2021-10-27 15:23:28 +05:30
let_it_be(:event) { create(:error_tracking_error_event) }
2021-09-30 23:02:18 +05:30
describe 'relationships' do
it { is_expected.to belong_to(:error) }
end
describe 'validations' do
it { is_expected.to validate_presence_of(:description) }
2021-12-11 22:18:48 +05:30
it { is_expected.to validate_length_of(:description).is_at_most(1024) }
2021-09-30 23:02:18 +05:30
it { is_expected.to validate_presence_of(:occurred_at) }
2021-12-11 22:18:48 +05:30
it { is_expected.to validate_length_of(:level).is_at_most(255) }
it { is_expected.to validate_length_of(:environment).is_at_most(255) }
2021-09-30 23:02:18 +05:30
end
2021-10-27 15:23:28 +05:30
describe '#stacktrace' do
it 'generates a correct stacktrace in expected format' do
expected_context = [
[132, " end\n"],
[133, "\n"],
[134, " begin\n"],
[135, " block.call(work, *extra)\n"],
[136, " rescue Exception => e\n"],
[137, " STDERR.puts \"Error reached top of thread-pool: #\{e.message\} (#\{e.class\})\"\n"],
[138, " end\n"]
]
expected_entry = {
'lineNo' => 135,
'context' => expected_context,
'filename' => 'puma/thread_pool.rb',
'function' => 'block in spawn_thread',
'colNo' => 0
}
expect(event.stacktrace).to be_kind_of(Array)
expect(event.stacktrace.first).to eq(expected_entry)
end
2021-12-11 22:18:48 +05:30
context 'error context is missing' do
let(:event) { create(:error_tracking_error_event, :browser) }
it 'generates a stacktrace without context' do
expected_entry = {
'lineNo' => 6395,
'context' => [],
'filename' => 'webpack-internal:///./node_modules/vue/dist/vue.runtime.esm.js',
'function' => 'hydrate',
'colNo' => 0
}
expect(event.stacktrace).to be_kind_of(Array)
expect(event.stacktrace.first).to eq(expected_entry)
end
end
2021-10-27 15:23:28 +05:30
end
describe '#to_sentry_error_event' do
it { expect(event.to_sentry_error_event).to be_kind_of(Gitlab::ErrorTracking::ErrorEvent) }
end
2021-09-30 23:02:18 +05:30
end