const { strict: assert } = require('assert'); const { withFixtures } = require('../helpers'); const FixtureBuilder = require('../fixture-builder'); const { TEST_SNAPS_WEBSITE_URL } = require('./enums'); describe('Test Snap Dialog', function () { it('test all three snap_dialog types', async function () { const ganacheOptions = { accounts: [ { secretKey: '0x7C9529A67102755B7E6102D6D950AC5D5863C98713805CEC576B945B15B71EAC', balance: 25000000000000000000, }, ], }; 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 to dialog snap await driver.openNewPage(TEST_SNAPS_WEBSITE_URL); await driver.delay(1000); const dialogButton = await driver.findElement('#connectdialogs'); await driver.scrollToElement(dialogButton); await driver.delay(1000); await driver.clickElement('#connectdialogs'); await driver.delay(1000); // switch to metamask extension and click connect let windowHandles = await driver.waitUntilXWindowHandles( 3, 1000, 10000, ); await driver.switchToWindowWithTitle( 'MetaMask Notification', windowHandles, ); await driver.clickElement({ text: 'Connect', tag: 'button', }); await driver.waitForSelector({ text: 'Install' }); await driver.clickElement({ text: 'Install', tag: 'button', }); await driver.waitForSelector({ text: 'OK' }); await driver.clickElement({ text: 'OK', tag: 'button', }); // switch to test snaps tab await driver.switchToWindowWithTitle('Test Snaps', windowHandles); // wait for npm installation success await driver.waitForSelector({ css: '#connectdialogs', text: 'Reconnect to Dialogs Snap', }); // click on alert dialog await driver.clickElement('#sendAlertButton'); await driver.delay(500); // switch to dialog popup windowHandles = await driver.waitUntilXWindowHandles(3, 1000, 10000); await driver.switchToWindowWithTitle( 'MetaMask Notification', windowHandles, ); await driver.delay(500); // check dialog contents let result = await driver.findElement('.snap-ui-renderer__panel'); await driver.scrollToElement(result); await driver.delay(500); assert.equal( await result.getText(), 'Alert Dialog\nThis is an alert dialog. It has a single button: "OK".', ); // click ok button await driver.clickElement({ text: 'OK', tag: 'button', }); // switch back to test snaps tab windowHandles = await driver.waitUntilXWindowHandles(2, 1000, 10000); await driver.switchToWindowWithTitle('Test Snaps', windowHandles); // check result is null result = await driver.findElement('#dialogResult'); await driver.delay(500); assert.equal(await result.getText(), 'null'); // click conf button await driver.clickElement('#sendConfirmationButton'); await driver.delay(500); // switch to dialog popup windowHandles = await driver.waitUntilXWindowHandles(3, 1000, 10000); await driver.switchToWindowWithTitle( 'MetaMask Notification', windowHandles, ); await driver.delay(500); // click reject await driver.clickElement({ text: 'Reject', tag: 'button', }); // switch back to test snaps tab windowHandles = await driver.waitUntilXWindowHandles(2, 1000, 10000); await driver.switchToWindowWithTitle('Test Snaps', windowHandles); // check for false result result = await driver.findElement('#dialogResult'); await driver.delay(500); assert.equal(await result.getText(), 'false'); // click conf button again await driver.clickElement('#sendConfirmationButton'); await driver.delay(500); // switch to dialog popup windowHandles = await driver.waitUntilXWindowHandles(3, 1000, 10000); await driver.switchToWindowWithTitle( 'MetaMask Notification', windowHandles, ); await driver.delay(500); // click accept await driver.clickElement({ text: 'Approve', tag: 'button', }); // switch back to test snaps tab windowHandles = await driver.waitUntilXWindowHandles(2, 1000, 10000); await driver.switchToWindowWithTitle('Test Snaps', windowHandles); // check for true result result = await driver.findElement('#dialogResult'); await driver.delay(500); assert.equal(await result.getText(), 'true'); // click prompt button await driver.clickElement('#sendPromptButton'); await driver.delay(500); // switch to dialog popup windowHandles = await driver.waitUntilXWindowHandles(3, 1000, 10000); await driver.switchToWindowWithTitle( 'MetaMask Notification', windowHandles, ); await driver.delay(500); // click cancel button await driver.clickElement({ text: 'Cancel', tag: 'button', }); // switch back to test snaps tab windowHandles = await driver.waitUntilXWindowHandles(2, 1000, 10000); await driver.switchToWindowWithTitle('Test Snaps', windowHandles); // check result is equal to 'null' result = await driver.findElement('#dialogResult'); await driver.delay(500); assert.equal(await result.getText(), 'null'); // click prompt button await driver.clickElement('#sendPromptButton'); await driver.delay(500); // switch to dialog popup windowHandles = await driver.waitUntilXWindowHandles(3, 1000, 10000); await driver.switchToWindowWithTitle( 'MetaMask Notification', windowHandles, ); await driver.delay(500); // fill '2323' in form field await driver.pasteIntoField('.MuiInput-input', '2323'); // click submit button await driver.clickElement({ text: 'Submit', tag: 'button', }); // switch back to test snaps tab windowHandles = await driver.waitUntilXWindowHandles(2, 1000, 10000); await driver.switchToWindowWithTitle('Test Snaps', windowHandles); // check result is equal to '2323' result = await driver.findElement('#dialogResult'); assert.equal(await result.getText(), '"2323"'); }, ); }); });