diff options
Diffstat (limited to 'spec/models/release_spec.rb')
-rw-r--r-- | spec/models/release_spec.rb | 96 |
1 files changed, 92 insertions, 4 deletions
diff --git a/spec/models/release_spec.rb b/spec/models/release_spec.rb index 880fb21b7af..bddd0516400 100644 --- a/spec/models/release_spec.rb +++ b/spec/models/release_spec.rb @@ -2,7 +2,7 @@ require 'spec_helper' -RSpec.describe Release do +RSpec.describe Release, feature_category: :release_orchestration do let_it_be(:user) { create(:user) } let_it_be(:project) { create(:project, :public, :repository) } @@ -54,9 +54,9 @@ RSpec.describe Release do it 'creates a validation error' do milestone = build(:milestone, project: create(:project)) - expect { release.milestones << milestone } - .to raise_error(ActiveRecord::RecordInvalid, - 'Validation failed: Release does not have the same project as the milestone') + expect { release.milestones << milestone }.to raise_error( + ActiveRecord::RecordInvalid, 'Validation failed: Release does not have the same project as the milestone' + ) end end @@ -85,6 +85,94 @@ RSpec.describe Release do end end + describe 'latest releases' do + let_it_be(:yesterday) { Time.zone.now - 1.day } + let_it_be(:tomorrow) { Time.zone.now + 1.day } + + let_it_be(:project2) { create(:project) } + + let_it_be(:project_release1) do + create(:release, project: project, released_at: yesterday, created_at: tomorrow) + end + + let_it_be(:project_release2) do + create(:release, project: project, released_at: tomorrow, created_at: yesterday) + end + + let_it_be(:project2_release1) do + create(:release, project: project2, released_at: yesterday, created_at: tomorrow) + end + + let_it_be(:project2_release2) do + create(:release, project: project2, released_at: tomorrow, created_at: yesterday) + end + + let(:args) { {} } + + describe '.latest' do + subject(:latest) { project.releases.latest(**args) } + + context 'without order_by' do + it 'returns the latest release by released date' do + expect(latest).to eq(project_release2) + end + end + + context 'with order_by: created_at' do + let(:args) { { order_by: 'created_at' } } + + it 'returns the latest release by created date' do + expect(latest).to eq(project_release1) + end + end + + context 'when there are no releases' do + it 'returns nil' do + project.releases.delete_all + + expect(latest).to eq(nil) + end + end + end + + describe '.latest_for_projects' do + let(:projects) { [project, project2] } + + subject(:latest_for_projects) { described_class.latest_for_projects(projects, **args) } + + context 'without order_by' do + it 'returns the latest release by released date for each project' do + expect(latest_for_projects).to match_array([project_release2, project2_release2]) + end + end + + context 'with order_by: created_at' do + let(:args) { { order_by: 'created_at' } } + + it 'returns the latest release by created date for each project' do + expect(latest_for_projects).to match_array([project_release1, project2_release1]) + end + end + + context 'when no projects are provided' do + let(:projects) { [] } + + it 'returns empty response' do + expect(latest_for_projects).to be_empty + end + end + + context 'when there are no releases' do + it 'returns empty response' do + project.releases.delete_all + project2.releases.delete_all + + expect(latest_for_projects).to be_empty + end + end + end + end + describe '#assets_count' do subject { Release.find(release.id).assets_count } |