mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
b1b6d7ae38
The metrics e2e test would fail if the segment events still weren't dispatched when the page loaded. The Segment events are sent on a set interval, so it isn't abnormal for them to lag behind the page load itself. The `waitUntilCalled` utility has been used to wait until all required events have been dispatched. The `wait-until-called` module was converted to an ES5 module, so that it could be used from an e2e test. The optional `callCount` parameter has also been added, to allow waiting for more than one call. The `segmentSpy` had to be converted to a `segmentStub`, to allow the `waitUntilCalled` utility to be used.
57 lines
1.9 KiB
JavaScript
57 lines
1.9 KiB
JavaScript
const { strict: assert } = require('assert')
|
|
const { By, Key } = require('selenium-webdriver')
|
|
const waitUntilCalled = require('../lib/wait-until-called')
|
|
const { withFixtures } = require('./helpers')
|
|
|
|
/**
|
|
* WARNING: These tests must be run using a build created with `yarn build:test:metrics`, so that it has
|
|
* the correct Segment host and write keys set. Otherwise this test will fail.
|
|
*/
|
|
describe('Segment metrics', function () {
|
|
this.timeout(0)
|
|
|
|
it('should send first three Page metric events upon fullscreen page load', async function () {
|
|
const ganacheOptions = {
|
|
accounts: [
|
|
{
|
|
secretKey:
|
|
'0x7C9529A67102755B7E6102D6D950AC5D5863C98713805CEC576B945B15B71EAC',
|
|
balance: 25000000000000000000,
|
|
},
|
|
],
|
|
}
|
|
await withFixtures(
|
|
{
|
|
fixtures: 'metrics-enabled',
|
|
ganacheOptions,
|
|
title: this.test.title,
|
|
mockSegment: true,
|
|
},
|
|
async ({ driver, segmentStub }) => {
|
|
const threeSegmentEventsReceived = waitUntilCalled(segmentStub, null, 3)
|
|
await driver.navigate()
|
|
|
|
const passwordField = await driver.findElement(By.css('#password'))
|
|
await passwordField.sendKeys('correct horse battery staple')
|
|
await passwordField.sendKeys(Key.ENTER)
|
|
|
|
await threeSegmentEventsReceived
|
|
|
|
assert.ok(segmentStub.called, 'Segment should receive metrics')
|
|
|
|
const firstSegmentEvent = segmentStub.getCall(0).args[0]
|
|
assert.equal(firstSegmentEvent.name, 'Home')
|
|
assert.equal(firstSegmentEvent.context.page.path, '/')
|
|
|
|
const secondSegmentEvent = segmentStub.getCall(1).args[0]
|
|
assert.equal(secondSegmentEvent.name, 'Unlock Page')
|
|
assert.equal(secondSegmentEvent.context.page.path, '/unlock')
|
|
|
|
const thirdSegmentEvent = segmentStub.getCall(2).args[0]
|
|
assert.equal(thirdSegmentEvent.name, 'Home')
|
|
assert.equal(thirdSegmentEvent.context.page.path, '/')
|
|
},
|
|
)
|
|
})
|
|
})
|