summaryrefslogtreecommitdiff
path: root/spec
diff options
context:
space:
mode:
authorRémy Coutable <remy@rymai.me>2018-11-21 16:10:56 +0000
committerRémy Coutable <remy@rymai.me>2018-11-21 16:10:56 +0000
commitaa261c81da591ae33ba85f7fbcef79e79bb3dd8d (patch)
tree615c38a470b0bca7810dc1a63ac4324601180638 /spec
parent7d1bc0bee8abe4bb029f96b74fd7de492219a49c (diff)
parent4c4c8532d0710689cca2a3c71b134665d42e839a (diff)
downloadgitlab-ce-aa261c81da591ae33ba85f7fbcef79e79bb3dd8d.tar.gz
Merge branch 'sh-fix-issue-51220' into 'master'
Handle force_remove_source_branch when creating merge request Closes #51220 See merge request gitlab-org/gitlab-ce!23281
Diffstat (limited to 'spec')
-rw-r--r--spec/services/merge_requests/build_service_spec.rb34
1 files changed, 26 insertions, 8 deletions
diff --git a/spec/services/merge_requests/build_service_spec.rb b/spec/services/merge_requests/build_service_spec.rb
index c9a668994eb..1894d8c8d0e 100644
--- a/spec/services/merge_requests/build_service_spec.rb
+++ b/spec/services/merge_requests/build_service_spec.rb
@@ -21,15 +21,20 @@ describe MergeRequests::BuildService do
let(:commit_2) { double(:commit_2, sha: 'f00ba7', safe_message: 'This is a bad commit message!') }
let(:commits) { nil }
+ let(:params) do
+ {
+ description: description,
+ source_branch: source_branch,
+ target_branch: target_branch,
+ source_project: source_project,
+ target_project: target_project,
+ milestone_id: milestone_id,
+ label_ids: label_ids
+ }
+ end
+
let(:service) do
- described_class.new(project, user,
- description: description,
- source_branch: source_branch,
- target_branch: target_branch,
- source_project: source_project,
- target_project: target_project,
- milestone_id: milestone_id,
- label_ids: label_ids)
+ described_class.new(project, user, params)
end
before do
@@ -56,6 +61,19 @@ describe MergeRequests::BuildService do
merge_request
end
+ it 'does not assign force_remove_source_branch' do
+ expect(merge_request.force_remove_source_branch?).to be_falsey
+ end
+
+ context 'with force_remove_source_branch parameter' do
+ let(:mr_params) { params.merge(force_remove_source_branch: '1') }
+ let(:merge_request) { described_class.new(project, user, mr_params).execute }
+
+ it 'assigns force_remove_source_branch' do
+ expect(merge_request.force_remove_source_branch?).to be_truthy
+ end
+ end
+
context 'missing source branch' do
let(:source_branch) { '' }