Commit 51002673 authored by Dmytro Zaporozhets (DZ)'s avatar Dmytro Zaporozhets (DZ)

Merge branch '229918-fix-some-issue-events' into 'master'

Fix usage data tracking for some issue events

See merge request gitlab-org/gitlab!49571
parents d83550ac efc275a6
...@@ -15,7 +15,6 @@ class ResourceLabelEvent < ResourceEvent ...@@ -15,7 +15,6 @@ class ResourceLabelEvent < ResourceEvent
validate :exactly_one_issuable validate :exactly_one_issuable
after_save :expire_etag_cache after_save :expire_etag_cache
after_save :usage_metrics
after_destroy :expire_etag_cache after_destroy :expire_etag_cache
enum action: { enum action: {
...@@ -114,16 +113,6 @@ class ResourceLabelEvent < ResourceEvent ...@@ -114,16 +113,6 @@ class ResourceLabelEvent < ResourceEvent
def discussion_id_key def discussion_id_key
[self.class.name, created_at, user_id] [self.class.name, created_at, user_id]
end end
def for_issue?
issue_id.present?
end
def usage_metrics
return unless for_issue?
Gitlab::UsageDataCounters::IssueActivityUniqueCounter.track_issue_label_changed_action(author: user)
end
end end
ResourceLabelEvent.prepend_if_ee('EE::ResourceLabelEvent') ResourceLabelEvent.prepend_if_ee('EE::ResourceLabelEvent')
...@@ -11,7 +11,7 @@ class ResourceStateEvent < ResourceEvent ...@@ -11,7 +11,7 @@ class ResourceStateEvent < ResourceEvent
# state is used for issue and merge request states. # state is used for issue and merge request states.
enum state: Issue.available_states.merge(MergeRequest.available_states).merge(reopened: 5) enum state: Issue.available_states.merge(MergeRequest.available_states).merge(reopened: 5)
after_save :usage_metrics after_create :issue_usage_metrics
def self.issuable_attrs def self.issuable_attrs
%i(issue merge_request).freeze %i(issue merge_request).freeze
...@@ -27,7 +27,7 @@ class ResourceStateEvent < ResourceEvent ...@@ -27,7 +27,7 @@ class ResourceStateEvent < ResourceEvent
private private
def usage_metrics def issue_usage_metrics
return unless for_issue? return unless for_issue?
case state case state
......
...@@ -13,7 +13,7 @@ class ResourceTimeboxEvent < ResourceEvent ...@@ -13,7 +13,7 @@ class ResourceTimeboxEvent < ResourceEvent
remove: 2 remove: 2
} }
after_save :usage_metrics after_create :issue_usage_metrics
def self.issuable_attrs def self.issuable_attrs
%i(issue merge_request).freeze %i(issue merge_request).freeze
...@@ -25,7 +25,13 @@ class ResourceTimeboxEvent < ResourceEvent ...@@ -25,7 +25,13 @@ class ResourceTimeboxEvent < ResourceEvent
private private
def usage_metrics def for_issue?
issue_id.present?
end
def issue_usage_metrics
return unless for_issue?
case self case self
when ResourceMilestoneEvent when ResourceMilestoneEvent
Gitlab::UsageDataCounters::IssueActivityUniqueCounter.track_issue_milestone_changed_action(author: user) Gitlab::UsageDataCounters::IssueActivityUniqueCounter.track_issue_milestone_changed_action(author: user)
......
...@@ -24,6 +24,8 @@ module ResourceEvents ...@@ -24,6 +24,8 @@ module ResourceEvents
Gitlab::Database.bulk_insert(ResourceLabelEvent.table_name, labels) # rubocop:disable Gitlab/BulkInsert Gitlab::Database.bulk_insert(ResourceLabelEvent.table_name, labels) # rubocop:disable Gitlab/BulkInsert
resource.expire_note_etag_cache resource.expire_note_etag_cache
Gitlab::UsageDataCounters::IssueActivityUniqueCounter.track_issue_label_changed_action(author: user) if resource.is_a?(Issue)
end end
private private
......
---
title: Fix usage data tracking of some issue events
merge_request: 49571
author:
type: fixed
...@@ -6,8 +6,10 @@ module EE ...@@ -6,8 +6,10 @@ module EE
private private
override :usage_metrics override :issue_usage_metrics
def usage_metrics def issue_usage_metrics
return unless for_issue?
case self case self
when ResourceIterationEvent when ResourceIterationEvent
::Gitlab::UsageDataCounters::IssueActivityUniqueCounter.track_issue_iteration_changed_action(author: user) ::Gitlab::UsageDataCounters::IssueActivityUniqueCounter.track_issue_iteration_changed_action(author: user)
......
...@@ -4,12 +4,4 @@ class ResourceWeightEvent < ResourceEvent ...@@ -4,12 +4,4 @@ class ResourceWeightEvent < ResourceEvent
include IssueResourceEvent include IssueResourceEvent
validates :issue, presence: true validates :issue, presence: true
after_save :usage_metrics
private
def usage_metrics
Gitlab::UsageDataCounters::IssueActivityUniqueCounter.track_issue_weight_changed_action(author: user)
end
end end
...@@ -42,7 +42,7 @@ module EE ...@@ -42,7 +42,7 @@ module EE
def handle_weight_change def handle_weight_change
return unless issuable.previous_changes.include?('weight') return unless issuable.previous_changes.include?('weight')
::ResourceEvents::ChangeWeightService.new([issuable], current_user, Time.current).execute ::ResourceEvents::ChangeWeightService.new(issuable, current_user, Time.current).execute
end end
def handle_health_status_change def handle_health_status_change
......
# frozen_string_literal: true
module EE
module ResourceEvents
class ChangeWeightService
attr_reader :resources, :user, :event_created_at
def initialize(resources, user, created_at)
@resources = resources
@user = user
@event_created_at = created_at
end
def execute
unless resource_weight_changes.empty?
::Gitlab::Database.bulk_insert(ResourceWeightEvent.table_name, resource_weight_changes) # rubocop:disable Gitlab/BulkInsert
resources.each(&:expire_note_etag_cache)
end
end
private
def resource_weight_changes
@weight_changes ||= resources.map do |resource|
changes = []
base_data = { user_id: user.id, issue_id: resource.id }
changes << base_data.merge({ weight: resource.previous_weight, created_at: resource.previous_updated_at }) if resource.first_weight_event?
changes << base_data.merge({ weight: resource.weight, created_at: event_created_at })
end.flatten
end
end
end
end
...@@ -2,31 +2,31 @@ ...@@ -2,31 +2,31 @@
module ResourceEvents module ResourceEvents
class ChangeWeightService class ChangeWeightService
attr_reader :resources, :user, :event_created_at attr_reader :resource, :user, :event_created_at
def initialize(resources, user, created_at) def initialize(resource, user, created_at)
@resources = resources @resource = resource
@user = user @user = user
@event_created_at = created_at @event_created_at = created_at
end end
def execute def execute
unless resource_weight_changes.empty? ::Gitlab::Database.bulk_insert(ResourceWeightEvent.table_name, resource_weight_changes) # rubocop:disable Gitlab/BulkInsert
::Gitlab::Database.bulk_insert(ResourceWeightEvent.table_name, resource_weight_changes) # rubocop:disable Gitlab/BulkInsert resource.expire_note_etag_cache
resources.each(&:expire_note_etag_cache)
end Gitlab::UsageDataCounters::IssueActivityUniqueCounter.track_issue_weight_changed_action(author: user)
end end
private private
def resource_weight_changes def resource_weight_changes
@weight_changes ||= resources.map do |resource| changes = []
changes = [] base_data = { user_id: user.id, issue_id: resource.id }
base_data = { user_id: user.id, issue_id: resource.id }
changes << base_data.merge({ weight: resource.previous_weight, created_at: resource.previous_updated_at }) if resource.first_weight_event?
changes << base_data.merge({ weight: resource.weight, created_at: event_created_at })
changes << base_data.merge({ weight: resource.previous_weight, created_at: resource.previous_updated_at }) if resource.first_weight_event? changes
changes << base_data.merge({ weight: resource.weight, created_at: event_created_at })
end.flatten
end end
end end
end end
...@@ -73,14 +73,4 @@ RSpec.describe ResourceWeightEvent, type: :model do ...@@ -73,14 +73,4 @@ RSpec.describe ResourceWeightEvent, type: :model do
expect(event.discussion_id).to eq('73d167c478') expect(event.discussion_id).to eq('73d167c478')
end end
end end
context 'callbacks' do
describe '#usage_metrics' do
it 'tracks changed weights' do
expect(Gitlab::UsageDataCounters::IssueActivityUniqueCounter).to receive(:track_issue_weight_changed_action).with(author: user1)
create(:resource_weight_event, issue: issue1, user: user1)
end
end
end
end end
...@@ -8,7 +8,7 @@ RSpec.describe ResourceEvents::ChangeWeightService do ...@@ -8,7 +8,7 @@ RSpec.describe ResourceEvents::ChangeWeightService do
let(:issue) { create(:issue, weight: 3) } let(:issue) { create(:issue, weight: 3) }
let(:created_at_time) { Time.utc(2019, 1, 1, 12, 30, 48, '123.123'.to_r) } let(:created_at_time) { Time.utc(2019, 1, 1, 12, 30, 48, '123.123'.to_r) }
subject { described_class.new([issue], user, created_at_time).execute } subject { described_class.new(issue, user, created_at_time).execute }
before do before do
ResourceWeightEvent.new(issue: issue, user: user).save! ResourceWeightEvent.new(issue: issue, user: user).save!
...@@ -51,31 +51,16 @@ RSpec.describe ResourceEvents::ChangeWeightService do ...@@ -51,31 +51,16 @@ RSpec.describe ResourceEvents::ChangeWeightService do
end end
end end
it 'tracks issue usage data counters' do
expect(Gitlab::UsageDataCounters::IssueActivityUniqueCounter).to receive(:track_issue_weight_changed_action).with(author: user)
subject
end
def expect_event_record(record, weight:, created_at:) def expect_event_record(record, weight:, created_at:)
expect(record.issue).to eq(issue) expect(record.issue).to eq(issue)
expect(record.user).to eq(user) expect(record.user).to eq(user)
expect(record.weight).to eq(weight) expect(record.weight).to eq(weight)
expect(record.created_at).to be_like_time(created_at) expect(record.created_at).to be_like_time(created_at)
end end
describe 'bulk issue weight updates' do
let(:issues) { create_list(:issue, 3, weight: 1) }
before do
issues.each { |issue| issue.update!(weight: 3) }
end
it 'bulk insert weight changes' do
expect do
described_class.new(issues, user, created_at_time).execute
end.to change { ResourceWeightEvent.count }.by(6)
end
it 'calls first_weight_event? once per resource' do
service = described_class.new(issues, user, created_at_time)
allow(service).to receive(:first_weight_event?).exactly(3).times
service.execute
end
end
end end
...@@ -51,14 +51,6 @@ RSpec.describe ResourceLabelEvent, type: :model do ...@@ -51,14 +51,6 @@ RSpec.describe ResourceLabelEvent, type: :model do
end end
context 'callbacks' do context 'callbacks' do
describe '#usage_metrics' do
it 'tracks changed labels' do
expect(Gitlab::UsageDataCounters::IssueActivityUniqueCounter).to receive(:track_issue_label_changed_action)
subject.save!
end
end
describe '#expire_etag_cache' do describe '#expire_etag_cache' do
def expect_expiration(issue) def expect_expiration(issue)
expect_next_instance_of(Gitlab::EtagCaching::Store) do |instance| expect_next_instance_of(Gitlab::EtagCaching::Store) do |instance|
......
...@@ -41,7 +41,7 @@ RSpec.describe ResourceStateEvent, type: :model do ...@@ -41,7 +41,7 @@ RSpec.describe ResourceStateEvent, type: :model do
end end
context 'callbacks' do context 'callbacks' do
describe '#usage_metrics' do describe '#issue_usage_metrics' do
it 'tracks closed issues' do it 'tracks closed issues' do
expect(Gitlab::UsageDataCounters::IssueActivityUniqueCounter).to receive(:track_issue_closed_action) expect(Gitlab::UsageDataCounters::IssueActivityUniqueCounter).to receive(:track_issue_closed_action)
...@@ -53,6 +53,12 @@ RSpec.describe ResourceStateEvent, type: :model do ...@@ -53,6 +53,12 @@ RSpec.describe ResourceStateEvent, type: :model do
create(described_class.name.underscore.to_sym, issue: issue, state: described_class.states[:reopened]) create(described_class.name.underscore.to_sym, issue: issue, state: described_class.states[:reopened])
end end
it 'does not track merge requests' do
expect(Gitlab::UsageDataCounters::IssueActivityUniqueCounter).not_to receive(:track_issue_closed_action)
create(described_class.name.underscore.to_sym, merge_request: merge_request, state: described_class.states[:closed])
end
end end
end end
end end
...@@ -10,7 +10,7 @@ RSpec.describe ResourceEvents::ChangeLabelsService do ...@@ -10,7 +10,7 @@ RSpec.describe ResourceEvents::ChangeLabelsService do
describe '.change_labels' do describe '.change_labels' do
subject { described_class.new(resource, author).execute(added_labels: added, removed_labels: removed) } subject { described_class.new(resource, author).execute(added_labels: added, removed_labels: removed) }
let(:labels) { create_list(:label, 2, project: project) } let_it_be(:labels) { create_list(:label, 2, project: project) }
def expect_label_event(event, label, action) def expect_label_event(event, label, action)
expect(event.user).to eq(author) expect(event.user).to eq(author)
...@@ -57,5 +57,28 @@ RSpec.describe ResourceEvents::ChangeLabelsService do ...@@ -57,5 +57,28 @@ RSpec.describe ResourceEvents::ChangeLabelsService do
expect { subject }.to change { resource.resource_label_events.count }.from(0).to(2) expect { subject }.to change { resource.resource_label_events.count }.from(0).to(2)
end end
end end
describe 'usage data' do
let(:added) { [labels[0]] }
let(:removed) { [labels[1]] }
context 'when resource is an issue' do
it 'tracks changed labels' do
expect(Gitlab::UsageDataCounters::IssueActivityUniqueCounter).to receive(:track_issue_label_changed_action)
subject
end
end
context 'when resource is a merge request' do
let(:resource) { create(:merge_request, source_project: project) }
it 'does not track changed labels' do
expect(Gitlab::UsageDataCounters::IssueActivityUniqueCounter).not_to receive(:track_issue_label_changed_action)
subject
end
end
end
end end
end end
...@@ -75,11 +75,17 @@ RSpec.shared_examples 'timebox resource event actions' do ...@@ -75,11 +75,17 @@ RSpec.shared_examples 'timebox resource event actions' do
end end
RSpec.shared_examples 'timebox resource tracks issue metrics' do |type| RSpec.shared_examples 'timebox resource tracks issue metrics' do |type|
describe '#usage_metrics' do describe '#issue_usage_metrics' do
it 'tracks usage' do it 'tracks usage for issues' do
expect(Gitlab::UsageDataCounters::IssueActivityUniqueCounter).to receive(:"track_issue_#{type}_changed_action") expect(Gitlab::UsageDataCounters::IssueActivityUniqueCounter).to receive(:"track_issue_#{type}_changed_action")
create(described_class.name.underscore.to_sym, issue: create(:issue)) create(described_class.name.underscore.to_sym, issue: create(:issue))
end end
it 'does not track usage for merge requests' do
expect(Gitlab::UsageDataCounters::IssueActivityUniqueCounter).not_to receive(:"track_issue_#{type}_changed_action")
create(described_class.name.underscore.to_sym, merge_request: create(:merge_request))
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