debian-mirror-gitlab/spec/models/release_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

230 lines
7.3 KiB
Ruby
Raw Normal View History

2019-07-07 11:18:12 +05:30
# frozen_string_literal: true
2019-12-04 20:38:33 +05:30
require 'spec_helper'
2015-11-26 14:37:03 +05:30
2017-09-10 17:25:29 +05:30
RSpec.describe Release do
2021-03-08 18:12:59 +05:30
let_it_be(:user) { create(:user) }
let_it_be(:project) { create(:project, :public, :repository) }
2021-06-08 01:23:25 +05:30
2021-03-11 19:13:27 +05:30
let(:release) { create(:release, project: project, author: user) }
2015-11-26 14:37:03 +05:30
it { expect(release).to be_valid }
describe 'associations' do
2021-04-29 21:17:54 +05:30
it { is_expected.to belong_to(:project).touch(true) }
2019-02-15 15:39:39 +05:30
it { is_expected.to belong_to(:author).class_name('User') }
it { is_expected.to have_many(:links).class_name('Releases::Link') }
2019-12-04 20:38:33 +05:30
it { is_expected.to have_many(:milestones) }
it { is_expected.to have_many(:milestone_releases) }
2020-04-22 19:07:51 +05:30
it { is_expected.to have_many(:evidences).class_name('Releases::Evidence') }
2015-11-26 14:37:03 +05:30
end
describe 'validation' do
it { is_expected.to validate_presence_of(:project) }
2019-12-21 20:55:43 +05:30
it { is_expected.to validate_presence_of(:tag) }
2019-07-31 22:56:46 +05:30
context 'when a release exists in the database without a name' do
it 'does not require name' do
existing_release_without_name = build(:release, project: project, author: user, name: nil)
2021-12-11 22:18:48 +05:30
existing_release_without_name.save!(validate: false)
2019-07-31 22:56:46 +05:30
existing_release_without_name.description = "change"
2021-12-11 22:18:48 +05:30
existing_release_without_name.save!
2019-07-31 22:56:46 +05:30
existing_release_without_name.reload
expect(existing_release_without_name).to be_valid
expect(existing_release_without_name.description).to eq("change")
2019-12-26 22:10:19 +05:30
expect(existing_release_without_name.name).not_to be_nil
2019-07-31 22:56:46 +05:30
end
end
2019-12-04 20:38:33 +05:30
2021-06-08 01:23:25 +05:30
context 'when description of a release is longer than the limit' do
let(:description) { 'a' * (Gitlab::Database::MAX_TEXT_SIZE_LIMIT + 1) }
let(:release) { build(:release, project: project, description: description) }
it 'creates a validation error' do
release.validate
expect(release.errors.full_messages)
.to include("Description is too long (maximum is #{Gitlab::Database::MAX_TEXT_SIZE_LIMIT} characters)")
end
end
2019-12-04 20:38:33 +05:30
context 'when a release is tied to a milestone for another project' do
it 'creates a validation error' do
milestone = build(:milestone, project: create(:project))
2022-07-16 23:28:13 +05:30
expect { release.milestones << milestone }
.to raise_error(ActiveRecord::RecordInvalid,
'Validation failed: Release does not have the same project as the milestone')
2019-12-04 20:38:33 +05:30
end
end
context 'when a release is tied to a milestone linked to the same project' do
it 'successfully links this release to this milestone' do
milestone = build(:milestone, project: project)
expect { release.milestones << milestone }.to change { MilestoneRelease.count }.by(1)
end
end
2022-07-23 23:45:48 +05:30
context 'when creating new release' do
subject { build(:release, project: project, name: 'Release 1.0') }
it { is_expected.to validate_presence_of(:author_id) }
end
2023-04-23 21:23:45 +05:30
# Deleting user along with their contributions, nullifies releases author_id.
2022-07-23 23:45:48 +05:30
context 'when updating existing release without author' do
let(:release) { create(:release, :legacy) }
it 'updates successfully' do
release.description += 'Update'
expect { release.save! }.not_to raise_error
end
end
2015-11-26 14:37:03 +05:30
end
2019-02-15 15:39:39 +05:30
describe '#assets_count' do
2021-06-08 01:23:25 +05:30
subject { Release.find(release.id).assets_count }
2019-02-15 15:39:39 +05:30
it 'returns the number of sources' do
2019-12-26 22:10:19 +05:30
is_expected.to eq(Gitlab::Workhorse::ARCHIVE_FORMATS.count)
2019-02-15 15:39:39 +05:30
end
context 'when a links exists' do
let!(:link) { create(:release_link, release: release) }
it 'counts the link as an asset' do
2019-12-26 22:10:19 +05:30
is_expected.to eq(1 + Gitlab::Workhorse::ARCHIVE_FORMATS.count)
2019-02-15 15:39:39 +05:30
end
2019-07-31 22:56:46 +05:30
it "excludes sources count when asked" do
2021-06-08 01:23:25 +05:30
assets_count = Release.find(release.id).assets_count(except: [:sources])
2019-07-31 22:56:46 +05:30
expect(assets_count).to eq(1)
end
2019-02-15 15:39:39 +05:30
end
end
2020-10-24 23:57:45 +05:30
describe '.create' do
it "fills released_at using created_at if it's not set" do
2021-12-11 22:18:48 +05:30
release = create(:release, project: project, author: user, released_at: nil)
2020-10-24 23:57:45 +05:30
expect(release.released_at).to eq(release.created_at)
end
it "does not change released_at if it's set explicitly" do
released_at = Time.zone.parse('2018-10-20T18:00:00Z')
2021-12-11 22:18:48 +05:30
release = create(:release, project: project, author: user, released_at: released_at)
2020-10-24 23:57:45 +05:30
expect(release.released_at).to eq(released_at)
end
end
2021-03-11 19:13:27 +05:30
describe '#update' do
2021-12-11 22:18:48 +05:30
subject { release.update!(params) }
2021-03-11 19:13:27 +05:30
context 'when links do not exist' do
context 'when params are specified for creation' do
let(:params) do
{ links_attributes: [{ name: 'test', url: 'https://www.google.com/' }] }
end
it 'creates a link successfuly' do
is_expected.to eq(true)
expect(release.links.count).to eq(1)
expect(release.links.first.name).to eq('test')
expect(release.links.first.url).to eq('https://www.google.com/')
end
end
end
context 'when a link exists' do
let!(:link1) { create(:release_link, release: release, name: 'test1', url: 'https://www.google1.com/') }
let!(:link2) { create(:release_link, release: release, name: 'test2', url: 'https://www.google2.com/') }
before do
release.reload
end
context 'when params are specified for update' do
let(:params) do
{ links_attributes: [{ id: link1.id, name: 'new' }] }
end
it 'updates the link successfully' do
is_expected.to eq(true)
expect(release.links.count).to eq(2)
expect(release.links.first.name).to eq('new')
end
end
context 'when params are specified for deletion' do
let(:params) do
{ links_attributes: [{ id: link1.id, _destroy: true }] }
end
it 'removes the link successfuly' do
is_expected.to eq(true)
expect(release.links.count).to eq(1)
expect(release.links.first.name).to eq(link2.name)
end
end
end
end
2019-02-15 15:39:39 +05:30
describe '#sources' do
subject { release.sources }
it 'returns sources' do
is_expected.to all(be_a(Releases::Source))
end
end
2019-09-30 21:07:59 +05:30
describe '#upcoming_release?' do
context 'during the backfill migration when released_at could be nil' do
it 'handles a nil released_at value and returns false' do
allow(release).to receive(:released_at).and_return nil
expect(release.upcoming_release?).to eq(false)
end
end
end
2019-12-21 20:55:43 +05:30
2020-01-01 13:55:28 +05:30
describe 'evidence' do
let(:release_with_evidence) { create(:release, :with_evidence, project: project) }
2019-12-21 20:55:43 +05:30
context 'when a release is deleted' do
it 'also deletes the associated evidence' do
2020-01-01 13:55:28 +05:30
release_with_evidence
2019-12-21 20:55:43 +05:30
2021-12-11 22:18:48 +05:30
expect { release_with_evidence.destroy! }.to change(Releases::Evidence, :count).by(-1)
2019-12-21 20:55:43 +05:30
end
end
end
2019-12-26 22:10:19 +05:30
describe '#name' do
context 'name is nil' do
before do
2021-12-11 22:18:48 +05:30
release.update!(name: nil)
2019-12-26 22:10:19 +05:30
end
it 'returns tag' do
expect(release.name).to eq(release.tag)
end
end
end
2020-01-01 13:55:28 +05:30
2020-03-13 15:44:24 +05:30
describe '#milestone_titles' do
2021-03-08 18:12:59 +05:30
let_it_be(:milestone_1) { create(:milestone, project: project, title: 'Milestone 1') }
let_it_be(:milestone_2) { create(:milestone, project: project, title: 'Milestone 2') }
let_it_be(:release) { create(:release, project: project, milestones: [milestone_1, milestone_2]) }
2020-03-13 15:44:24 +05:30
2022-08-27 11:52:29 +05:30
it { expect(release.milestone_titles).to eq("#{milestone_1.title}, #{milestone_2.title}") }
2020-03-13 15:44:24 +05:30
end
2015-11-26 14:37:03 +05:30
end