2019-07-31 22:56:46 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2019-02-15 15:39:39 +05:30
|
|
|
require 'spec_helper'
|
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
RSpec.describe Releases::UpdateService do
|
2019-02-15 15:39:39 +05:30
|
|
|
let(:project) { create(:project, :repository) }
|
|
|
|
let(:user) { create(:user) }
|
|
|
|
let(:new_name) { 'A new name' }
|
|
|
|
let(:new_description) { 'The best release!' }
|
|
|
|
let(:params) { { name: new_name, description: new_description, tag: tag_name } }
|
|
|
|
let(:service) { described_class.new(project, user, params) }
|
|
|
|
let!(:release) { create(:release, project: project, author: user, tag: tag_name) }
|
|
|
|
let(:tag_name) { 'v1.1.0' }
|
|
|
|
|
|
|
|
before do
|
|
|
|
project.add_developer(user)
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '#execute' do
|
|
|
|
shared_examples 'a failed update' do
|
|
|
|
it 'raises an error' do
|
|
|
|
result = service.execute
|
|
|
|
expect(result[:status]).to eq(:error)
|
2020-03-13 15:44:24 +05:30
|
|
|
expect(result[:milestones_updated]).to be_falsy
|
2019-02-15 15:39:39 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'successfully updates an existing release' do
|
|
|
|
result = service.execute
|
|
|
|
expect(result[:status]).to eq(:success)
|
|
|
|
expect(result[:release].name).to eq(new_name)
|
|
|
|
expect(result[:release].description).to eq(new_description)
|
|
|
|
end
|
|
|
|
|
2021-01-29 00:20:46 +05:30
|
|
|
it 'executes hooks' do
|
|
|
|
expect(service.release).to receive(:execute_hooks).with('update')
|
|
|
|
|
|
|
|
service.execute
|
|
|
|
end
|
|
|
|
|
2019-02-15 15:39:39 +05:30
|
|
|
context 'when the tag does not exists' do
|
|
|
|
let(:tag_name) { 'foobar' }
|
|
|
|
|
|
|
|
it_behaves_like 'a failed update'
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when the release does not exist' do
|
|
|
|
let!(:release) { }
|
|
|
|
|
|
|
|
it_behaves_like 'a failed update'
|
|
|
|
end
|
|
|
|
|
2019-12-04 20:38:33 +05:30
|
|
|
context 'when a milestone is passed in' do
|
|
|
|
let(:milestone) { create(:milestone, project: project, title: 'v1.0') }
|
|
|
|
let(:params_with_milestone) { params.merge!({ milestones: [new_title] }) }
|
2020-03-13 15:44:24 +05:30
|
|
|
let(:new_milestone) { create(:milestone, project: project, title: new_title) }
|
2019-12-04 20:38:33 +05:30
|
|
|
let(:service) { described_class.new(new_milestone.project, user, params_with_milestone) }
|
|
|
|
|
|
|
|
before do
|
|
|
|
release.milestones << milestone
|
2020-03-13 15:44:24 +05:30
|
|
|
end
|
2019-12-04 20:38:33 +05:30
|
|
|
|
2020-03-13 15:44:24 +05:30
|
|
|
context 'a different milestone' do
|
|
|
|
let(:new_title) { 'v2.0' }
|
|
|
|
|
|
|
|
it 'updates the related milestone accordingly' do
|
|
|
|
result = service.execute
|
|
|
|
release.reload
|
|
|
|
|
|
|
|
expect(release.milestones.first.title).to eq(new_title)
|
|
|
|
expect(result[:milestones_updated]).to be_truthy
|
|
|
|
end
|
2019-12-04 20:38:33 +05:30
|
|
|
end
|
|
|
|
|
2020-03-13 15:44:24 +05:30
|
|
|
context 'an identical milestone' do
|
|
|
|
let(:new_title) { 'v1.0' }
|
|
|
|
|
|
|
|
it "raises an error" do
|
|
|
|
expect { service.execute }.to raise_error(ActiveRecord::RecordInvalid)
|
|
|
|
end
|
2019-12-04 20:38:33 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when an 'empty' milestone is passed in" do
|
|
|
|
let(:milestone) { create(:milestone, project: project, title: 'v1.0') }
|
|
|
|
let(:params_with_empty_milestone) { params.merge!({ milestones: [] }) }
|
|
|
|
|
|
|
|
before do
|
|
|
|
release.milestones << milestone
|
|
|
|
|
|
|
|
service.params = params_with_empty_milestone
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'removes the old milestone and does not associate any new milestone' do
|
2020-03-13 15:44:24 +05:30
|
|
|
result = service.execute
|
|
|
|
release.reload
|
|
|
|
|
2019-12-04 20:38:33 +05:30
|
|
|
expect(release.milestones).not_to be_present
|
2020-03-13 15:44:24 +05:30
|
|
|
expect(result[:milestones_updated]).to be_truthy
|
2019-12-04 20:38:33 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when multiple new milestones are passed in" do
|
|
|
|
let(:new_title_1) { 'v2.0' }
|
|
|
|
let(:new_title_2) { 'v2.0-rc' }
|
|
|
|
let(:milestone) { create(:milestone, project: project, title: 'v1.0') }
|
|
|
|
let(:params_with_milestones) { params.merge!({ milestones: [new_title_1, new_title_2] }) }
|
|
|
|
let(:service) { described_class.new(project, user, params_with_milestones) }
|
|
|
|
|
|
|
|
before do
|
|
|
|
create(:milestone, project: project, title: new_title_1)
|
|
|
|
create(:milestone, project: project, title: new_title_2)
|
|
|
|
release.milestones << milestone
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'removes the old milestone and update the release with the new ones' do
|
2020-03-13 15:44:24 +05:30
|
|
|
result = service.execute
|
|
|
|
release.reload
|
|
|
|
|
2019-12-04 20:38:33 +05:30
|
|
|
milestone_titles = release.milestones.map(&:title)
|
|
|
|
expect(milestone_titles).to match_array([new_title_1, new_title_2])
|
2020-03-13 15:44:24 +05:30
|
|
|
expect(result[:milestones_updated]).to be_truthy
|
2019-12-04 20:38:33 +05:30
|
|
|
end
|
|
|
|
end
|
2019-02-15 15:39:39 +05:30
|
|
|
end
|
|
|
|
end
|