forked from snowplow/snowplow-javascript-tracker
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathactivityCallback.test.ts
More file actions
102 lines (83 loc) · 3.21 KB
/
activityCallback.test.ts
File metadata and controls
102 lines (83 loc) · 3.21 KB
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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
import F from 'lodash/fp';
import { pageSetup } from '../integration/helpers';
declare var trackPageView: () => void;
declare var findMaxX: () => number;
declare var findMaxY: () => number;
declare var getCurrentPageViewId: () => void;
declare var findFirstEventForPageViewId: (id: string) => Record<string, unknown>;
declare var findLastEventForPageViewId: (id: string) => Record<string, unknown>;
describe('Activity tracking with callbacks', () => {
const browserName = 'browserName' in browser.capabilities && browser.capabilities.browserName;
if (browserName === 'internet explorer') {
fit('Skip IE', () => {});
return;
}
beforeAll(async () => {
await pageSetup();
});
it('reports events on scroll', async () => {
await browser.url('/activity-callback.html?test1');
await browser.waitUntil(async () => (await $('#init').getText()) === 'true', {
timeout: 5000,
timeoutMsg: 'expected init after 5s',
interval: 250,
});
await $('#bottomRight').scrollIntoView();
await browser.waitUntil(async () => +(await $('#numEvents').getText()) >= 1, {
timeout: 10000,
timeoutMsg: 'expected > 1 event after 10s',
});
const [maxX, maxY] = await browser.execute(() => {
return [findMaxX(), findMaxY()];
});
expect(maxX).toBeGreaterThan(100);
expect(maxY).toBeGreaterThan(100);
});
it('carries pageviewid change through and resets scroll', async () => {
await browser.url('/activity-callback.html?test2');
await browser.waitUntil(async () => (await $('#init').getText()) === 'true', {
timeout: 5000,
timeoutMsg: 'expected init after 5s',
interval: 250,
});
await browser.execute(() => window.scrollTo(0, 0));
await browser.execute(() => {
getCurrentPageViewId();
});
const firstPageViewId = await $('#currentPageViewId').getText();
await $('#bottomRight').scrollIntoView();
await $('#middle').scrollIntoView();
await browser.waitUntil(async () => +(await $('#numEvents').getText()) >= 1, {
timeout: 10000,
timeoutMsg: 'expected > 1 event after 10s',
});
await browser.execute(() => {
trackPageView();
});
await $('#bottomRight').scrollIntoView();
await browser.waitUntil(async () => +(await $('#numEvents').getText()) > 1, {
timeout: 10000,
timeoutMsg: 'expected > 1 event after 10s',
});
await browser.execute(() => {
getCurrentPageViewId();
});
const secondPageViewId = await $('#currentPageViewId').getText();
// sanity check
expect(firstPageViewId).not.toEqual(secondPageViewId);
const first = await browser.execute((id) => {
return findFirstEventForPageViewId(id);
}, firstPageViewId);
const second = await browser.execute((id) => {
return findLastEventForPageViewId(id);
}, secondPageViewId);
const getMinXY = F.at(['minXOffset', 'minYOffset']);
// the first page view starts at 0,0
expect(getMinXY(first)).toEqual([0, 0]);
// but the second starts at #bottomRight and only moves as far as #middle
// so there is no way it can get to 0,0
const [secondX, secondY] = getMinXY(second);
expect(secondX).toBeGreaterThan(0);
expect(secondY).toBeGreaterThan(0);
});
});