From 7e7be2769df7c24413dc6ac92404a31ad2d112f2 Mon Sep 17 00:00:00 2001 From: Bowen Sanders Date: Thu, 8 Dec 2022 12:15:59 -0800 Subject: [PATCH] [FLASK] Create E2E test for tx-insights (#16785) * Created an E2E test for tx-insights. Co-authored-by: Guillaume Roux --- test/e2e/snaps/enums.js | 2 +- test/e2e/snaps/test-snap-txinsights.spec.js | 124 ++++++++++++++++++ .../flask/snap-insight.js | 2 +- 3 files changed, 126 insertions(+), 2 deletions(-) create mode 100644 test/e2e/snaps/test-snap-txinsights.spec.js diff --git a/test/e2e/snaps/enums.js b/test/e2e/snaps/enums.js index dd4708fb6..1ef7435a1 100644 --- a/test/e2e/snaps/enums.js +++ b/test/e2e/snaps/enums.js @@ -1,3 +1,3 @@ module.exports = { - TEST_SNAPS_WEBSITE_URL: 'https://metamask.github.io/test-snaps/4.2.0/', + TEST_SNAPS_WEBSITE_URL: 'https://metamask.github.io/test-snaps/4.3.0/', }; diff --git a/test/e2e/snaps/test-snap-txinsights.spec.js b/test/e2e/snaps/test-snap-txinsights.spec.js new file mode 100644 index 000000000..6a91e4d7b --- /dev/null +++ b/test/e2e/snaps/test-snap-txinsights.spec.js @@ -0,0 +1,124 @@ +const { strict: assert } = require('assert'); +const { withFixtures } = require('../helpers'); +const FixtureBuilder = require('../fixture-builder'); +const { TEST_SNAPS_WEBSITE_URL } = require('./enums'); + +describe('Test Snap TxInsights', function () { + it('tests tx insights functionality', async function () { + const ganacheOptions = { + accounts: [ + { + secretKey: + '0x7C9529A67102755B7E6102D6D950AC5D5863C98713805CEC576B945B15B71EAC', + }, + ], + }; + await withFixtures( + { + fixtures: new FixtureBuilder().build(), + ganacheOptions, + failOnConsoleError: false, + title: this.test.title, + }, + async ({ driver }) => { + await driver.navigate(); + + // enter pw into extension + await driver.fill('#password', 'correct horse battery staple'); + await driver.press('#password', driver.Key.ENTER); + + // navigate to test snaps page and connect + await driver.driver.get(TEST_SNAPS_WEBSITE_URL); + await driver.delay(1000); + + // find and scroll to the bip32 test and connect + const snapButton1 = await driver.findElement('#connectInsightsSnap'); + await driver.scrollToElement(snapButton1); + await driver.delay(1000); + await driver.clickElement('#connectInsightsSnap'); + + // switch to metamask extension and click connect + let windowHandles = await driver.waitUntilXWindowHandles( + 2, + 1000, + 10000, + ); + await driver.switchToWindowWithTitle( + 'MetaMask Notification', + windowHandles, + ); + await driver.clickElement( + { + text: 'Connect', + tag: 'button', + }, + 10000, + ); + + await driver.delay(2000); + + // switch to metamask extension + windowHandles = await driver.waitUntilXWindowHandles(2, 1000, 10000); + + // approve install of snap + await driver.switchToWindowWithTitle( + 'MetaMask Notification', + windowHandles, + ); + await driver.clickElement({ + text: 'Approve & install', + tag: 'button', + }); + + await driver.delay(1000); + + // switch to test-snaps page and get accounts + windowHandles = await driver.waitUntilXWindowHandles(1, 1000, 10000); + await driver.switchToWindowWithTitle('Test Snaps', windowHandles); + await driver.clickElement('#getAccounts'); + await driver.delay(1000); + + // switch back to MetaMask window and deal with dialogs + windowHandles = await driver.waitUntilXWindowHandles(2, 1000, 10000); + await driver.switchToWindowWithTitle( + 'MetaMask Notification', + windowHandles, + ); + await driver.clickElement({ + text: 'Next', + tag: 'button', + }); + await driver.delay(1000); + await driver.clickElement({ + text: 'Connect', + tag: 'button', + }); + + // switch to test-snaps page and send tx + windowHandles = await driver.waitUntilXWindowHandles(1, 1000, 10000); + await driver.switchToWindowWithTitle('Test Snaps', windowHandles); + await driver.clickElement('#sendInsights'); + await driver.delay(1000); + + // switch back to MetaMask window and switch to tx insights pane + windowHandles = await driver.waitUntilXWindowHandles(2, 1000, 10000); + await driver.switchToWindowWithTitle( + 'MetaMask Notification', + windowHandles, + ); + await driver.delay(2000); + await driver.clickElement({ + text: 'TxInsightsTest', + tag: 'button', + }); + + // check that txinsightstest tab contains the right info + await driver.delay(1000); + const txInsightsResult = await driver.findElement( + '[data-testid="Test-0"]', + ); + assert.equal(await txInsightsResult.getText(), 'Test\nSuccessful'); + }, + ); + }); +}); diff --git a/ui/components/app/confirm-page-container/flask/snap-insight.js b/ui/components/app/confirm-page-container/flask/snap-insight.js index d201b1970..6c9e0a839 100644 --- a/ui/components/app/confirm-page-container/flask/snap-insight.js +++ b/ui/components/app/confirm-page-container/flask/snap-insight.js @@ -62,7 +62,7 @@ export const SnapInsight = ({ transaction, origin, chainId, selectedSnap }) => { className="snap-insight__container__data" > {Object.keys(data).map((key, i) => ( -
+