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-11-15 18:52:08 +01:00
|
|
|
const FixtureBuilder = require('../fixture-builder');
|
2022-07-01 21:46:12 +02:00
|
|
|
|
|
|
|
const downloadsFolder = `${process.cwd()}/test-artifacts/downloads`;
|
|
|
|
|
|
|
|
const stateLogsExist = async () => {
|
|
|
|
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);
|
|
|
|
return true;
|
|
|
|
} catch (e) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
describe('State logs', function () {
|
|
|
|
const ganacheOptions = {
|
|
|
|
accounts: [
|
|
|
|
{
|
|
|
|
secretKey:
|
|
|
|
'0x7C9529A67102755B7E6102D6D950AC5D5863C98713805CEC576B945B15B71EAC',
|
|
|
|
balance: convertToHexValue(25000000000000000000),
|
|
|
|
},
|
|
|
|
],
|
|
|
|
};
|
|
|
|
it('should download state logs for the account', async function () {
|
|
|
|
await withFixtures(
|
|
|
|
{
|
2022-11-15 18:52:08 +01: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
|
2022-07-01 21:46:12 +02:00
|
|
|
await driver.clickElement('.account-menu__icon');
|
|
|
|
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
|
|
|
|
let fileExists;
|
|
|
|
await driver.wait(async () => {
|
|
|
|
fileExists = await stateLogsExist();
|
|
|
|
return fileExists === true;
|
|
|
|
}, 10000);
|
|
|
|
assert.equal(fileExists, true);
|
|
|
|
},
|
|
|
|
);
|
|
|
|
});
|
|
|
|
});
|