Add Gitpod enabled user setting to Usage Data

parent 047a3c49
...@@ -8,6 +8,9 @@ class UserPreference < ApplicationRecord ...@@ -8,6 +8,9 @@ class UserPreference < ApplicationRecord
belongs_to :user belongs_to :user
scope :with_user, -> { joins(:user) }
scope :gitpod_enabled, -> { where(gitpod_enabled: true) }
validates :issue_notes_filter, :merge_request_notes_filter, inclusion: { in: NOTES_FILTERS.values }, presence: true validates :issue_notes_filter, :merge_request_notes_filter, inclusion: { in: NOTES_FILTERS.values }, presence: true
validates :tab_width, numericality: { validates :tab_width, numericality: {
only_integer: true, only_integer: true,
......
---
title: Add Gitpod enabled user setting to Usage Data
merge_request: 42570
author:
type: changed
# frozen_string_literal: true
class AddIndexToUserPreferences < ActiveRecord::Migration[6.0]
include Gitlab::Database::MigrationHelpers
DOWNTIME = false
disable_ddl_transaction!
def up
add_concurrent_index :user_preferences, :gitpod_enabled, name: :index_user_preferences_on_gitpod_enabled
end
def down
remove_concurrent_index :user_preferences, :gitpod_enabled, name: :index_user_preferences_on_gitpod_enabled
end
end
8d14013bcb4d8302c91e331f619fb6f621ab79907aebc421d99c9484ecd7a5d8
\ No newline at end of file
...@@ -21335,6 +21335,8 @@ CREATE UNIQUE INDEX index_user_interacted_projects_on_project_id_and_user_id ON ...@@ -21335,6 +21335,8 @@ CREATE UNIQUE INDEX index_user_interacted_projects_on_project_id_and_user_id ON
CREATE INDEX index_user_interacted_projects_on_user_id ON user_interacted_projects USING btree (user_id); CREATE INDEX index_user_interacted_projects_on_user_id ON user_interacted_projects USING btree (user_id);
CREATE INDEX index_user_preferences_on_gitpod_enabled ON user_preferences USING btree (gitpod_enabled);
CREATE UNIQUE INDEX index_user_preferences_on_user_id ON user_preferences USING btree (user_id); CREATE UNIQUE INDEX index_user_preferences_on_user_id ON user_preferences USING btree (user_id);
CREATE INDEX index_user_statuses_on_user_id ON user_statuses USING btree (user_id); CREATE INDEX index_user_statuses_on_user_id ON user_statuses USING btree (user_id);
......
...@@ -445,8 +445,11 @@ module Gitlab ...@@ -445,8 +445,11 @@ module Gitlab
# rubocop: enable UsageData/LargeTable # rubocop: enable UsageData/LargeTable
# rubocop: enable CodeReuse/ActiveRecord # rubocop: enable CodeReuse/ActiveRecord
# augmented in EE
def user_preferences_usage def user_preferences_usage
{} # augmented in EE {
user_preferences_user_gitpod_enabled: count(UserPreference.with_user.gitpod_enabled.merge(User.active))
}
end end
def merge_requests_users(time_period) def merge_requests_users(time_period)
......
...@@ -102,6 +102,9 @@ FactoryBot.define do ...@@ -102,6 +102,9 @@ FactoryBot.define do
create(:package, project: projects[1]) create(:package, project: projects[1])
create(:package, created_at: 2.months.ago, project: projects[1]) create(:package, created_at: 2.months.ago, project: projects[1])
# User Preferences
create(:user_preference, gitpod_enabled: true)
ProjectFeature.first.update_attribute('repository_access_level', 0) ProjectFeature.first.update_attribute('repository_access_level', 0)
# Create fresh & a month (28-days SMAU) old data # Create fresh & a month (28-days SMAU) old data
......
...@@ -499,6 +499,7 @@ RSpec.describe Gitlab::UsageData, :aggregate_failures do ...@@ -499,6 +499,7 @@ RSpec.describe Gitlab::UsageData, :aggregate_failures do
expect(count_data[:projects_with_packages]).to eq(2) expect(count_data[:projects_with_packages]).to eq(2)
expect(count_data[:packages]).to eq(4) expect(count_data[:packages]).to eq(4)
expect(count_data[:user_preferences_user_gitpod_enabled]).to eq(1)
end end
it 'gathers object store usage correctly' do it 'gathers object store usage correctly' do
......
...@@ -133,6 +133,7 @@ module UsageDataHelpers ...@@ -133,6 +133,7 @@ module UsageDataHelpers
todos todos
uploads uploads
web_hooks web_hooks
user_preferences_user_gitpod_enabled
).push(*SMAU_KEYS) ).push(*SMAU_KEYS)
USAGE_DATA_KEYS = %i( USAGE_DATA_KEYS = %i(
......
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