Commit 54477d44 authored by Felipe Artur's avatar Felipe Artur

Add issues with health status to usage data

Track count of issues with health status on usage data
parent 66f4082d
# frozen_string_literal: true
class AddIndexToIssuesHealthStatus < ActiveRecord::Migration[6.0]
include Gitlab::Database::MigrationHelpers
DOWNTIME = false
INDEX_NAME = 'idx_issues_on_health_status_not_null'
disable_ddl_transaction!
def up
add_concurrent_index(
:issues,
:health_status,
where: 'health_status IS NOT NULL',
name: INDEX_NAME
)
end
def down
remove_concurrent_index_by_name(:issues, INDEX_NAME)
end
end
...@@ -8585,6 +8585,8 @@ CREATE UNIQUE INDEX idx_environment_merge_requests_unique_index ON public.deploy ...@@ -8585,6 +8585,8 @@ CREATE UNIQUE INDEX idx_environment_merge_requests_unique_index ON public.deploy
CREATE INDEX idx_geo_con_rep_updated_events_on_container_repository_id ON public.geo_container_repository_updated_events USING btree (container_repository_id); CREATE INDEX idx_geo_con_rep_updated_events_on_container_repository_id ON public.geo_container_repository_updated_events USING btree (container_repository_id);
CREATE INDEX idx_issues_on_health_status_not_null ON public.issues USING btree (health_status) WHERE (health_status IS NOT NULL);
CREATE INDEX idx_issues_on_project_id_and_created_at_and_id_and_state_id ON public.issues USING btree (project_id, created_at, id, state_id); CREATE INDEX idx_issues_on_project_id_and_created_at_and_id_and_state_id ON public.issues USING btree (project_id, created_at, id, state_id);
CREATE INDEX idx_issues_on_project_id_and_due_date_and_id_and_state_id ON public.issues USING btree (project_id, due_date, id, state_id) WHERE (due_date IS NOT NULL); CREATE INDEX idx_issues_on_project_id_and_due_date_and_id_and_state_id ON public.issues USING btree (project_id, due_date, id, state_id) WHERE (due_date IS NOT NULL);
...@@ -13147,6 +13149,7 @@ COPY "schema_migrations" (version) FROM STDIN; ...@@ -13147,6 +13149,7 @@ COPY "schema_migrations" (version) FROM STDIN;
20200406171857 20200406171857
20200406172135 20200406172135
20200406192059 20200406192059
20200406193427
20200407094005 20200407094005
20200407094923 20200407094923
20200408110856 20200408110856
......
...@@ -222,6 +222,7 @@ but commented out to help encourage others to add to it in the future. --> ...@@ -222,6 +222,7 @@ but commented out to help encourage others to add to it in the future. -->
|issues_with_associated_zoom_link|counts|| |issues_with_associated_zoom_link|counts||
|issues_using_zoom_quick_actions|counts|| |issues_using_zoom_quick_actions|counts||
|issues_with_embedded_grafana_charts_approx|counts|| |issues_with_embedded_grafana_charts_approx|counts||
|issues_with_health_status|counts||
|keys|counts|| |keys|counts||
|label_lists|counts|| |label_lists|counts||
|lfs_objects|counts|| |lfs_objects|counts||
......
...@@ -27,6 +27,7 @@ module EE ...@@ -27,6 +27,7 @@ module EE
end end
scope :on_status_page, -> { joins(project: :status_page_setting).where(status_page_settings: { enabled: true }).public_only } scope :on_status_page, -> { joins(project: :status_page_setting).where(status_page_settings: { enabled: true }).public_only }
scope :counts_by_health_status, -> { reorder(nil).group(:health_status).count } scope :counts_by_health_status, -> { reorder(nil).group(:health_status).count }
scope :with_health_status, -> { where.not(health_status: nil) }
has_one :epic_issue has_one :epic_issue
has_one :epic, through: :epic_issue has_one :epic, through: :epic_issue
......
---
title: Add health status counts to usage data
merge_request: 28964
author:
type: other
...@@ -147,6 +147,7 @@ module EE ...@@ -147,6 +147,7 @@ module EE
feature_flags: count(Operations::FeatureFlag), feature_flags: count(Operations::FeatureFlag),
geo_nodes: count(::GeoNode), geo_nodes: count(::GeoNode),
ldap_group_links: count(::LdapGroupLink), ldap_group_links: count(::LdapGroupLink),
issues_with_health_status: count(::Issue.with_health_status),
ldap_keys: count(::LDAPKey), ldap_keys: count(::LDAPKey),
ldap_users: count(::User.ldap, 'users.id'), ldap_users: count(::User.ldap, 'users.id'),
pod_logs_usages_total: ::Gitlab::UsageCounters::PodLogs.usage_totals[:total], pod_logs_usages_total: ::Gitlab::UsageCounters::PodLogs.usage_totals[:total],
......
...@@ -38,6 +38,10 @@ describe Gitlab::UsageData do ...@@ -38,6 +38,10 @@ describe Gitlab::UsageData do
create(:project_tracing_setting, project: projects[0]) create(:project_tracing_setting, project: projects[0])
create(:operations_feature_flag, project: projects[0]) create(:operations_feature_flag, project: projects[0])
create(:issue, project: projects[1])
create(:issue, health_status: :on_track, project: projects[1])
create(:issue, health_status: :at_risk, project: projects[1])
# for group_view testing # for group_view testing
create(:user) # user with group_view = NULL (should be counted as having default value 'details') create(:user) # user with group_view = NULL (should be counted as having default value 'details')
create(:user, group_view: :details) create(:user, group_view: :details)
...@@ -83,6 +87,7 @@ describe Gitlab::UsageData do ...@@ -83,6 +87,7 @@ describe Gitlab::UsageData do
epics_deepest_relationship_level epics_deepest_relationship_level
feature_flags feature_flags
geo_nodes geo_nodes
issues_with_health_status
ldap_group_links ldap_group_links
ldap_keys ldap_keys
ldap_users ldap_users
...@@ -116,6 +121,7 @@ describe Gitlab::UsageData do ...@@ -116,6 +121,7 @@ describe Gitlab::UsageData do
expect(count_data[:feature_flags]).to eq(1) expect(count_data[:feature_flags]).to eq(1)
expect(count_data[:status_page_projects]).to eq(1) expect(count_data[:status_page_projects]).to eq(1)
expect(count_data[:status_page_issues]).to eq(1) expect(count_data[:status_page_issues]).to eq(1)
expect(count_data[:issues_with_health_status]).to eq(2)
end end
it 'has integer value for epic relationship level' do it 'has integer value for epic relationship level' 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