85 lines
2.4 KiB
Ruby
85 lines
2.4 KiB
Ruby
|
# frozen_string_literal: true
|
||
|
|
||
|
require 'spec_helper'
|
||
|
|
||
|
describe Projects::Alerting::NotifyService do
|
||
|
let_it_be(:project, reload: true) { create(:project) }
|
||
|
|
||
|
before do
|
||
|
# We use `let_it_be(:project)` so we make sure to clear caches
|
||
|
project.clear_memoization(:licensed_feature_available)
|
||
|
end
|
||
|
|
||
|
shared_examples 'processes incident issues' do |amount|
|
||
|
let(:create_incident_service) { spy }
|
||
|
|
||
|
it 'processes issues' do
|
||
|
expect(IncidentManagement::ProcessAlertWorker)
|
||
|
.to receive(:perform_async)
|
||
|
.with(project.id, kind_of(Hash))
|
||
|
.exactly(amount).times
|
||
|
|
||
|
Sidekiq::Testing.inline! do
|
||
|
expect(subject.status).to eq(:success)
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
|
||
|
shared_examples 'does not process incident issues' do |http_status:|
|
||
|
it 'does not process issues' do
|
||
|
expect(IncidentManagement::ProcessAlertWorker)
|
||
|
.not_to receive(:perform_async)
|
||
|
|
||
|
expect(subject.status).to eq(:error)
|
||
|
expect(subject.http_status).to eq(http_status)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
describe '#execute' do
|
||
|
let(:token) { 'invalid-token' }
|
||
|
let(:starts_at) { Time.now.change(usec: 0) }
|
||
|
let(:service) { described_class.new(project, nil, payload) }
|
||
|
let(:payload_raw) do
|
||
|
{
|
||
|
'title' => 'alert title',
|
||
|
'start_time' => starts_at.rfc3339
|
||
|
}
|
||
|
end
|
||
|
let(:payload) { ActionController::Parameters.new(payload_raw).permit! }
|
||
|
|
||
|
subject { service.execute(token) }
|
||
|
|
||
|
context 'with activated Alerts Service' do
|
||
|
let!(:alerts_service) { create(:alerts_service, project: project) }
|
||
|
|
||
|
context 'with valid token' do
|
||
|
let(:token) { alerts_service.token }
|
||
|
|
||
|
context 'with a valid payload' do
|
||
|
it_behaves_like 'processes incident issues', 1
|
||
|
end
|
||
|
|
||
|
context 'with an invalid payload' do
|
||
|
before do
|
||
|
allow(Gitlab::Alerting::NotificationPayloadParser)
|
||
|
.to receive(:call)
|
||
|
.and_raise(Gitlab::Alerting::NotificationPayloadParser::BadPayloadError)
|
||
|
end
|
||
|
|
||
|
it_behaves_like 'does not process incident issues', http_status: 400
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context 'with invalid token' do
|
||
|
it_behaves_like 'does not process incident issues', http_status: 401
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context 'with deactivated Alerts Service' do
|
||
|
let!(:alerts_service) { create(:alerts_service, :inactive, project: project) }
|
||
|
|
||
|
it_behaves_like 'does not process incident issues', http_status: 403
|
||
|
end
|
||
|
end
|
||
|
end
|