Commit 8b602bd9 authored by Nicolò Maria Mezzopera's avatar Nicolò Maria Mezzopera

Merge branch '276185_alerts_integrations_list_tracking' into 'master'

Fix `view_alert_integrations_list` Snowplow event

See merge request gitlab-org/gitlab!47413
parents 7a2277a7 c50790c1
...@@ -99,7 +99,17 @@ export default { ...@@ -99,7 +99,17 @@ export default {
}; };
}, },
mounted() { mounted() {
const callback = entries => {
const isVisible = entries.some(entry => entry.isIntersecting);
if (isVisible) {
this.trackPageViews(); this.trackPageViews();
this.observer.disconnect();
}
};
this.observer = new IntersectionObserver(callback);
this.observer.observe(this.$el);
}, },
methods: { methods: {
tbodyTrClass(item) { tbodyTrClass(item) {
......
---
title: Fix alerts integration list Snowplow tracking event
merge_request: 47413
author:
type: fixed
import { GlTable, GlIcon, GlButton } from '@gitlab/ui'; import { GlTable, GlIcon, GlButton } from '@gitlab/ui';
import { mount } from '@vue/test-utils'; import { mount } from '@vue/test-utils';
import { useMockIntersectionObserver } from 'helpers/mock_dom_observer';
import Tracking from '~/tracking'; import Tracking from '~/tracking';
import AlertIntegrationsList, { import AlertIntegrationsList, {
i18n, i18n,
...@@ -23,6 +24,7 @@ const mockIntegrations = [ ...@@ -23,6 +24,7 @@ const mockIntegrations = [
describe('AlertIntegrationsList', () => { describe('AlertIntegrationsList', () => {
let wrapper; let wrapper;
const { trigger: triggerIntersection } = useMockIntersectionObserver();
function mountComponent({ data = {}, props = {} } = {}) { function mountComponent({ data = {}, props = {} } = {}) {
wrapper = mount(AlertIntegrationsList, { wrapper = mount(AlertIntegrationsList, {
...@@ -100,12 +102,23 @@ describe('AlertIntegrationsList', () => { ...@@ -100,12 +102,23 @@ describe('AlertIntegrationsList', () => {
describe('Snowplow tracking', () => { describe('Snowplow tracking', () => {
beforeEach(() => { beforeEach(() => {
jest.spyOn(Tracking, 'event');
mountComponent(); mountComponent();
jest.spyOn(Tracking, 'event');
});
it('should NOT track alert list page views when list is collapsed', () => {
triggerIntersection(wrapper.vm.$el, { entry: { isIntersecting: false } });
expect(Tracking.event).not.toHaveBeenCalled();
}); });
it('should track alert list page views', () => { it('should track alert list page views only once when list is expanded', () => {
triggerIntersection(wrapper.vm.$el, { entry: { isIntersecting: true } });
triggerIntersection(wrapper.vm.$el, { entry: { isIntersecting: true } });
triggerIntersection(wrapper.vm.$el, { entry: { isIntersecting: true } });
const { category, action } = trackAlertIntegrationsViewsOptions; const { category, action } = trackAlertIntegrationsViewsOptions;
expect(Tracking.event).toHaveBeenCalledTimes(1);
expect(Tracking.event).toHaveBeenCalledWith(category, action); expect(Tracking.event).toHaveBeenCalledWith(category, action);
}); });
}); });
......
...@@ -3,6 +3,7 @@ import { mount, createLocalVue } from '@vue/test-utils'; ...@@ -3,6 +3,7 @@ import { mount, createLocalVue } from '@vue/test-utils';
import createMockApollo from 'jest/helpers/mock_apollo_helper'; import createMockApollo from 'jest/helpers/mock_apollo_helper';
import waitForPromises from 'helpers/wait_for_promises'; import waitForPromises from 'helpers/wait_for_promises';
import { GlLoadingIcon, GlAlert } from '@gitlab/ui'; import { GlLoadingIcon, GlAlert } from '@gitlab/ui';
import { useMockIntersectionObserver } from 'helpers/mock_dom_observer';
import AlertsSettingsWrapper from '~/alerts_settings/components/alerts_settings_wrapper.vue'; import AlertsSettingsWrapper from '~/alerts_settings/components/alerts_settings_wrapper.vue';
import AlertsSettingsFormOld from '~/alerts_settings/components/alerts_settings_form_old.vue'; import AlertsSettingsFormOld from '~/alerts_settings/components/alerts_settings_form_old.vue';
import AlertsSettingsFormNew from '~/alerts_settings/components/alerts_settings_form_new.vue'; import AlertsSettingsFormNew from '~/alerts_settings/components/alerts_settings_form_new.vue';
...@@ -47,6 +48,7 @@ describe('AlertsSettingsWrapper', () => { ...@@ -47,6 +48,7 @@ describe('AlertsSettingsWrapper', () => {
let wrapper; let wrapper;
let fakeApollo; let fakeApollo;
let destroyIntegrationHandler; let destroyIntegrationHandler;
useMockIntersectionObserver();
const findLoader = () => wrapper.find(IntegrationsList).find(GlLoadingIcon); const findLoader = () => wrapper.find(IntegrationsList).find(GlLoadingIcon);
const findIntegrations = () => wrapper.find(IntegrationsList).findAll('table tbody tr'); const findIntegrations = () => wrapper.find(IntegrationsList).findAll('table tbody tr');
......
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