mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-12 04:37:13 +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
128 lines
4.5 KiB
JavaScript
128 lines
4.5 KiB
JavaScript
const { strict: assert } = require('assert');
|
|
const { convertToHexValue, withFixtures } = require('../helpers');
|
|
const FixtureBuilder = require('../fixture-builder');
|
|
|
|
describe('Dapp interactions', function () {
|
|
let windowHandles;
|
|
let extension;
|
|
let popup;
|
|
const ganacheOptions = {
|
|
accounts: [
|
|
{
|
|
secretKey:
|
|
'0x7C9529A67102755B7E6102D6D950AC5D5863C98713805CEC576B945B15B71EAC',
|
|
balance: convertToHexValue(25000000000000000000),
|
|
},
|
|
],
|
|
};
|
|
it('should trigger the add chain confirmation despite MetaMask being locked', async function () {
|
|
await withFixtures(
|
|
{
|
|
dapp: true,
|
|
fixtures: new FixtureBuilder().build(),
|
|
ganacheOptions: {
|
|
...ganacheOptions,
|
|
concurrent: { port: 8546, chainId: 1338 },
|
|
},
|
|
title: this.test.title,
|
|
},
|
|
async ({ driver }) => {
|
|
await driver.navigate();
|
|
await driver.fill('#password', 'correct horse battery staple');
|
|
await driver.press('#password', driver.Key.ENTER);
|
|
|
|
await driver.openNewPage('http://127.0.0.1:8080/');
|
|
windowHandles = await driver.getAllWindowHandles();
|
|
extension = windowHandles[0];
|
|
|
|
// Lock Account
|
|
await driver.switchToWindow(extension);
|
|
await driver.clickElement('.account-menu__icon');
|
|
await driver.clickElement({ text: 'Lock', tag: 'button' });
|
|
|
|
// Trigger Notification
|
|
await driver.switchToWindowWithTitle('E2E Test Dapp', windowHandles);
|
|
await driver.clickElement('#addEthereumChain');
|
|
await driver.waitUntilXWindowHandles(3);
|
|
await driver.switchToWindowWithTitle(
|
|
'MetaMask Notification',
|
|
windowHandles,
|
|
);
|
|
await driver.fill('#password', 'correct horse battery staple');
|
|
await driver.press('#password', driver.Key.ENTER);
|
|
const notification = await driver.isElementPresent({
|
|
text: 'Allow this site to add a network?',
|
|
tag: 'h3',
|
|
});
|
|
|
|
assert.ok(notification, 'Dapp action does not appear in Metamask');
|
|
},
|
|
);
|
|
});
|
|
|
|
it('should connect a second Dapp despite MetaMask being locked', async function () {
|
|
await withFixtures(
|
|
{
|
|
dapp: true,
|
|
fixtures: new FixtureBuilder()
|
|
.withPermissionControllerConnectedToTestDapp()
|
|
.build(),
|
|
ganacheOptions,
|
|
dappOptions: { numberOfDapps: 2 },
|
|
title: this.test.title,
|
|
},
|
|
async ({ driver }) => {
|
|
await driver.navigate();
|
|
await driver.fill('#password', 'correct horse battery staple');
|
|
await driver.press('#password', driver.Key.ENTER);
|
|
|
|
await driver.openNewPage('http://127.0.0.1:8080/');
|
|
windowHandles = await driver.getAllWindowHandles();
|
|
extension = windowHandles[0];
|
|
|
|
// Lock Account
|
|
await driver.switchToWindow(extension);
|
|
await driver.clickElement('.account-menu__icon');
|
|
await driver.clickElement({ text: 'Lock', tag: 'button' });
|
|
|
|
// Connect to Dapp1
|
|
await driver.openNewPage('http://127.0.0.1:8081/');
|
|
await driver.clickElement({ text: 'Connect', tag: 'button' });
|
|
await driver.waitUntilXWindowHandles(4);
|
|
windowHandles = await driver.getAllWindowHandles();
|
|
|
|
popup = await driver.switchToWindowWithTitle(
|
|
'MetaMask Notification',
|
|
windowHandles,
|
|
);
|
|
|
|
await driver.switchToWindow(popup);
|
|
await driver.fill('#password', 'correct horse battery staple');
|
|
await driver.press('#password', driver.Key.ENTER);
|
|
await driver.clickElement({ text: 'Next', tag: 'button' });
|
|
await driver.clickElement({ text: 'Connect', tag: 'button' });
|
|
|
|
// Assert Connection
|
|
await driver.switchToWindow(extension);
|
|
await driver.fill('#password', 'correct horse battery staple');
|
|
await driver.press('#password', driver.Key.ENTER);
|
|
await driver.clickElement(
|
|
'[data-testid ="account-options-menu-button"]',
|
|
);
|
|
await driver.clickElement({ text: 'Connected sites', tag: 'span' });
|
|
const connectedDapp1 = await driver.isElementPresent({
|
|
text: 'http://127.0.0.1:8080',
|
|
tag: 'span',
|
|
});
|
|
const connectedDapp2 = await driver.isElementPresent({
|
|
text: 'http://127.0.0.1:8081',
|
|
tag: 'span',
|
|
});
|
|
|
|
assert.ok(connectedDapp1, 'Account not connected to Dapp1');
|
|
assert.ok(connectedDapp2, 'Account not connected to Dapp2');
|
|
},
|
|
);
|
|
});
|
|
});
|