debian-mirror-gitlab/spec/services/releases/update_service_spec.rb

142 lines
4.5 KiB
Ruby
Raw Normal View History

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
2021-09-30 23:02:18 +05:30
context 'when tag is protected and user does not have access to it' do
let!(:protected_tag) { create(:protected_tag, :no_one_can_create, name: '*', project: project) }
it 'track the error event' do
stub_feature_flags(evalute_protected_tag_for_release_permissions: false)
expect(Gitlab::ErrorTracking).to receive(:log_exception).with(
kind_of(described_class::ReleaseProtectedTagAccessError),
project_id: project.id,
user_id: user.id)
service.execute
end
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