mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-11-26 12:29:06 +01:00
27cfb6aa51
The Selenium webdriver is difficult to use, and easy to misuse. To help use the driver and make it easier to maintain our e2e tests, all driver interactions are now performed via a `driver` module. This is basically a wrapper class around the `selenium-webdriver` that exposes only the methods we want to use directly, along with all of our helper methods.
146 lines
5.1 KiB
JavaScript
146 lines
5.1 KiB
JavaScript
const assert = require('assert')
|
|
const path = require('path')
|
|
const webdriver = require('selenium-webdriver')
|
|
|
|
const { By, Key, until } = webdriver
|
|
const {
|
|
prepareExtensionForTesting,
|
|
regularDelayMs,
|
|
largeDelayMs,
|
|
} = require('./helpers')
|
|
const Ganache = require('./ganache')
|
|
const FixtureServer = require('./fixture-server')
|
|
|
|
const fixtureServer = new FixtureServer()
|
|
|
|
const ganacheServer = new Ganache()
|
|
|
|
describe('MetaMask', function () {
|
|
let driver
|
|
let publicAddress
|
|
|
|
this.timeout(0)
|
|
this.bail(true)
|
|
|
|
before(async function () {
|
|
await ganacheServer.start()
|
|
await fixtureServer.start()
|
|
await fixtureServer.loadState(path.join(__dirname, 'fixtures', 'imported-account'))
|
|
publicAddress = '0x5cfe73b6021e818b776b421b1c4db2474086a7e1'
|
|
const result = await prepareExtensionForTesting()
|
|
driver = result.driver
|
|
})
|
|
|
|
afterEach(async function () {
|
|
if (process.env.SELENIUM_BROWSER === 'chrome') {
|
|
const errors = await driver.checkBrowserForConsoleErrors(driver)
|
|
if (errors.length) {
|
|
const errorReports = errors.map(err => err.message)
|
|
const errorMessage = `Errors found in browser console:\n${errorReports.join('\n')}`
|
|
console.error(new Error(errorMessage))
|
|
}
|
|
}
|
|
if (this.currentTest.state === 'failed') {
|
|
await driver.verboseReportOnFailure(driver, this.currentTest)
|
|
}
|
|
})
|
|
|
|
after(async function () {
|
|
await ganacheServer.quit()
|
|
await fixtureServer.stop()
|
|
await driver.quit()
|
|
})
|
|
|
|
describe('successfuly signs typed data', () => {
|
|
let extension
|
|
let popup
|
|
let dapp
|
|
let windowHandles
|
|
|
|
it('accepts the account password after lock', async () => {
|
|
await driver.delay(1000)
|
|
const passwordField = await driver.findElement(By.id('password'))
|
|
await passwordField.sendKeys('correct horse battery staple')
|
|
await passwordField.sendKeys(Key.ENTER)
|
|
await driver.delay(largeDelayMs * 4)
|
|
})
|
|
|
|
it('connects to the dapp', async () => {
|
|
await driver.openNewPage('http://127.0.0.1:8080/')
|
|
await driver.delay(regularDelayMs)
|
|
|
|
const connectButton = await driver.findElement(By.xpath(`//button[contains(text(), 'Connect')]`))
|
|
await connectButton.click()
|
|
|
|
await driver.delay(regularDelayMs)
|
|
|
|
await driver.waitUntilXWindowHandles(3)
|
|
const windowHandles = await driver.getAllWindowHandles()
|
|
|
|
extension = windowHandles[0]
|
|
dapp = await driver.switchToWindowWithTitle('E2E Test Dapp', windowHandles)
|
|
popup = windowHandles.find(handle => handle !== extension && handle !== dapp)
|
|
|
|
await driver.switchToWindow(popup)
|
|
|
|
await driver.delay(regularDelayMs)
|
|
|
|
const accountButton = await driver.findElement(By.css('.permissions-connect-choose-account__account'))
|
|
await accountButton.click()
|
|
|
|
const submitButton = await driver.findElement(By.xpath(`//button[contains(text(), 'Submit')]`))
|
|
await submitButton.click()
|
|
|
|
await driver.waitUntilXWindowHandles(2)
|
|
await driver.switchToWindow(dapp)
|
|
})
|
|
|
|
it('creates a sign typed data signature request', async () => {
|
|
const signTypedMessage = await driver.findElement(By.xpath(`//button[contains(text(), 'Sign')]`), 10000)
|
|
await signTypedMessage.click()
|
|
await driver.delay(largeDelayMs)
|
|
|
|
await driver.delay(regularDelayMs)
|
|
windowHandles = await driver.getAllWindowHandles()
|
|
await driver.switchToWindowWithTitle('MetaMask Notification', windowHandles)
|
|
await driver.delay(regularDelayMs)
|
|
|
|
const title = await driver.findElement(By.css('.signature-request-content__title'))
|
|
const name = await driver.findElement(By.css('.signature-request-content__info--bolded'))
|
|
const content = await driver.findElements(By.css('.signature-request-content__info'))
|
|
const origin = content[0]
|
|
const address = content[1]
|
|
assert.equal(await title.getText(), 'Signature Request')
|
|
assert.equal(await name.getText(), 'Ether Mail')
|
|
assert.equal(await origin.getText(), '127.0.0.1')
|
|
assert.equal(await address.getText(), publicAddress.slice(0, 8) + '...' + publicAddress.slice(publicAddress.length - 8))
|
|
})
|
|
|
|
it('signs the transaction', async () => {
|
|
const signButton = await driver.findElement(By.xpath(`//button[contains(text(), 'Sign')]`), 10000)
|
|
await signButton.click()
|
|
await driver.delay(regularDelayMs)
|
|
|
|
extension = windowHandles[0]
|
|
await driver.switchToWindow(extension)
|
|
})
|
|
|
|
it('gets the current accounts address', async () => {
|
|
const detailsButton = await driver.findElement(By.css('.account-details__details-button'))
|
|
await detailsButton.click()
|
|
await driver.delay(regularDelayMs)
|
|
|
|
const addressInput = await driver.findElement(By.css('.qr-ellip-address'))
|
|
const newPublicAddress = await addressInput.getAttribute('value')
|
|
const accountModal = await driver.findElement(By.css('span .modal'))
|
|
|
|
const accountModalClose = await driver.findElement(By.css('.account-modal-close'))
|
|
await accountModalClose.click()
|
|
|
|
await driver.wait(until.stalenessOf(accountModal))
|
|
await driver.delay(regularDelayMs)
|
|
assert.equal(newPublicAddress.toLowerCase(), publicAddress)
|
|
})
|
|
})
|
|
})
|