Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'spec/models/release_spec.rb')
-rw-r--r--spec/models/release_spec.rb96
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 }