summaryrefslogtreecommitdiff
path: root/spec/frontend/experimentation/experiment_tracking_spec.js
blob: 20f45a7015a16da2d1a635a9f639a5c37e6fc137 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
import { TRACKING_CONTEXT_SCHEMA } from '~/experimentation/constants';
import ExperimentTracking from '~/experimentation/experiment_tracking';
import { getExperimentData } from '~/experimentation/utils';
import Tracking from '~/tracking';

let experimentTracking;
let label;
let property;

jest.mock('~/tracking');
jest.mock('~/experimentation/utils', () => ({ getExperimentData: jest.fn() }));

const setup = () => {
  experimentTracking = new ExperimentTracking('sidebar_experiment', { label, property });
};

beforeEach(() => {
  document.body.dataset.page = 'issues-page';
});

afterEach(() => {
  label = undefined;
  property = undefined;
});

describe('event', () => {
  beforeEach(() => {
    getExperimentData.mockReturnValue(undefined);
  });

  describe('when experiment data exists for experimentName', () => {
    beforeEach(() => {
      getExperimentData.mockReturnValue('experiment-data');
      setup();
    });

    describe('when providing options', () => {
      label = 'sidebar-drawer';
      property = 'dark-mode';

      it('passes them to the tracking call', () => {
        experimentTracking.event('click_sidebar_close');

        expect(Tracking.event).toHaveBeenCalledTimes(1);
        expect(Tracking.event).toHaveBeenCalledWith('issues-page', 'click_sidebar_close', {
          label: 'sidebar-drawer',
          property: 'dark-mode',
          context: {
            schema: TRACKING_CONTEXT_SCHEMA,
            data: 'experiment-data',
          },
        });
      });
    });

    it('tracks with the correct context', () => {
      experimentTracking.event('click_sidebar_trigger');

      expect(Tracking.event).toHaveBeenCalledTimes(1);
      expect(Tracking.event).toHaveBeenCalledWith('issues-page', 'click_sidebar_trigger', {
        context: {
          schema: TRACKING_CONTEXT_SCHEMA,
          data: 'experiment-data',
        },
      });
    });
  });

  describe('when experiment data does NOT exists for the experimentName', () => {
    beforeEach(() => {
      setup();
    });

    it('does not track', () => {
      experimentTracking.event('click_sidebar_close');

      expect(Tracking.event).not.toHaveBeenCalled();
    });
  });
});