Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'spec/workers/merge_requests')
-rw-r--r--spec/workers/merge_requests/create_pipeline_worker_spec.rb37
-rw-r--r--spec/workers/merge_requests/update_head_pipeline_worker_spec.rb28
2 files changed, 47 insertions, 18 deletions
diff --git a/spec/workers/merge_requests/create_pipeline_worker_spec.rb b/spec/workers/merge_requests/create_pipeline_worker_spec.rb
index 06d44c45706..441d7652219 100644
--- a/spec/workers/merge_requests/create_pipeline_worker_spec.rb
+++ b/spec/workers/merge_requests/create_pipeline_worker_spec.rb
@@ -3,24 +3,50 @@
require 'spec_helper'
RSpec.describe MergeRequests::CreatePipelineWorker do
- subject(:worker) { described_class.new }
-
describe '#perform' do
let(:user) { create(:user) }
let(:project) { create(:project) }
let(:merge_request) { create(:merge_request) }
+ let(:worker) { described_class.new }
+
+ subject { worker.perform(project.id, user.id, merge_request.id) }
context 'when the objects exist' do
it 'calls the merge request create pipeline service and calls update head pipeline' do
aggregate_failures do
- expect_next_instance_of(MergeRequests::CreatePipelineService, project: project, current_user: user) do |service|
+ expect_next_instance_of(MergeRequests::CreatePipelineService,
+ project: project,
+ current_user: user,
+ params: { push_options: nil }) do |service|
expect(service).to receive(:execute).with(merge_request)
end
expect(MergeRequest).to receive(:find_by_id).with(merge_request.id).and_return(merge_request)
expect(merge_request).to receive(:update_head_pipeline)
- subject.perform(project.id, user.id, merge_request.id)
+ subject
+ end
+ end
+
+ context 'when push options are passed as Hash to the worker' do
+ let(:extra_params) { { 'push_options' => { 'ci' => { 'skip' => true } } } }
+
+ subject { worker.perform(project.id, user.id, merge_request.id, extra_params) }
+
+ it 'calls the merge request create pipeline service and calls update head pipeline' do
+ aggregate_failures do
+ expect_next_instance_of(MergeRequests::CreatePipelineService,
+ project: project,
+ current_user: user,
+ params: { push_options: { ci: { skip: true } } }) do |service|
+ expect(service).to receive(:execute).with(merge_request)
+ end
+
+ expect(MergeRequest).to receive(:find_by_id).with(merge_request.id).and_return(merge_request)
+ expect(merge_request).to receive(:update_head_pipeline)
+
+ subject
+ end
end
end
end
@@ -29,8 +55,7 @@ RSpec.describe MergeRequests::CreatePipelineWorker do
it 'does not call the create pipeline service' do
expect(MergeRequests::CreatePipelineService).not_to receive(:new)
- expect { subject.perform(project.id, user.id, merge_request.id) }
- .not_to raise_exception
+ expect { subject }.not_to raise_exception
end
end
diff --git a/spec/workers/merge_requests/update_head_pipeline_worker_spec.rb b/spec/workers/merge_requests/update_head_pipeline_worker_spec.rb
index 5e0b07067df..3574b8296a4 100644
--- a/spec/workers/merge_requests/update_head_pipeline_worker_spec.rb
+++ b/spec/workers/merge_requests/update_head_pipeline_worker_spec.rb
@@ -24,18 +24,6 @@ RSpec.describe MergeRequests::UpdateHeadPipelineWorker do
create(:merge_request, source_branch: 'feature', target_branch: "v1.1.0", source_project: project)
end
- context 'when related merge request is already merged' do
- let!(:merged_merge_request) do
- create(:merge_request, source_branch: 'master', target_branch: "branch_2", source_project: project, state: 'merged')
- end
-
- it 'does not schedule update head pipeline job' do
- expect(UpdateHeadPipelineForMergeRequestWorker).not_to receive(:perform_async).with(merged_merge_request.id)
-
- subject
- end
- end
-
context 'when the head pipeline sha equals merge request sha' do
let(:ref) { 'feature' }
@@ -52,6 +40,22 @@ RSpec.describe MergeRequests::UpdateHeadPipelineWorker do
expect(merge_request_1.reload.head_pipeline).to eq(pipeline)
expect(merge_request_2.reload.head_pipeline).to eq(pipeline)
end
+
+ context 'when the merge request is not open' do
+ before do
+ merge_request_1.close!
+ end
+
+ it 'only updates the open merge requests' do
+ merge_request_1
+ merge_request_2
+
+ subject
+
+ expect(merge_request_1.reload.head_pipeline).not_to eq(pipeline)
+ expect(merge_request_2.reload.head_pipeline).to eq(pipeline)
+ end
+ end
end
context 'when the head pipeline sha does not equal merge request sha' do