Commit 36f4011a authored by Yorick Peterse's avatar Yorick Peterse

Memoize the latest builds of a pipeline

This ensures that if a pipeline is present for the last commit on a
project's homepage we only run 1 query to get the builds, instead of
running 2 queries.

See https://gitlab.com/gitlab-org/gitlab-ce/issues/36878#note_40073339
for more information.
parent 1ddec841
...@@ -470,6 +470,10 @@ module Ci ...@@ -470,6 +470,10 @@ module Ci
artifacts.codequality.find(&:has_codeclimate_json?) artifacts.codequality.find(&:has_codeclimate_json?)
end end
def latest_builds_with_artifacts
@latest_builds_with_artifacts ||= builds.latest.with_artifacts
end
private private
def ci_yaml_from_repo def ci_yaml_from_repo
......
...@@ -26,18 +26,16 @@ ...@@ -26,18 +26,16 @@
%i.fa.fa-download %i.fa.fa-download
%span= _('Download tar') %span= _('Download tar')
- if pipeline - if pipeline && pipeline.latest_builds_with_artifacts.any?
- artifacts = pipeline.builds.latest.with_artifacts %li.dropdown-header Artifacts
- if artifacts.any? - unless pipeline.latest?
%li.dropdown-header Artifacts - latest_pipeline = project.pipeline_for(ref)
- unless pipeline.latest? %li
- latest_pipeline = project.pipeline_for(ref) .unclickable= ci_status_for_statuseable(latest_pipeline)
%li %li.dropdown-header Previous Artifacts
.unclickable= ci_status_for_statuseable(latest_pipeline) - pipeline.latest_builds_with_artifacts.each do |job|
%li.dropdown-header Previous Artifacts %li
- artifacts.each do |job| = link_to latest_succeeded_project_artifacts_path(project, "#{ref}/download", job: job.name), rel: 'nofollow', download: '' do
%li %i.fa.fa-download
= link_to latest_succeeded_project_artifacts_path(project, "#{ref}/download", job: job.name), rel: 'nofollow', download: '' do %span
%i.fa.fa-download #{s_('DownloadArtifacts|Download')} '#{job.name}'
%span
#{ s_('DownloadArtifacts|Download') } '#{job.name}'
---
title: "Memoize the latest builds of a pipeline on a project's homepage"
merge_request:
author:
type: other
...@@ -1444,6 +1444,26 @@ describe Ci::Pipeline, :mailer do ...@@ -1444,6 +1444,26 @@ describe Ci::Pipeline, :mailer do
end end
end end
describe '#latest_builds_with_artifacts' do
let!(:pipeline) { create(:ci_pipeline, :success) }
let!(:build) do
create(:ci_build, :success, :artifacts, pipeline: pipeline)
end
it 'returns the latest builds' do
expect(pipeline.latest_builds_with_artifacts).to eq([build])
end
it 'memoizes the returned relation' do
query_count = ActiveRecord::QueryRecorder
.new { 2.times { pipeline.latest_builds_with_artifacts.to_a } }
.count
expect(query_count).to eq(1)
end
end
describe '#codeclimate_artifact' do describe '#codeclimate_artifact' do
context 'has codequality job' do context 'has codequality job' do
let!(:build) do let!(:build) do
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment