mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-11-27 04:46:10 +01:00
110 lines
3.4 KiB
JavaScript
110 lines
3.4 KiB
JavaScript
const fs = require('fs')
|
|
const mkdirp = require('mkdirp')
|
|
const pify = require('pify')
|
|
const {until} = require('selenium-webdriver')
|
|
const { delay } = require('../func')
|
|
|
|
const testContract = `
|
|
pragma solidity ^0.4.0;
|
|
contract PiggyBank {
|
|
|
|
uint private balance;
|
|
address public owner;
|
|
|
|
function PiggyBank() public {
|
|
owner = msg.sender;
|
|
balance = 0;
|
|
}
|
|
|
|
function deposit() public payable returns (uint) {
|
|
balance += msg.value;
|
|
return balance;
|
|
}
|
|
|
|
function withdraw(uint withdrawAmount) public returns (uint remainingBal) {
|
|
require(msg.sender == owner);
|
|
balance -= withdrawAmount;
|
|
|
|
msg.sender.transfer(withdrawAmount);
|
|
|
|
return balance;
|
|
}
|
|
}
|
|
`
|
|
|
|
module.exports = {
|
|
checkBrowserForConsoleErrors,
|
|
loadExtension,
|
|
verboseReportOnFailure,
|
|
findElement,
|
|
findElements,
|
|
openNewPage,
|
|
testContract,
|
|
}
|
|
|
|
async function loadExtension (driver, extensionId) {
|
|
switch (process.env.SELENIUM_BROWSER) {
|
|
case 'chrome': {
|
|
await driver.get(`chrome-extension://${extensionId}/home.html`)
|
|
break
|
|
}
|
|
case 'firefox': {
|
|
await driver.get(`moz-extension://${extensionId}/home.html`)
|
|
break
|
|
}
|
|
}
|
|
}
|
|
|
|
async function checkBrowserForConsoleErrors (driver) {
|
|
const ignoredLogTypes = ['WARNING']
|
|
const ignoredErrorMessages = [
|
|
// React throws error warnings on "dataset", but still sets the data-* properties correctly
|
|
'Warning: Unknown prop `dataset` on ',
|
|
// Third-party Favicon 404s show up as errors
|
|
'favicon.ico - Failed to load resource: the server responded with a status of 404 (Not Found)',
|
|
// React Development build - known issue blocked by test build sys
|
|
'Warning: It looks like you\'re using a minified copy of the development build of React.',
|
|
// Redux Development build - known issue blocked by test build sys
|
|
'This means that you are running a slower development build of Redux.',
|
|
]
|
|
const browserLogs = await driver.manage().logs().get('browser')
|
|
const errorEntries = browserLogs.filter(entry => !ignoredLogTypes.includes(entry.level.toString()))
|
|
const errorObjects = errorEntries.map(entry => entry.toJSON())
|
|
return errorObjects.filter(entry => !ignoredErrorMessages.some(message => entry.message.includes(message)))
|
|
}
|
|
|
|
async function verboseReportOnFailure (driver, test) {
|
|
let artifactDir
|
|
if (process.env.SELENIUM_BROWSER === 'chrome') {
|
|
artifactDir = `./test-artifacts/chrome/${test.title}`
|
|
} else if (process.env.SELENIUM_BROWSER === 'firefox') {
|
|
artifactDir = `./test-artifacts/firefox/${test.title}`
|
|
}
|
|
const filepathBase = `${artifactDir}/test-failure`
|
|
await pify(mkdirp)(artifactDir)
|
|
const screenshot = await driver.takeScreenshot()
|
|
await pify(fs.writeFile)(`${filepathBase}-screenshot.png`, screenshot, { encoding: 'base64' })
|
|
const htmlSource = await driver.getPageSource()
|
|
await pify(fs.writeFile)(`${filepathBase}-dom.html`, htmlSource)
|
|
}
|
|
|
|
async function findElement (driver, by, timeout = 10000) {
|
|
return driver.wait(until.elementLocated(by), timeout)
|
|
}
|
|
|
|
async function findElements (driver, by, timeout = 10000) {
|
|
return driver.wait(until.elementsLocated(by), timeout)
|
|
}
|
|
|
|
async function openNewPage (driver, url) {
|
|
await driver.executeScript('window.open()')
|
|
await delay(1000)
|
|
|
|
const handles = await driver.getAllWindowHandles()
|
|
const lastHandle = handles.pop()
|
|
await driver.switchTo().window(lastHandle)
|
|
|
|
await driver.get(url)
|
|
await delay(1000)
|
|
}
|