Commit a9d33e6b authored by Erick Bajao's avatar Erick Bajao

Preload recent failures on test suite

This preloads the recent_failures information for the test suite
details.
parent 1950c267
...@@ -42,9 +42,13 @@ module Projects ...@@ -42,9 +42,13 @@ module Projects
end end
def test_suite def test_suite
builds.map do |build| suite = builds.map do |build|
build.collect_test_reports!(Gitlab::Ci::Reports::TestReports.new) build.collect_test_reports!(Gitlab::Ci::Reports::TestReports.new)
end.sum end.sum
Gitlab::Ci::Reports::TestFailureHistory.new(suite.failed.values, project).load!
suite
end end
# rubocop: enable CodeReuse/ActiveRecord # rubocop: enable CodeReuse/ActiveRecord
end end
......
...@@ -34,20 +34,35 @@ RSpec.describe Projects::Pipelines::TestsController do ...@@ -34,20 +34,35 @@ RSpec.describe Projects::Pipelines::TestsController do
end end
describe 'GET #show.json' do describe 'GET #show.json' do
context 'when pipeline has build report results' do context 'when pipeline has builds with test reports' do
let(:pipeline) { create(:ci_pipeline, :with_report_results, project: project) } let(:main_pipeline) { create(:ci_pipeline, :with_test_reports_with_three_failures, project: project) }
let(:pipeline) { create(:ci_pipeline, :with_test_reports_with_three_failures, project: project, ref: 'new-feature') }
let(:suite_name) { 'test' } let(:suite_name) { 'test' }
let(:build_ids) { pipeline.latest_builds.pluck(:id) } let(:build_ids) { pipeline.latest_builds.pluck(:id) }
before do
# The JUnit fixture for the given build has 3 failures.
# This service will create 1 test case failure record for each.
Ci::TestFailureHistoryService.new(main_pipeline).execute
end
it 'renders test suite data' do it 'renders test suite data' do
get_tests_show_json(build_ids) get_tests_show_json(build_ids)
expect(response).to have_gitlab_http_status(:ok) expect(response).to have_gitlab_http_status(:ok)
expect(json_response['name']).to eq('test') expect(json_response['name']).to eq('test')
# Each test failure in this pipeline has a matching failure in the default branch
recent_failures = json_response['test_cases'].map { |tc| tc['recent_failures'] }
expect(recent_failures).to eq([
{ 'count' => 1, 'base_branch' => 'master' },
{ 'count' => 1, 'base_branch' => 'master' },
{ 'count' => 1, 'base_branch' => 'master' }
])
end end
end end
context 'when pipeline does not have build report results' do context 'when pipeline has no builds that matches the given build_ids' do
let(:pipeline) { create(:ci_empty_pipeline) } let(:pipeline) { create(:ci_empty_pipeline) }
let(:suite_name) { 'test' } let(:suite_name) { 'test' }
......
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