73 lines
2.7 KiB
Ruby
73 lines
2.7 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'spec_helper'
|
|
|
|
RSpec.describe Resolvers::AlertManagement::AlertResolver do
|
|
include GraphqlHelpers
|
|
|
|
let_it_be(:current_user) { create(:user) }
|
|
let_it_be(:project) { create(:project) }
|
|
let_it_be(:resolved_alert) { create(:alert_management_alert, :resolved, project: project, ended_at: 1.year.ago, events: 2, severity: :high) }
|
|
let_it_be(:ignored_alert) { create(:alert_management_alert, :ignored, project: project, events: 1, severity: :critical) }
|
|
let_it_be(:alert_other_proj) { create(:alert_management_alert) }
|
|
|
|
let(:args) { {} }
|
|
|
|
subject { resolve_alerts(args) }
|
|
|
|
context 'user does not have permission' do
|
|
it { is_expected.to eq(AlertManagement::Alert.none) }
|
|
end
|
|
|
|
context 'user has permission' do
|
|
before do
|
|
project.add_developer(current_user)
|
|
end
|
|
|
|
it { is_expected.to contain_exactly(resolved_alert, ignored_alert) }
|
|
|
|
context 'finding by iid' do
|
|
let(:args) { { iid: resolved_alert.iid } }
|
|
|
|
it { is_expected.to contain_exactly(resolved_alert) }
|
|
end
|
|
|
|
context 'finding by status' do
|
|
let(:args) { { statuses: [Types::AlertManagement::StatusEnum.values['IGNORED'].value] } }
|
|
|
|
it { is_expected.to contain_exactly(ignored_alert) }
|
|
end
|
|
|
|
context 'filtering by domain' do
|
|
let_it_be(:alert1) { create(:alert_management_alert, project: project, monitoring_tool: 'other', domain: :threat_monitoring) }
|
|
let_it_be(:alert2) { create(:alert_management_alert, project: project, monitoring_tool: 'other', domain: :threat_monitoring) }
|
|
let_it_be(:alert3) { create(:alert_management_alert, project: project, monitoring_tool: 'generic') }
|
|
|
|
let(:args) { { domain: 'operations' } }
|
|
|
|
it { is_expected.to contain_exactly(resolved_alert, ignored_alert, alert3) }
|
|
end
|
|
|
|
describe 'sorting' do
|
|
# Other sorting examples in spec/finders/alert_management/alerts_finder_spec.rb
|
|
context 'when sorting by events count' do
|
|
let_it_be(:alert_count_6) { create(:alert_management_alert, project: project, events: 6) }
|
|
let_it_be(:alert_count_3) { create(:alert_management_alert, project: project, events: 3) }
|
|
|
|
it 'sorts alerts ascending' do
|
|
expect(resolve_alerts(sort: :event_count_asc)).to eq [ignored_alert, resolved_alert, alert_count_3, alert_count_6]
|
|
end
|
|
|
|
it 'sorts alerts descending' do
|
|
expect(resolve_alerts(sort: :event_count_desc)).to eq [alert_count_6, alert_count_3, resolved_alert, ignored_alert]
|
|
end
|
|
end
|
|
end
|
|
end
|
|
|
|
private
|
|
|
|
def resolve_alerts(args = {}, context = { current_user: current_user })
|
|
resolve(described_class, obj: project, args: args, ctx: context, arg_style: :internal)
|
|
end
|
|
end
|