diff options
author | GitLab Bot <gitlab-bot@gitlab.com> | 2020-02-11 18:08:44 +0300 |
---|---|---|
committer | GitLab Bot <gitlab-bot@gitlab.com> | 2020-02-11 18:08:44 +0300 |
commit | bcc77054ee9aefd1e332e04a4189390fd5a3112e (patch) | |
tree | e6e1908c310e4733038794e932196cae0d66ba9a /spec/workers | |
parent | 05b5c609cb8c260b10c2eb1b92b711dc82d32c3f (diff) |
Add latest changes from gitlab-org/gitlab@master
Diffstat (limited to 'spec/workers')
-rw-r--r-- | spec/workers/concerns/worker_context_spec.rb | 10 | ||||
-rw-r--r-- | spec/workers/incident_management/process_alert_worker_spec.rb | 39 |
2 files changed, 49 insertions, 0 deletions
diff --git a/spec/workers/concerns/worker_context_spec.rb b/spec/workers/concerns/worker_context_spec.rb index 97a88eecd73..4e8c81c57dc 100644 --- a/spec/workers/concerns/worker_context_spec.rb +++ b/spec/workers/concerns/worker_context_spec.rb @@ -106,5 +106,15 @@ describe WorkerContext do expect(Labkit::Context.current.to_h).to include('meta.user' => 'jane-doe') end end + + it 'yields the arguments to the block' do + a_user = build_stubbed(:user) + a_project = build_stubbed(:project) + + worker.new.with_context(user: a_user, project: a_project) do |user:, project:| + expect(user).to eq(a_user) + expect(project).to eq(a_project) + end + end end end diff --git a/spec/workers/incident_management/process_alert_worker_spec.rb b/spec/workers/incident_management/process_alert_worker_spec.rb new file mode 100644 index 00000000000..9f40833dfd7 --- /dev/null +++ b/spec/workers/incident_management/process_alert_worker_spec.rb @@ -0,0 +1,39 @@ +# frozen_string_literal: true + +require 'spec_helper' + +describe IncidentManagement::ProcessAlertWorker do + let_it_be(:project) { create(:project) } + + describe '#perform' do + let(:alert) { :alert } + let(:create_issue_service) { spy(:create_issue_service) } + + subject { described_class.new.perform(project.id, alert) } + + it 'calls create issue service' do + expect(Project).to receive(:find_by_id).and_call_original + + expect(IncidentManagement::CreateIssueService) + .to receive(:new).with(project, :alert) + .and_return(create_issue_service) + + expect(create_issue_service).to receive(:execute) + + subject + end + + context 'with invalid project' do + let(:invalid_project_id) { 0 } + + subject { described_class.new.perform(invalid_project_id, alert) } + + it 'does not create issues' do + expect(Project).to receive(:find_by_id).and_call_original + expect(IncidentManagement::CreateIssueService).not_to receive(:new) + + subject + end + end + end +end |