2015-09-25 12:07:36 +05:30
|
|
|
require 'spec_helper'
|
|
|
|
|
|
|
|
describe MergeWorker do
|
|
|
|
describe "remove source branch" do
|
|
|
|
let!(:merge_request) { create(:merge_request, source_branch: "markdown") }
|
|
|
|
let!(:source_project) { merge_request.source_project }
|
|
|
|
let!(:project) { merge_request.project }
|
|
|
|
let!(:author) { merge_request.author }
|
|
|
|
|
|
|
|
before do
|
|
|
|
source_project.team << [author, :master]
|
2016-06-22 15:30:34 +05:30
|
|
|
source_project.repository.expire_branches_cache
|
2015-09-25 12:07:36 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
it 'clears cache of source repo after removing source branch' do
|
|
|
|
expect(source_project.repository.branch_names).to include('markdown')
|
|
|
|
|
2017-08-17 22:00:37 +05:30
|
|
|
described_class.new.perform(
|
2015-09-25 12:07:36 +05:30
|
|
|
merge_request.id, merge_request.author_id,
|
|
|
|
commit_message: 'wow such merge',
|
|
|
|
should_remove_source_branch: true)
|
|
|
|
|
|
|
|
merge_request.reload
|
|
|
|
expect(merge_request).to be_merged
|
2016-06-02 11:05:42 +05:30
|
|
|
|
|
|
|
source_project.repository.expire_branches_cache
|
2015-09-25 12:07:36 +05:30
|
|
|
expect(source_project.repository.branch_names).not_to include('markdown')
|
|
|
|
end
|
|
|
|
end
|
2017-09-10 17:25:29 +05:30
|
|
|
|
|
|
|
it 'persists merge_jid' do
|
|
|
|
merge_request = create(:merge_request, merge_jid: nil)
|
|
|
|
user = create(:user)
|
|
|
|
worker = described_class.new
|
|
|
|
|
|
|
|
allow(worker).to receive(:jid) { '999' }
|
|
|
|
|
|
|
|
expect { worker.perform(merge_request.id, user.id, {}) }
|
|
|
|
.to change { merge_request.reload.merge_jid }.from(nil).to('999')
|
|
|
|
end
|
2015-09-25 12:07:36 +05:30
|
|
|
end
|