summaryrefslogtreecommitdiff
path: root/spec/graphql/resolvers/alert_management/alert_resolver_spec.rb
blob: 618735837e8d89cd0d17e5eb82e4e68d823e2e52 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
# 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