Commit bf7c49f3 authored by Toon Claes's avatar Toon Claes

Merge branch 'mo-coverage-finder-graphql-cleanup' into 'master'

Refactor code coverage summary graphql resolver

See merge request gitlab-org/gitlab!55658
parents 30f1b4f1 38e1debb
...@@ -4,7 +4,6 @@ module Ci ...@@ -4,7 +4,6 @@ module Ci
class DailyBuildGroupReportResult < ApplicationRecord class DailyBuildGroupReportResult < ApplicationRecord
extend Gitlab::Ci::Model extend Gitlab::Ci::Model
REPORT_WINDOW = 90.days
PARAM_TYPES = %w[coverage].freeze PARAM_TYPES = %w[coverage].freeze
belongs_to :last_pipeline, class_name: 'Ci::Pipeline', foreign_key: :last_pipeline_id belongs_to :last_pipeline, class_name: 'Ci::Pipeline', foreign_key: :last_pipeline_id
...@@ -13,13 +12,11 @@ module Ci ...@@ -13,13 +12,11 @@ module Ci
validates :data, json_schema: { filename: "daily_build_group_report_result_data" } validates :data, json_schema: { filename: "daily_build_group_report_result_data" }
scope :with_included_projects, -> { includes(:project) }
scope :by_ref_path, -> (ref_path) { where(ref_path: ref_path) } scope :by_ref_path, -> (ref_path) { where(ref_path: ref_path) }
scope :by_projects, -> (ids) { where(project_id: ids) } scope :by_projects, -> (ids) { where(project_id: ids) }
scope :by_group, -> (group_id) { where(group_id: group_id) } scope :by_group, -> (group_id) { where(group_id: group_id) }
scope :with_coverage, -> { where("(data->'coverage') IS NOT NULL") } scope :with_coverage, -> { where("(data->'coverage') IS NOT NULL") }
scope :with_default_branch, -> { where(default_branch: true) } scope :with_default_branch, -> { where(default_branch: true) }
scope :by_date, -> (start_date) { where(date: report_window(start_date)..Date.current) }
scope :by_dates, -> (start_date, end_date) { where(date: start_date..end_date) } scope :by_dates, -> (start_date, end_date) { where(date: start_date..end_date) }
scope :ordered_by_date_and_group_name, -> { order(date: :desc, group_name: :asc) } scope :ordered_by_date_and_group_name, -> { order(date: :desc, group_name: :asc) }
...@@ -29,13 +26,6 @@ module Ci ...@@ -29,13 +26,6 @@ module Ci
def upsert_reports(data) def upsert_reports(data)
upsert_all(data, unique_by: :index_daily_build_group_report_results_unique_columns) if data.any? upsert_all(data, unique_by: :index_daily_build_group_report_results_unique_columns) if data.any?
end end
def report_window(start_date)
default_date = REPORT_WINDOW.ago.to_date
date = Date.parse(start_date) rescue default_date
[date, default_date].max
end
end end
end end
end end
......
...@@ -9,6 +9,8 @@ module EE ...@@ -9,6 +9,8 @@ module EE
# Added arguments: # Added arguments:
# params: # params:
# group: integer # group: integer
# group_activity: boolean
#
module DailyBuildGroupReportResultsFinder module DailyBuildGroupReportResultsFinder
extend ::Gitlab::Utils::Override extend ::Gitlab::Utils::Override
...@@ -24,6 +26,17 @@ module EE ...@@ -24,6 +26,17 @@ module EE
private private
override :filter_report_results
def filter_report_results(collection)
collection = super(collection)
collection = by_activity_per_group(collection)
collection
end
def by_activity_per_group(items)
params[:group_activity].present? ? items.activity_per_group : items
end
override :query_allowed? override :query_allowed?
def query_allowed? def query_allowed?
return super unless params[:group] return super unless params[:group]
......
...@@ -12,16 +12,24 @@ module Resolvers ...@@ -12,16 +12,24 @@ module Resolvers
alias_method :group, :object alias_method :group, :object
def resolve(**args) def resolve(**args)
project_ids = group.projects.select(:id) code_coverage_params = params(args)
start_date = args[:start_date].to_s
::Ci::DailyBuildGroupReportResult ::Ci::DailyBuildGroupReportResultsFinder.new(
.with_included_projects params: code_coverage_params,
.by_projects(project_ids) current_user: current_user
.with_coverage ).execute
.with_default_branch end
.by_date(start_date)
.activity_per_group private
def params(args)
{
group: group,
coverage: true,
start_date: args.dig(:start_date).to_s,
end_date: Date.current.to_s,
group_activity: true
}
end end
end end
end end
......
...@@ -17,7 +17,8 @@ RSpec.describe Ci::DailyBuildGroupReportResultsFinder do ...@@ -17,7 +17,8 @@ RSpec.describe Ci::DailyBuildGroupReportResultsFinder do
let(:start_date) { '2020-03-09' } let(:start_date) { '2020-03-09' }
let(:end_date) { '2020-03-10' } let(:end_date) { '2020-03-10' }
let(:limit) { nil } let(:limit) { nil }
let(:sort) { true } let(:sort) { false }
let(:group_activity) { nil }
let(:params) do let(:params) do
{ {
...@@ -27,7 +28,8 @@ RSpec.describe Ci::DailyBuildGroupReportResultsFinder do ...@@ -27,7 +28,8 @@ RSpec.describe Ci::DailyBuildGroupReportResultsFinder do
start_date: start_date, start_date: start_date,
end_date: end_date, end_date: end_date,
sort: sort, sort: sort,
limit: limit limit: limit,
group_activity: group_activity
} }
end end
...@@ -40,8 +42,12 @@ RSpec.describe Ci::DailyBuildGroupReportResultsFinder do ...@@ -40,8 +42,12 @@ RSpec.describe Ci::DailyBuildGroupReportResultsFinder do
group.add_reporter(current_user) group.add_reporter(current_user)
end end
it 'returns coverages belonging to the group' do context 'when sort is true' do
expect(coverages).to contain_exactly(rspec_coverage, karma_coverage) let(:sort) { true }
it 'returns coverages belonging to the group' do
expect(coverages).to contain_exactly(rspec_coverage, karma_coverage)
end
end end
context 'with a limit below 1000' do context 'with a limit below 1000' do
...@@ -65,6 +71,31 @@ RSpec.describe Ci::DailyBuildGroupReportResultsFinder do ...@@ -65,6 +71,31 @@ RSpec.describe Ci::DailyBuildGroupReportResultsFinder do
expect(coverages.limit_value).to eq(Ci::DailyBuildGroupReportResultsFinder::MAX_ITEMS) expect(coverages.limit_value).to eq(Ci::DailyBuildGroupReportResultsFinder::MAX_ITEMS)
end end
end end
context 'with group_activity' do
let(:group_activity) { true }
let_it_be(:karma_coverage_2) { create_daily_coverage('karma', 89.0, '2020-03-10', karma_project, group) }
it 'returns the group activity aggregated data' do
expected_results = [
{
average_coverage: 89.0,
coverage_count: 1,
project_count: 1,
date: '2020-03-09'.to_date
},
{
average_coverage: 92.0,
coverage_count: 2,
project_count: 2,
date: '2020-03-10'.to_date
}
]
expect(coverages).to eq(expected_results)
end
end
end end
context 'without permmissions' do context 'without permmissions' do
......
...@@ -16,8 +16,8 @@ RSpec.describe Resolvers::Ci::CodeCoverageActivitiesResolver do ...@@ -16,8 +16,8 @@ RSpec.describe Resolvers::Ci::CodeCoverageActivitiesResolver do
let(:start_date) { 1.day.ago.to_date.to_s } let(:start_date) { 1.day.ago.to_date.to_s }
context 'when group has projects with coverage' do context 'when group has projects with coverage' do
let!(:coverage_1) { create(:ci_daily_build_group_report_result, project: project_1) } let!(:coverage_1) { create(:ci_daily_build_group_report_result, project: project_1, group: group) }
let!(:coverage_2) { create(:ci_daily_build_group_report_result, project: project_2) } let!(:coverage_2) { create(:ci_daily_build_group_report_result, project: project_2, group: group) }
it 'returns coverage activity for the group' do it 'returns coverage activity for the group' do
expected_results = expected_activities( expected_results = expected_activities(
...@@ -42,8 +42,8 @@ RSpec.describe Resolvers::Ci::CodeCoverageActivitiesResolver do ...@@ -42,8 +42,8 @@ RSpec.describe Resolvers::Ci::CodeCoverageActivitiesResolver do
end end
context 'when coverage is included within start date' do context 'when coverage is included within start date' do
let!(:coverage_1) { create(:ci_daily_build_group_report_result, project: project_1, date: 1.week.ago) } let!(:coverage_1) { create(:ci_daily_build_group_report_result, project: project_1, date: 1.week.ago, group: group) }
let!(:coverage_2) { create(:ci_daily_build_group_report_result, project: project_1, date: 1.week.ago, group_name: 'karma') } let!(:coverage_2) { create(:ci_daily_build_group_report_result, project: project_1, date: 1.week.ago, group_name: 'karma', group: group) }
let(:start_date) { 1.week.ago.to_date.to_s } let(:start_date) { 1.week.ago.to_date.to_s }
it 'returns coverage from the start_date' do it 'returns coverage from the start_date' do
......
...@@ -372,12 +372,12 @@ RSpec.describe 'getting group information' do ...@@ -372,12 +372,12 @@ RSpec.describe 'getting group information' do
end end
context 'when default sorting' do context 'when default sorting' do
let_it_be(:cov_1) { create(:ci_daily_build_group_report_result, project: project_1, coverage: 77.0) } let_it_be(:cov_1) { create(:ci_daily_build_group_report_result, project: project_1, coverage: 77.0, group: group) }
let_it_be(:cov_2) { create(:ci_daily_build_group_report_result, project: project_2, coverage: 88.8, date: 1.week.ago) } let_it_be(:cov_2) { create(:ci_daily_build_group_report_result, project: project_2, coverage: 88.8, date: 1.week.ago, group: group) }
let_it_be(:cov_3) { create(:ci_daily_build_group_report_result, project: project_1, coverage: 66.6, date: 2.weeks.ago) } let_it_be(:cov_3) { create(:ci_daily_build_group_report_result, project: project_1, coverage: 66.6, date: 2.weeks.ago, group: group) }
let_it_be(:cov_4) { create(:ci_daily_build_group_report_result, project: project_2, coverage: 99.9, date: 3.weeks.ago) } let_it_be(:cov_4) { create(:ci_daily_build_group_report_result, project: project_2, coverage: 99.9, date: 3.weeks.ago, group: group) }
let_it_be(:cov_5) { create(:ci_daily_build_group_report_result, project: project_1, coverage: 44.4, date: 4.weeks.ago) } let_it_be(:cov_5) { create(:ci_daily_build_group_report_result, project: project_1, coverage: 44.4, date: 4.weeks.ago, group: group) }
let_it_be(:cov_6) { create(:ci_daily_build_group_report_result, project: project_1, coverage: 100.0, date: 6.weeks.ago) } let_it_be(:cov_6) { create(:ci_daily_build_group_report_result, project: project_1, coverage: 100.0, date: 6.weeks.ago, group: group) }
let(:start_date) { 5.weeks.ago.to_date.to_s } let(:start_date) { 5.weeks.ago.to_date.to_s }
......
...@@ -162,39 +162,5 @@ RSpec.describe Ci::DailyBuildGroupReportResult do ...@@ -162,39 +162,5 @@ RSpec.describe Ci::DailyBuildGroupReportResult do
end end
end end
end end
describe '.by_date' do
subject(:coverages) { described_class.by_date(start_date) }
let!(:coverage_1) { create(:ci_daily_build_group_report_result, date: 1.week.ago) }
context 'when project has several coverage' do
let!(:coverage_2) { create(:ci_daily_build_group_report_result, date: 2.weeks.ago) }
let(:start_date) { 1.week.ago.to_date.to_s }
it 'returns the coverage from the start_date' do
expect(coverages).to contain_exactly(coverage_1)
end
end
context 'when start_date is over 90 days' do
let!(:coverage_2) { create(:ci_daily_build_group_report_result, date: 90.days.ago) }
let!(:coverage_3) { create(:ci_daily_build_group_report_result, date: 91.days.ago) }
let(:start_date) { 1.year.ago.to_date.to_s }
it 'returns the coverage in the last 90 days' do
expect(coverages).to contain_exactly(coverage_1, coverage_2)
end
end
context 'when start_date is not a string' do
let!(:coverage_2) { create(:ci_daily_build_group_report_result, date: 90.days.ago) }
let(:start_date) { 1.week.ago }
it 'returns the coverage in the last 90 days' do
expect(coverages).to contain_exactly(coverage_1, coverage_2)
end
end
end
end end
end end
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