mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-11-26 20:39:08 +01:00
0b4532ec1b
* remove state.json files * move file * Update Readme * Create fixture builder * load test fixture * remove redundant method * update snap tests * update stats tests * update extension tests * update extension tests * Update fixture data * snap test dapp connection * Update fixture data * add onboarding fixture * use onboarding fixture * reuse import account vault * remove unnecessary use of class * use fixture builder in new tests * switch to function * update default fixture * update default fixture * update test * update 1559 test fixttures * update 1559 test fixtures * update 1559 test fixtures * dismiss 3box whats new * remove redundant code * move docs * remove unused code * token detection * use default timeout * remove redundant code * Update fixture builder hide `Protect your funds` dialog remove browser environment remove default network details hide dismiss seed backup reminder recursively merges fixture data * add token to tokencontroller * remove network details * add missing identities to preference controller * remove duplicate properties * update bip-32 to use fixturebuilder * alphabetise snap permissions * update get snaps to use fixturebuilder * Update test-snap-bip-32.spec.js wait for window * add popular network state * update test * lint
69 lines
2.4 KiB
JavaScript
69 lines
2.4 KiB
JavaScript
const { strict: assert } = require('assert');
|
|
const { convertToHexValue, withFixtures } = require('../helpers');
|
|
const FixtureBuilder = require('../fixture-builder');
|
|
|
|
describe('Segment metrics', function () {
|
|
async function mockSegment(mockServer) {
|
|
mockServer.reset();
|
|
await mockServer.forAnyRequest().thenPassThrough();
|
|
return await mockServer
|
|
.forPost('https://api.segment.io/v1/batch')
|
|
.withJsonBodyIncluding({ batch: [{ type: 'page' }] })
|
|
.times(3)
|
|
.thenCallback(() => {
|
|
return {
|
|
statusCode: 200,
|
|
};
|
|
});
|
|
}
|
|
const ganacheOptions = {
|
|
accounts: [
|
|
{
|
|
secretKey:
|
|
'0x7C9529A67102755B7E6102D6D950AC5D5863C98713805CEC576B945B15B71EAC',
|
|
balance: convertToHexValue(25000000000000000000),
|
|
},
|
|
],
|
|
};
|
|
it('should send first three Page metric events upon fullscreen page load', async function () {
|
|
await withFixtures(
|
|
{
|
|
fixtures: new FixtureBuilder()
|
|
.withMetaMetricsController({
|
|
metaMetricsId: 'fake-metrics-id',
|
|
participateInMetaMetrics: true,
|
|
})
|
|
.build(),
|
|
ganacheOptions,
|
|
title: this.test.title,
|
|
failOnConsoleError: false,
|
|
},
|
|
async ({ driver, mockServer }) => {
|
|
const mockedEndpoints = await mockSegment(mockServer);
|
|
await driver.navigate();
|
|
await driver.fill('#password', 'correct horse battery staple');
|
|
await driver.press('#password', driver.Key.ENTER);
|
|
await driver.wait(async () => {
|
|
const isPending = await mockedEndpoints.isPending();
|
|
return isPending === false;
|
|
}, 10000);
|
|
const mockedRequests = await mockedEndpoints.getSeenRequests();
|
|
assert.equal(mockedRequests.length, 3);
|
|
const [firstMock, secondMock, thirdMock] = mockedRequests;
|
|
let [mockJson] = firstMock.body.json.batch;
|
|
let { title, path } = mockJson.context.page;
|
|
assert.equal(title, 'Home');
|
|
assert.equal(path, '/');
|
|
[mockJson] = secondMock.body.json.batch;
|
|
({ title, path } = mockJson.context.page);
|
|
assert.equal(title, 'Unlock Page');
|
|
assert.equal(path, '/unlock');
|
|
[mockJson] = thirdMock.body.json.batch;
|
|
({ title, path } = mockJson.context.page);
|
|
assert.equal(title, 'Home');
|
|
assert.equal(path, '/');
|
|
},
|
|
);
|
|
});
|
|
});
|