2018-11-20 20:47:30 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require 'spec_helper'
|
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
RSpec.describe Gitlab::Import::MergeRequestCreator do
|
2018-11-20 20:47:30 +05:30
|
|
|
let(:project) { create(:project, :repository) }
|
|
|
|
|
|
|
|
subject { described_class.new(project) }
|
|
|
|
|
|
|
|
describe '#execute' do
|
|
|
|
context 'merge request already exists' do
|
|
|
|
let(:merge_request) { create(:merge_request, target_project: project, source_project: project) }
|
|
|
|
let(:commits) { merge_request.merge_request_diffs.first.commits }
|
|
|
|
let(:attributes) { HashWithIndifferentAccess.new(merge_request.attributes.except("merge_params")) }
|
|
|
|
|
|
|
|
it 'updates the data' do
|
|
|
|
commits_count = commits.count
|
2020-06-23 00:09:42 +05:30
|
|
|
merge_request.merge_request_diffs.destroy_all # rubocop: disable Cop/DestroyAll
|
2018-11-20 20:47:30 +05:30
|
|
|
|
|
|
|
expect(merge_request.merge_request_diffs.count).to eq(0)
|
|
|
|
|
|
|
|
subject.execute(attributes)
|
|
|
|
|
2019-12-21 20:55:43 +05:30
|
|
|
merge_request.reload
|
|
|
|
|
|
|
|
expect(merge_request.merge_request_diffs.count).to eq(1)
|
|
|
|
expect(merge_request.merge_request_diffs.first.commits.count).to eq(commits_count)
|
|
|
|
expect(merge_request.latest_merge_request_diff_id).to eq(merge_request.merge_request_diffs.first.id)
|
2018-11-20 20:47:30 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'new merge request' do
|
|
|
|
let(:merge_request) { build(:merge_request, target_project: project, source_project: project) }
|
|
|
|
let(:attributes) { HashWithIndifferentAccess.new(merge_request.attributes.except("merge_params")) }
|
|
|
|
|
|
|
|
it 'creates a new merge request' do
|
|
|
|
attributes.delete(:id)
|
|
|
|
|
|
|
|
expect { subject.execute(attributes) }.to change { MergeRequest.count }.by(1)
|
|
|
|
|
|
|
|
new_mr = MergeRequest.last
|
|
|
|
expect(new_mr.merge_request_diffs.count).to eq(1)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|