2022-07-01 21:46:12 +02:00
|
|
|
const { strict: assert } = require('assert');
|
|
|
|
const { promises: fs } = require('fs');
|
2022-08-09 20:36:32 +02:00
|
|
|
const {
|
|
|
|
convertToHexValue,
|
|
|
|
withFixtures,
|
|
|
|
createDownloadFolder,
|
|
|
|
} = require('../helpers');
|
2022-10-28 10:42:12 +02:00
|
|
|
const FixtureBuilder = require('../fixture-builder');
|
2022-07-01 21:46:12 +02:00
|
|
|
|
|
|
|
const downloadsFolder = `${process.cwd()}/test-artifacts/downloads`;
|
|
|
|
|
2023-03-07 01:00:52 +01:00
|
|
|
const getStateLogsJson = async () => {
|
2022-07-01 21:46:12 +02:00
|
|
|
try {
|
2022-08-08 21:01:38 +02:00
|
|
|
const stateLogs = `${downloadsFolder}/MetaMask state logs.json`;
|
2022-07-01 21:46:12 +02:00
|
|
|
await fs.access(stateLogs);
|
2023-03-07 01:00:52 +01:00
|
|
|
const contents = await fs.readFile(stateLogs);
|
|
|
|
return JSON.parse(contents.toString());
|
2022-07-01 21:46:12 +02:00
|
|
|
} catch (e) {
|
2023-03-07 01:00:52 +01:00
|
|
|
return null;
|
2022-07-01 21:46:12 +02:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
describe('State logs', function () {
|
|
|
|
const ganacheOptions = {
|
|
|
|
accounts: [
|
|
|
|
{
|
|
|
|
secretKey:
|
|
|
|
'0x7C9529A67102755B7E6102D6D950AC5D5863C98713805CEC576B945B15B71EAC',
|
|
|
|
balance: convertToHexValue(25000000000000000000),
|
|
|
|
},
|
|
|
|
],
|
|
|
|
};
|
2023-07-27 19:33:36 +02:00
|
|
|
|
2022-07-01 21:46:12 +02:00
|
|
|
it('should download state logs for the account', async function () {
|
2023-07-27 19:33:36 +02:00
|
|
|
if (process.env.SELENIUM_BROWSER === 'chrome') {
|
|
|
|
// Chrome shows OS level download prompt which can't be dismissed by Selenium
|
|
|
|
this.skip();
|
|
|
|
}
|
2022-07-01 21:46:12 +02:00
|
|
|
await withFixtures(
|
|
|
|
{
|
2022-10-28 10:42:12 +02:00
|
|
|
fixtures: new FixtureBuilder().build(),
|
2022-07-01 21:46:12 +02:00
|
|
|
ganacheOptions,
|
|
|
|
title: this.test.title,
|
|
|
|
failOnConsoleError: false,
|
|
|
|
},
|
|
|
|
async ({ driver }) => {
|
2022-08-09 20:36:32 +02:00
|
|
|
await createDownloadFolder(downloadsFolder);
|
2022-07-01 21:46:12 +02:00
|
|
|
await driver.navigate();
|
|
|
|
await driver.fill('#password', 'correct horse battery staple');
|
|
|
|
await driver.press('#password', driver.Key.ENTER);
|
|
|
|
|
2022-08-08 21:01:38 +02:00
|
|
|
// Download state logs
|
2023-06-01 23:14:38 +02:00
|
|
|
await driver.clickElement(
|
|
|
|
'[data-testid="account-options-menu-button"]',
|
|
|
|
);
|
2022-07-01 21:46:12 +02:00
|
|
|
await driver.clickElement({ text: 'Settings', tag: 'div' });
|
|
|
|
await driver.clickElement({ text: 'Advanced', tag: 'div' });
|
|
|
|
await driver.clickElement({
|
2022-08-08 21:01:38 +02:00
|
|
|
text: 'Download state logs',
|
2022-07-01 21:46:12 +02:00
|
|
|
tag: 'button',
|
|
|
|
});
|
|
|
|
|
|
|
|
// Verify download
|
2023-03-07 01:00:52 +01:00
|
|
|
let info;
|
2022-07-01 21:46:12 +02:00
|
|
|
await driver.wait(async () => {
|
2023-03-07 01:00:52 +01:00
|
|
|
info = await getStateLogsJson();
|
|
|
|
return info !== null;
|
2022-07-01 21:46:12 +02:00
|
|
|
}, 10000);
|
2023-03-07 01:00:52 +01:00
|
|
|
assert.notEqual(info, null);
|
|
|
|
// Verify Json
|
|
|
|
assert.equal(
|
|
|
|
info?.metamask?.identities[
|
|
|
|
'0x5cfe73b6021e818b776b421b1c4db2474086a7e1'
|
|
|
|
].address,
|
|
|
|
'0x5cfe73b6021e818b776b421b1c4db2474086a7e1',
|
|
|
|
);
|
2022-07-01 21:46:12 +02:00
|
|
|
},
|
|
|
|
);
|
|
|
|
});
|
|
|
|
});
|