mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-11-22 18:00:18 +01:00
b73f543b23
* Add 'What's New' notification popup * Move selectors from shared/notifications into ui/ directory * Use keys for localized message in whats new notifications objects, to ensure notifications will be translated. * Remove unused swaps intro popup locale messages * Fix keys of whats new notification locales * Remove notifications messages and descriptions from comment in shared/notifications * Move notifcationActionFunctions to shared/notifications and make it stateless * Get notification data from constants instead of state in whats-new-popup * Code cleanup * Fix build quote reference to swapsEthToken, broken during rebase * Rename notificationFilters to notificationToExclude to clarify its purpose * Documentation for getSortedNotificationsToShow * Move notification action functions from shared/ to whats-new-popup.js * Stop setting swapsWelcomeMessageHasBeenShown to state in app-state controller * Update e2e tests for whats new popup changes * Updating migration files * Addressing feedback part 1 * Addressing feedback part 2 * Remove unnecessary div in whats-new-popup * Change getNotificationsToExclude to getNotificationsToInclude for use in the getSortedNotificationsToShow selector * Delete intro-popup directory and test files * Lint fix * Add notifiction state to address-entry fixture * Use two separate functions for rendering first and subsequent notifications in the whats-new-popup * Ensure that string literals are passed to t for whats new popup text * Update import-ui fixtures to include notificaiton controller state * Remove unnecessary, accidental change confirm-approve * Remove swaps notification in favour of mobile swaps as first notifcation and TBD 3rd notification * Update whats-new-popup to use intersection observer api to detect if notification has been seen * Add notifications to send-edit and threebox e2e test fixtures * Update ui/app/selectors/selectors.js Co-authored-by: Mark Stacey <markjstacey@gmail.com> * Update ui/app/selectors/selectors.js Co-authored-by: Mark Stacey <markjstacey@gmail.com> * Clean up locale code for whats-new-popup notifications * Disconnect observers in whats-new-popup when their callback is first called * Add test case for migration 58 for when the AppStateController does not exist * Rename popover components containerRef to popoverWrapRef * Fix messages.json * Update notification messages and images * Rename popoverWrapRef -> popoverRef in whats-new-popup and popover.component * Only create one observer, and only after images have loaded, in whats-new-popup * Set width and height on whats-new-popup image, instead of setting state on img load * Update ui/app/components/app/whats-new-popup/whats-new-popup.js Co-authored-by: Mark Stacey <markjstacey@gmail.com> * Code clean up in whats new popup re: notification rendering and action functions * Code cleanup in render notification functions of whats-new-popup * Update ui/app/components/app/whats-new-popup/whats-new-popup.js Co-authored-by: Mark Stacey <markjstacey@gmail.com> * lint fix * Update and localize notification dates * Clean up date code in shred/notifications/index.js Co-authored-by: ryanml <ryanlanese@gmail.com> Co-authored-by: Mark Stacey <markjstacey@gmail.com>
183 lines
6.1 KiB
JavaScript
183 lines
6.1 KiB
JavaScript
const { strict: assert } = require('assert');
|
|
const { withFixtures, tinyDelayMs } = require('../helpers');
|
|
const enLocaleMessages = require('../../../app/_locales/en/messages.json');
|
|
|
|
describe('Incremental Security', function () {
|
|
const ganacheOptions = {
|
|
accounts: [
|
|
{
|
|
secretKey:
|
|
'0x250F458997A364988956409A164BA4E16F0F99F916ACDD73ADCD3A1DE30CF8D1',
|
|
balance: 0,
|
|
},
|
|
{
|
|
secretKey:
|
|
'0x53CB0AB5226EEBF4D872113D98332C1555DC304443BEE1CF759D15798D3C55A9',
|
|
balance: 25000000000000000000,
|
|
},
|
|
],
|
|
};
|
|
it('Back up seed phrase from backup reminder', async function () {
|
|
await withFixtures(
|
|
{
|
|
dapp: true,
|
|
fixtures: 'onboarding',
|
|
ganacheOptions,
|
|
title: this.test.title,
|
|
failOnConsoleError: false,
|
|
dappPath: 'send-eth-with-private-key-test',
|
|
},
|
|
async ({ driver }) => {
|
|
await driver.navigate();
|
|
await driver.delay(tinyDelayMs);
|
|
|
|
// clicks the continue button on the welcome screen
|
|
await driver.findElement('.welcome-page__header');
|
|
await driver.clickElement({
|
|
text: enLocaleMessages.getStarted.message,
|
|
tag: 'button',
|
|
});
|
|
|
|
// clicks the "Create New Wallet" option
|
|
await driver.clickElement({ text: 'Create a Wallet', tag: 'button' });
|
|
|
|
// clicks the "No thanks" option on the metametrics opt-in screen
|
|
await driver.clickElement('.btn-default');
|
|
|
|
// accepts a secure password
|
|
await driver.fill(
|
|
'.first-time-flow__form #create-password',
|
|
'correct horse battery staple',
|
|
);
|
|
await driver.fill(
|
|
'.first-time-flow__form #confirm-password',
|
|
'correct horse battery staple',
|
|
);
|
|
await driver.clickElement('.first-time-flow__checkbox');
|
|
await driver.clickElement('.first-time-flow__form button');
|
|
|
|
// renders the seed phrase intro screen'
|
|
await driver.clickElement('.seed-phrase-intro__left button');
|
|
|
|
// skips the seed phrase challenge
|
|
await driver.clickElement({
|
|
text: enLocaleMessages.remindMeLater.message,
|
|
tag: 'button',
|
|
});
|
|
|
|
// closes the what's new popup
|
|
const popover = await driver.findElement('.popover-container');
|
|
|
|
await driver.clickElement('[data-testid="popover-close"]');
|
|
|
|
await popover.waitForElementState('hidden');
|
|
|
|
await driver.clickElement(
|
|
'[data-testid="account-options-menu-button"]',
|
|
);
|
|
await driver.clickElement(
|
|
'[data-testid="account-options-menu__account-details"]',
|
|
);
|
|
|
|
// gets the current accounts address
|
|
const addressInput = await driver.findElement('.readonly-input__input');
|
|
const publicAddress = await addressInput.getAttribute('value');
|
|
|
|
// wait for account modal to be visible
|
|
const accountModal = await driver.findVisibleElement('span .modal');
|
|
|
|
await driver.clickElement('.account-modal__close');
|
|
|
|
// wait for account modal to be removed from DOM
|
|
await accountModal.waitForElementState('hidden');
|
|
|
|
// send to current account from dapp with different provider
|
|
const windowHandles = await driver.getAllWindowHandles();
|
|
const extension = windowHandles[0];
|
|
|
|
// switched to Dapp
|
|
await driver.openNewPage('http://127.0.0.1:8080/');
|
|
|
|
// sends eth to the current account
|
|
await driver.fill('#address', publicAddress);
|
|
await driver.clickElement('#send');
|
|
|
|
await driver.waitForSelector(
|
|
{ css: '#success', text: 'Success' },
|
|
{ timeout: 15000 },
|
|
);
|
|
|
|
// switch to extension
|
|
await driver.switchToWindow(extension);
|
|
|
|
// should have the correct amount of eth
|
|
let currencyDisplay = await driver.waitForSelector({
|
|
css: '.currency-display-component__text',
|
|
text: '1',
|
|
});
|
|
let balance = await currencyDisplay.getText();
|
|
assert.strictEqual(balance, '1');
|
|
|
|
// backs up the seed phrase
|
|
// should show a backup reminder
|
|
const backupReminder = await driver.findElements({
|
|
xpath:
|
|
"//div[contains(@class, 'home-notification__text') and contains(text(), 'Backup your Secret Recovery code to keep your wallet and funds secure')]",
|
|
});
|
|
assert.equal(backupReminder.length, 1);
|
|
|
|
// should take the user to the seedphrase backup screen
|
|
await driver.clickElement('.home-notification__accept-button');
|
|
|
|
// reveals the seed phrase
|
|
await driver.clickElement(
|
|
'.reveal-seed-phrase__secret-blocker .reveal-seed-phrase__reveal-button',
|
|
);
|
|
|
|
const revealedSeedPhrase = await driver.findElement(
|
|
'.reveal-seed-phrase__secret-words',
|
|
);
|
|
const seedPhrase = await revealedSeedPhrase.getText();
|
|
assert.equal(seedPhrase.split(' ').length, 12);
|
|
|
|
await driver.clickElement({
|
|
text: enLocaleMessages.next.message,
|
|
tag: 'button',
|
|
});
|
|
|
|
// selecting the words from seedphrase
|
|
async function clickWordAndWait(word) {
|
|
await driver.clickElement(
|
|
`[data-testid="seed-phrase-sorted"] [data-testid="draggable-seed-${word}"]`,
|
|
);
|
|
await driver.delay(tinyDelayMs);
|
|
}
|
|
|
|
// can retype the seed phrase
|
|
const words = seedPhrase.split(' ');
|
|
|
|
for (const word of words) {
|
|
await clickWordAndWait(word);
|
|
}
|
|
|
|
await driver.clickElement({ text: 'Confirm', tag: 'button' });
|
|
|
|
// can click through the success screen
|
|
await driver.clickElement({ text: 'All Done', tag: 'button' });
|
|
|
|
// should have the correct amount of eth
|
|
currencyDisplay = await driver.waitForSelector({
|
|
css: '.currency-display-component__text',
|
|
text: '1',
|
|
});
|
|
balance = await currencyDisplay.getText();
|
|
|
|
assert.strictEqual(balance, '1');
|
|
|
|
// should not show a backup reminder
|
|
await driver.assertElementNotPresent('.backup-notification');
|
|
},
|
|
);
|
|
});
|
|
});
|