mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
Merge pull request #4678 from MetaMask/e2e-beta-tests-upgrade
E2e beta tests upgrade
This commit is contained in:
commit
9f5ee94b69
13686
package-lock.json
generated
13686
package-lock.json
generated
File diff suppressed because it is too large
Load Diff
@ -183,6 +183,7 @@
|
|||||||
"semaphore": "^1.0.5",
|
"semaphore": "^1.0.5",
|
||||||
"semver": "^5.4.1",
|
"semver": "^5.4.1",
|
||||||
"shallow-copy": "0.0.1",
|
"shallow-copy": "0.0.1",
|
||||||
|
"superstatic": "^5.0.2",
|
||||||
"sw-controller": "^1.0.3",
|
"sw-controller": "^1.0.3",
|
||||||
"sw-stream": "^2.0.2",
|
"sw-stream": "^2.0.2",
|
||||||
"textarea-caret": "^3.0.1",
|
"textarea-caret": "^3.0.1",
|
||||||
@ -251,6 +252,7 @@
|
|||||||
"gulp-util": "^3.0.7",
|
"gulp-util": "^3.0.7",
|
||||||
"gulp-watch": "^5.0.0",
|
"gulp-watch": "^5.0.0",
|
||||||
"gulp-zip": "^4.0.0",
|
"gulp-zip": "^4.0.0",
|
||||||
|
"http-server": "^0.11.1",
|
||||||
"image-size": "^0.6.2",
|
"image-size": "^0.6.2",
|
||||||
"isomorphic-fetch": "^2.2.1",
|
"isomorphic-fetch": "^2.2.1",
|
||||||
"jsdoc": "^3.5.5",
|
"jsdoc": "^3.5.5",
|
||||||
|
61
test/e2e/beta/contract-test/contract.js
Normal file
61
test/e2e/beta/contract-test/contract.js
Normal file
@ -0,0 +1,61 @@
|
|||||||
|
/*
|
||||||
|
The `piggybankContract` is compiled from:
|
||||||
|
|
||||||
|
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;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
|
var piggybankContract = web3.eth.contract([{"constant":false,"inputs":[{"name":"withdrawAmount","type":"uint256"}],"name":"withdraw","outputs":[{"name":"remainingBal","type":"uint256"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"owner","outputs":[{"name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[],"name":"deposit","outputs":[{"name":"","type":"uint256"}],"payable":true,"stateMutability":"payable","type":"function"},{"inputs":[],"payable":false,"stateMutability":"nonpayable","type":"constructor"}]);
|
||||||
|
|
||||||
|
deployButton.addEventListener('click', function (event) {
|
||||||
|
|
||||||
|
var piggybank = piggybankContract.new(
|
||||||
|
{
|
||||||
|
from: web3.eth.accounts[0],
|
||||||
|
data: '0x608060405234801561001057600080fd5b5033600160006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055506000808190555061023b806100686000396000f300608060405260043610610057576000357c0100000000000000000000000000000000000000000000000000000000900463ffffffff1680632e1a7d4d1461005c5780638da5cb5b1461009d578063d0e30db0146100f4575b600080fd5b34801561006857600080fd5b5061008760048036038101908080359060200190929190505050610112565b6040518082815260200191505060405180910390f35b3480156100a957600080fd5b506100b26101d0565b604051808273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390f35b6100fc6101f6565b6040518082815260200191505060405180910390f35b6000600160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff1614151561017057600080fd5b8160008082825403925050819055503373ffffffffffffffffffffffffffffffffffffffff166108fc839081150290604051600060405180830381858888f193505050501580156101c5573d6000803e3d6000fd5b506000549050919050565b600160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b60003460008082825401925050819055506000549050905600a165627a7a72305820f237db3ec816a52589d82512117bc85bc08d3537683ffeff9059108caf3e5d400029',
|
||||||
|
gas: '4700000'
|
||||||
|
}, function (e, contract){
|
||||||
|
console.log(e, contract);
|
||||||
|
if (typeof contract.address !== 'undefined') {
|
||||||
|
console.log('Contract mined! address: ' + contract.address + ' transactionHash: ' + contract.transactionHash);
|
||||||
|
|
||||||
|
console.log(`contract`, contract);
|
||||||
|
|
||||||
|
depositButton.addEventListener('click', function (event) {
|
||||||
|
contract.deposit({ from: web3.eth.accounts[0], value: '0x29a2241af62c0000' }, function (result) {
|
||||||
|
console.log(result)
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
withdrawButton.addEventListener('click', function (event) {
|
||||||
|
contract.withdraw('0xde0b6b3a7640000', { from: web3.eth.accounts[0] }, function (result) {
|
||||||
|
console.log(result)
|
||||||
|
})
|
||||||
|
})
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
})
|
8
test/e2e/beta/contract-test/index.html
Normal file
8
test/e2e/beta/contract-test/index.html
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
<html>
|
||||||
|
<body>
|
||||||
|
<button id="deployButton">Deploy Contract</button>
|
||||||
|
<button id="depositButton">Deposit</button>
|
||||||
|
<button id="withdrawButton">Withdraw</button>
|
||||||
|
</body>
|
||||||
|
<script src="contract.js"></script>
|
||||||
|
</html>
|
@ -26,6 +26,7 @@ describe('Using MetaMask with an existing account', function () {
|
|||||||
|
|
||||||
const testSeedPhrase = 'phrase upgrade clock rough situate wedding elder clever doctor stamp excess tent'
|
const testSeedPhrase = 'phrase upgrade clock rough situate wedding elder clever doctor stamp excess tent'
|
||||||
const testAddress = '0xE18035BF8712672935FDB4e5e431b1a0183d2DFC'
|
const testAddress = '0xE18035BF8712672935FDB4e5e431b1a0183d2DFC'
|
||||||
|
const testPrivateKey2 = '14abe6f4aab7f9f626fe981c864d0adeb5685f289ac9270c27b8fd790b4235d6'
|
||||||
const regularDelayMs = 1000
|
const regularDelayMs = 1000
|
||||||
const largeDelayMs = regularDelayMs * 2
|
const largeDelayMs = regularDelayMs * 2
|
||||||
const waitingNewPageDelayMs = regularDelayMs * 10
|
const waitingNewPageDelayMs = regularDelayMs * 10
|
||||||
@ -166,8 +167,7 @@ describe('Using MetaMask with an existing account', function () {
|
|||||||
|
|
||||||
describe('Show account information', () => {
|
describe('Show account information', () => {
|
||||||
it('shows the correct account address', async () => {
|
it('shows the correct account address', async () => {
|
||||||
const detailsButton = await findElement(driver, By.xpath(`//button[contains(text(), 'Details')]`))
|
await driver.findElement(By.css('.wallet-view__details-button')).click()
|
||||||
detailsButton.click()
|
|
||||||
await driver.findElement(By.css('.qr-wrapper')).isDisplayed()
|
await driver.findElement(By.css('.qr-wrapper')).isDisplayed()
|
||||||
await delay(regularDelayMs)
|
await delay(regularDelayMs)
|
||||||
|
|
||||||
@ -263,8 +263,10 @@ describe('Using MetaMask with an existing account', function () {
|
|||||||
await configureGas.click()
|
await configureGas.click()
|
||||||
await delay(regularDelayMs)
|
await delay(regularDelayMs)
|
||||||
|
|
||||||
|
const gasModal = await driver.findElement(By.css('span .modal'))
|
||||||
const save = await findElement(driver, By.xpath(`//button[contains(text(), 'Save')]`))
|
const save = await findElement(driver, By.xpath(`//button[contains(text(), 'Save')]`))
|
||||||
await save.click()
|
await save.click()
|
||||||
|
await driver.wait(until.stalenessOf(gasModal))
|
||||||
await delay(regularDelayMs)
|
await delay(regularDelayMs)
|
||||||
|
|
||||||
// Continue to next screen
|
// Continue to next screen
|
||||||
@ -289,143 +291,36 @@ describe('Using MetaMask with an existing account', function () {
|
|||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
describe('Send ETH from Faucet', () => {
|
describe('Imports an account with private key', () => {
|
||||||
it('starts a send transaction inside Faucet', async () => {
|
it('choose Create Account from the account menu', async () => {
|
||||||
await driver.executeScript('window.open("https://faucet.metamask.io")')
|
await driver.findElement(By.css('.account-menu__icon')).click()
|
||||||
await delay(waitingNewPageDelayMs)
|
|
||||||
|
|
||||||
const [extension, faucet] = await driver.getAllWindowHandles()
|
|
||||||
await driver.switchTo().window(faucet)
|
|
||||||
await delay(regularDelayMs)
|
await delay(regularDelayMs)
|
||||||
|
|
||||||
const send1eth = await findElement(driver, By.xpath(`//button[contains(text(), '10 ether')]`), 14000)
|
const [importAccount] = await findElements(driver, By.xpath(`//div[contains(text(), 'Import Account')]`))
|
||||||
await send1eth.click()
|
await importAccount.click()
|
||||||
await delay(regularDelayMs)
|
await delay(regularDelayMs)
|
||||||
|
})
|
||||||
|
|
||||||
await driver.switchTo().window(extension)
|
it('enter private key', async () => {
|
||||||
await loadExtension(driver, extensionId)
|
const privateKeyInput = await findElement(driver, By.css('#private-key-box'))
|
||||||
|
await privateKeyInput.sendKeys(testPrivateKey2)
|
||||||
await delay(regularDelayMs)
|
await delay(regularDelayMs)
|
||||||
|
const importButtons = await findElements(driver, By.xpath(`//button[contains(text(), 'Import')]`))
|
||||||
|
await importButtons[0].click()
|
||||||
|
await delay(regularDelayMs)
|
||||||
|
})
|
||||||
|
|
||||||
const confirmButton = await findElement(driver, By.xpath(`//button[contains(text(), 'Confirm')]`), 14000)
|
it('should show the correct account name', async () => {
|
||||||
await confirmButton.click()
|
const [accountName] = await findElements(driver, By.css('.account-name'))
|
||||||
|
assert.equal(await accountName.getText(), 'Account 3')
|
||||||
await delay(regularDelayMs)
|
await delay(regularDelayMs)
|
||||||
|
})
|
||||||
|
|
||||||
await driver.switchTo().window(faucet)
|
it('should show the imported label', async () => {
|
||||||
await delay(regularDelayMs)
|
const [importedLabel] = await findElements(driver, By.css('.wallet-view__keyring-label'))
|
||||||
await driver.close()
|
assert.equal(await importedLabel.getText(), 'IMPORTED')
|
||||||
await delay(regularDelayMs)
|
|
||||||
await driver.switchTo().window(extension)
|
|
||||||
await delay(regularDelayMs)
|
|
||||||
await loadExtension(driver, extensionId)
|
|
||||||
await delay(regularDelayMs)
|
await delay(regularDelayMs)
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
describe('Add existing token using search', () => {
|
|
||||||
it('clicks on the Add Token button', async () => {
|
|
||||||
const addToken = await findElement(driver, By.xpath(`//button[contains(text(), 'Add Token')]`))
|
|
||||||
await addToken.click()
|
|
||||||
await delay(regularDelayMs)
|
|
||||||
})
|
|
||||||
|
|
||||||
it('picks an existing token', async () => {
|
|
||||||
const tokenSearch = await findElement(driver, By.css('#search-tokens'))
|
|
||||||
await tokenSearch.sendKeys('BAT')
|
|
||||||
await delay(regularDelayMs)
|
|
||||||
|
|
||||||
const token = await findElement(driver, By.xpath("//span[contains(text(), 'BAT')]"))
|
|
||||||
await token.click()
|
|
||||||
await delay(regularDelayMs)
|
|
||||||
|
|
||||||
const nextScreen = await findElement(driver, By.xpath(`//button[contains(text(), 'Next')]`))
|
|
||||||
await nextScreen.click()
|
|
||||||
await delay(regularDelayMs)
|
|
||||||
|
|
||||||
const addTokens = await findElement(driver, By.xpath(`//button[contains(text(), 'Add Tokens')]`))
|
|
||||||
await addTokens.click()
|
|
||||||
await delay(largeDelayMs)
|
|
||||||
})
|
|
||||||
|
|
||||||
it('renders the balance for the new token', async () => {
|
|
||||||
const balance = await findElement(driver, By.css('.tx-view .balance-display .token-amount'))
|
|
||||||
await driver.wait(until.elementTextMatches(balance, /^0\s*BAT\s*$/), 10000)
|
|
||||||
const tokenAmount = await balance.getText()
|
|
||||||
assert.ok(/^0\s*BAT\s*$/.test(tokenAmount))
|
|
||||||
await delay(regularDelayMs)
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
describe('Add a custom token from TokenFactory', () => {
|
|
||||||
it('creates a new token', async () => {
|
|
||||||
await driver.executeScript('window.open("https://tokenfactory.surge.sh/#/factory")')
|
|
||||||
await delay(waitingNewPageDelayMs)
|
|
||||||
|
|
||||||
const [extension, tokenFactory] = await driver.getAllWindowHandles()
|
|
||||||
await driver.switchTo().window(tokenFactory)
|
|
||||||
const [
|
|
||||||
totalSupply,
|
|
||||||
tokenName,
|
|
||||||
tokenDecimal,
|
|
||||||
tokenSymbol,
|
|
||||||
] = await findElements(driver, By.css('.form-control'))
|
|
||||||
|
|
||||||
await totalSupply.sendKeys('100')
|
|
||||||
await tokenName.sendKeys('Test')
|
|
||||||
await tokenDecimal.sendKeys('0')
|
|
||||||
await tokenSymbol.sendKeys('TST')
|
|
||||||
|
|
||||||
const createToken = await findElement(driver, By.xpath(`//button[contains(text(), 'Create Token')]`))
|
|
||||||
await createToken.click()
|
|
||||||
await delay(regularDelayMs)
|
|
||||||
|
|
||||||
await driver.switchTo().window(extension)
|
|
||||||
await loadExtension(driver, extensionId)
|
|
||||||
await delay(regularDelayMs)
|
|
||||||
|
|
||||||
const confirmButton = await findElement(driver, By.xpath(`//button[contains(text(), 'Confirm')]`))
|
|
||||||
await confirmButton.click()
|
|
||||||
await delay(regularDelayMs)
|
|
||||||
|
|
||||||
await driver.switchTo().window(tokenFactory)
|
|
||||||
await delay(regularDelayMs)
|
|
||||||
const tokenContactAddress = await driver.findElement(By.css('div > div > div:nth-child(2) > span:nth-child(3)'))
|
|
||||||
tokenAddress = await tokenContactAddress.getText()
|
|
||||||
await driver.close()
|
|
||||||
await driver.switchTo().window(extension)
|
|
||||||
await loadExtension(driver, extensionId)
|
|
||||||
await delay(regularDelayMs)
|
|
||||||
})
|
|
||||||
|
|
||||||
it('clicks on the Add Token button', async () => {
|
|
||||||
const addToken = await findElement(driver, By.xpath(`//button[contains(text(), 'Add Token')]`))
|
|
||||||
await addToken.click()
|
|
||||||
await delay(regularDelayMs)
|
|
||||||
})
|
|
||||||
|
|
||||||
it('picks the new Test token', async () => {
|
|
||||||
const addCustomToken = await findElement(driver, By.xpath("//div[contains(text(), 'Custom Token')]"))
|
|
||||||
await addCustomToken.click()
|
|
||||||
await delay(regularDelayMs)
|
|
||||||
|
|
||||||
const newTokenAddress = await findElement(driver, By.css('#custom-address'))
|
|
||||||
await newTokenAddress.sendKeys(tokenAddress)
|
|
||||||
await delay(regularDelayMs)
|
|
||||||
|
|
||||||
const nextScreen = await findElement(driver, By.xpath(`//button[contains(text(), 'Next')]`))
|
|
||||||
await nextScreen.click()
|
|
||||||
await delay(regularDelayMs)
|
|
||||||
|
|
||||||
const addTokens = await findElement(driver, By.xpath(`//button[contains(text(), 'Add Tokens')]`))
|
|
||||||
await addTokens.click()
|
|
||||||
await delay(regularDelayMs)
|
|
||||||
})
|
|
||||||
|
|
||||||
it('renders the balance for the new token', async () => {
|
|
||||||
const balance = await findElement(driver, By.css('.tx-view .balance-display .token-amount'))
|
|
||||||
await driver.wait(until.elementTextMatches(balance, /^100\s*TST\s*$/), 10000)
|
|
||||||
const tokenAmount = await balance.getText()
|
|
||||||
assert.ok(/^100\s*TST\s*$/.test(tokenAmount))
|
|
||||||
await delay(regularDelayMs)
|
|
||||||
})
|
|
||||||
})
|
|
||||||
})
|
})
|
||||||
|
@ -2,6 +2,7 @@ const fs = require('fs')
|
|||||||
const mkdirp = require('mkdirp')
|
const mkdirp = require('mkdirp')
|
||||||
const pify = require('pify')
|
const pify = require('pify')
|
||||||
const {until} = require('selenium-webdriver')
|
const {until} = require('selenium-webdriver')
|
||||||
|
const { delay } = require('../func')
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
checkBrowserForConsoleErrors,
|
checkBrowserForConsoleErrors,
|
||||||
@ -9,6 +10,7 @@ module.exports = {
|
|||||||
verboseReportOnFailure,
|
verboseReportOnFailure,
|
||||||
findElement,
|
findElement,
|
||||||
findElements,
|
findElements,
|
||||||
|
openNewPage,
|
||||||
}
|
}
|
||||||
|
|
||||||
async function loadExtension (driver, extensionId) {
|
async function loadExtension (driver, extensionId) {
|
||||||
@ -64,3 +66,15 @@ async function findElement (driver, by, timeout = 10000) {
|
|||||||
async function findElements (driver, by, timeout = 10000) {
|
async function findElements (driver, by, timeout = 10000) {
|
||||||
return driver.wait(until.elementsLocated(by), timeout)
|
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 secondHandle = handles[1]
|
||||||
|
await driver.switchTo().window(secondHandle)
|
||||||
|
|
||||||
|
await driver.get(url)
|
||||||
|
await delay(1000)
|
||||||
|
}
|
||||||
|
@ -16,6 +16,7 @@ const {
|
|||||||
checkBrowserForConsoleErrors,
|
checkBrowserForConsoleErrors,
|
||||||
loadExtension,
|
loadExtension,
|
||||||
verboseReportOnFailure,
|
verboseReportOnFailure,
|
||||||
|
openNewPage,
|
||||||
} = require('./helpers')
|
} = require('./helpers')
|
||||||
|
|
||||||
describe('MetaMask', function () {
|
describe('MetaMask', function () {
|
||||||
@ -62,7 +63,7 @@ describe('MetaMask', function () {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (this.currentTest.state === 'failed') {
|
if (this.currentTest.state === 'failed') {
|
||||||
await verboseReportOnFailure(this.currentTest)
|
await verboseReportOnFailure(driver, this.currentTest)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
@ -71,14 +72,20 @@ describe('MetaMask', function () {
|
|||||||
})
|
})
|
||||||
|
|
||||||
describe('New UI setup', async function () {
|
describe('New UI setup', async function () {
|
||||||
|
let networkSelector
|
||||||
it('switches to first tab', async function () {
|
it('switches to first tab', async function () {
|
||||||
const [firstTab] = await driver.getAllWindowHandles()
|
const [firstTab] = await driver.getAllWindowHandles()
|
||||||
await driver.switchTo().window(firstTab)
|
await driver.switchTo().window(firstTab)
|
||||||
await delay(regularDelayMs)
|
await delay(regularDelayMs)
|
||||||
|
try {
|
||||||
|
networkSelector = await findElement(driver, By.css('#network_component'))
|
||||||
|
} catch (e) {
|
||||||
|
await loadExtension(driver, extensionId)
|
||||||
|
}
|
||||||
|
await delay(regularDelayMs)
|
||||||
})
|
})
|
||||||
|
|
||||||
it('use the local network', async function () {
|
it('use the local network', async function () {
|
||||||
const networkSelector = await findElement(driver, By.css('#network_component'))
|
|
||||||
await networkSelector.click()
|
await networkSelector.click()
|
||||||
await delay(regularDelayMs)
|
await delay(regularDelayMs)
|
||||||
|
|
||||||
@ -136,6 +143,7 @@ describe('MetaMask', function () {
|
|||||||
await driver.executeScript('arguments[0].scrollIntoView(true)', bottomOfTos)
|
await driver.executeScript('arguments[0].scrollIntoView(true)', bottomOfTos)
|
||||||
await delay(regularDelayMs)
|
await delay(regularDelayMs)
|
||||||
const acceptTos = await findElement(driver, By.css('.tou button'))
|
const acceptTos = await findElement(driver, By.css('.tou button'))
|
||||||
|
driver.wait(until.elementIsEnabled(acceptTos))
|
||||||
await acceptTos.click()
|
await acceptTos.click()
|
||||||
await delay(regularDelayMs)
|
await delay(regularDelayMs)
|
||||||
})
|
})
|
||||||
@ -160,8 +168,10 @@ describe('MetaMask', function () {
|
|||||||
let seedPhrase
|
let seedPhrase
|
||||||
|
|
||||||
it('reveals the seed phrase', async () => {
|
it('reveals the seed phrase', async () => {
|
||||||
const revealSeedPhrase = await findElement(driver, By.css('.backup-phrase__secret-blocker'))
|
const byRevealButton = By.css('.backup-phrase__secret-blocker .backup-phrase__reveal-button')
|
||||||
await revealSeedPhrase.click()
|
await driver.wait(until.elementLocated(byRevealButton, 10000))
|
||||||
|
const revealSeedPhraseButton = await findElement(driver, byRevealButton, 10000)
|
||||||
|
await revealSeedPhraseButton.click()
|
||||||
await delay(regularDelayMs)
|
await delay(regularDelayMs)
|
||||||
|
|
||||||
seedPhrase = await driver.findElement(By.css('.backup-phrase__secret-words')).getText()
|
seedPhrase = await driver.findElement(By.css('.backup-phrase__secret-words')).getText()
|
||||||
@ -173,56 +183,76 @@ describe('MetaMask', function () {
|
|||||||
await delay(regularDelayMs)
|
await delay(regularDelayMs)
|
||||||
})
|
})
|
||||||
|
|
||||||
it('can retype the seed phrase', async () => {
|
async function retypeSeedPhrase (words) {
|
||||||
const words = seedPhrase.split(' ')
|
try {
|
||||||
|
const word0 = await findElement(driver, By.xpath(`//button[contains(text(), '${words[0]}')]`), 10000)
|
||||||
|
|
||||||
const word0 = await findElement(driver, By.xpath(`//button[contains(text(), '${words[0]}')]`))
|
|
||||||
await word0.click()
|
await word0.click()
|
||||||
await delay(tinyDelayMs)
|
await delay(tinyDelayMs)
|
||||||
|
|
||||||
const word1 = await findElement(driver, By.xpath(`//button[contains(text(), '${words[1]}')]`))
|
const word1 = await findElement(driver, By.xpath(`//button[contains(text(), '${words[1]}')]`), 10000)
|
||||||
|
|
||||||
await word1.click()
|
await word1.click()
|
||||||
await delay(tinyDelayMs)
|
await delay(tinyDelayMs)
|
||||||
|
|
||||||
const word2 = await findElement(driver, By.xpath(`//button[contains(text(), '${words[2]}')]`))
|
const word2 = await findElement(driver, By.xpath(`//button[contains(text(), '${words[2]}')]`), 10000)
|
||||||
|
|
||||||
await word2.click()
|
await word2.click()
|
||||||
await delay(tinyDelayMs)
|
await delay(tinyDelayMs)
|
||||||
|
|
||||||
const word3 = await findElement(driver, By.xpath(`//button[contains(text(), '${words[3]}')]`))
|
const word3 = await findElement(driver, By.xpath(`//button[contains(text(), '${words[3]}')]`), 10000)
|
||||||
|
|
||||||
await word3.click()
|
await word3.click()
|
||||||
await delay(tinyDelayMs)
|
await delay(tinyDelayMs)
|
||||||
|
|
||||||
const word4 = await findElement(driver, By.xpath(`//button[contains(text(), '${words[4]}')]`))
|
const word4 = await findElement(driver, By.xpath(`//button[contains(text(), '${words[4]}')]`), 10000)
|
||||||
|
|
||||||
await word4.click()
|
await word4.click()
|
||||||
await delay(tinyDelayMs)
|
await delay(tinyDelayMs)
|
||||||
|
|
||||||
const word5 = await findElement(driver, By.xpath(`//button[contains(text(), '${words[5]}')]`))
|
const word5 = await findElement(driver, By.xpath(`//button[contains(text(), '${words[5]}')]`), 10000)
|
||||||
|
|
||||||
await word5.click()
|
await word5.click()
|
||||||
await delay(tinyDelayMs)
|
await delay(tinyDelayMs)
|
||||||
|
|
||||||
const word6 = await findElement(driver, By.xpath(`//button[contains(text(), '${words[6]}')]`))
|
const word6 = await findElement(driver, By.xpath(`//button[contains(text(), '${words[6]}')]`), 10000)
|
||||||
|
|
||||||
await word6.click()
|
await word6.click()
|
||||||
await delay(tinyDelayMs)
|
await delay(tinyDelayMs)
|
||||||
|
|
||||||
const word7 = await findElement(driver, By.xpath(`//button[contains(text(), '${words[7]}')]`))
|
const word7 = await findElement(driver, By.xpath(`//button[contains(text(), '${words[7]}')]`), 10000)
|
||||||
|
|
||||||
await word7.click()
|
await word7.click()
|
||||||
await delay(tinyDelayMs)
|
await delay(tinyDelayMs)
|
||||||
|
|
||||||
const word8 = await findElement(driver, By.xpath(`//button[contains(text(), '${words[8]}')]`))
|
const word8 = await findElement(driver, By.xpath(`//button[contains(text(), '${words[8]}')]`), 10000)
|
||||||
|
|
||||||
await word8.click()
|
await word8.click()
|
||||||
await delay(tinyDelayMs)
|
await delay(tinyDelayMs)
|
||||||
|
|
||||||
const word9 = await findElement(driver, By.xpath(`//button[contains(text(), '${words[9]}')]`))
|
const word9 = await findElement(driver, By.xpath(`//button[contains(text(), '${words[9]}')]`), 10000)
|
||||||
|
|
||||||
await word9.click()
|
await word9.click()
|
||||||
await delay(tinyDelayMs)
|
await delay(tinyDelayMs)
|
||||||
|
|
||||||
const word10 = await findElement(driver, By.xpath(`//button[contains(text(), '${words[10]}')]`))
|
const word10 = await findElement(driver, By.xpath(`//button[contains(text(), '${words[10]}')]`), 10000)
|
||||||
|
|
||||||
await word10.click()
|
await word10.click()
|
||||||
await delay(tinyDelayMs)
|
await delay(tinyDelayMs)
|
||||||
|
|
||||||
const word11 = await findElement(driver, By.xpath(`//button[contains(text(), '${words[11]}')]`))
|
const word11 = await findElement(driver, By.xpath(`//button[contains(text(), '${words[11]}')]`), 10000)
|
||||||
await word11.click()
|
await word11.click()
|
||||||
await delay(tinyDelayMs)
|
await delay(tinyDelayMs)
|
||||||
|
} catch (e) {
|
||||||
|
await loadExtension(driver, extensionId)
|
||||||
|
await retypeSeedPhrase(words)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
it('can retype the seed phrase', async () => {
|
||||||
|
const words = seedPhrase.split(' ')
|
||||||
|
|
||||||
|
await retypeSeedPhrase(words)
|
||||||
|
|
||||||
const confirm = await findElement(driver, By.xpath(`//button[contains(text(), 'Confirm')]`))
|
const confirm = await findElement(driver, By.xpath(`//button[contains(text(), 'Confirm')]`))
|
||||||
await confirm.click()
|
await confirm.click()
|
||||||
@ -230,7 +260,8 @@ describe('MetaMask', function () {
|
|||||||
})
|
})
|
||||||
|
|
||||||
it('clicks through the deposit modal', async () => {
|
it('clicks through the deposit modal', async () => {
|
||||||
const buyModal = await driver.findElement(By.css('span .modal'))
|
const byBuyModal = By.css('span .modal')
|
||||||
|
const buyModal = await driver.wait(until.elementLocated(byBuyModal))
|
||||||
const closeModal = await findElement(driver, By.css('.page-container__header-close'))
|
const closeModal = await findElement(driver, By.css('.page-container__header-close'))
|
||||||
await closeModal.click()
|
await closeModal.click()
|
||||||
await driver.wait(until.stalenessOf(buyModal))
|
await driver.wait(until.stalenessOf(buyModal))
|
||||||
@ -244,8 +275,12 @@ describe('MetaMask', function () {
|
|||||||
await driver.findElement(By.css('.qr-wrapper')).isDisplayed()
|
await driver.findElement(By.css('.qr-wrapper')).isDisplayed()
|
||||||
await delay(regularDelayMs)
|
await delay(regularDelayMs)
|
||||||
|
|
||||||
|
let accountModal = await driver.findElement(By.css('span .modal'))
|
||||||
|
|
||||||
await driver.executeScript("document.querySelector('.account-modal-close').click()")
|
await driver.executeScript("document.querySelector('.account-modal-close').click()")
|
||||||
await delay(regularDelayMs * 4)
|
|
||||||
|
await driver.wait(until.stalenessOf(accountModal))
|
||||||
|
await delay(regularDelayMs)
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
@ -345,8 +380,11 @@ describe('MetaMask', function () {
|
|||||||
await configureGas.click()
|
await configureGas.click()
|
||||||
await delay(regularDelayMs)
|
await delay(regularDelayMs)
|
||||||
|
|
||||||
|
const gasModal = await driver.findElement(By.css('span .modal'))
|
||||||
|
|
||||||
const save = await findElement(driver, By.xpath(`//button[contains(text(), 'Save')]`))
|
const save = await findElement(driver, By.xpath(`//button[contains(text(), 'Save')]`))
|
||||||
await save.click()
|
await save.click()
|
||||||
|
await driver.wait(until.stalenessOf(gasModal))
|
||||||
await delay(regularDelayMs)
|
await delay(regularDelayMs)
|
||||||
|
|
||||||
// Continue to next screen
|
// Continue to next screen
|
||||||
@ -365,19 +403,20 @@ describe('MetaMask', function () {
|
|||||||
const transactions = await findElements(driver, By.css('.tx-list-item'))
|
const transactions = await findElements(driver, By.css('.tx-list-item'))
|
||||||
assert.equal(transactions.length, 1)
|
assert.equal(transactions.length, 1)
|
||||||
|
|
||||||
const txValues = await findElements(driver, By.css('.tx-list-value'))
|
const txValues = await findElement(driver, By.css('.tx-list-value'))
|
||||||
assert.equal(txValues.length, 1)
|
await driver.wait(until.elementTextMatches(txValues, /1\sETH/), 10000)
|
||||||
assert.equal(await txValues[0].getText(), '1 ETH')
|
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
describe('Send ETH from Faucet', () => {
|
describe('Send ETH from Faucet', () => {
|
||||||
it('starts a send transaction inside Faucet', async () => {
|
it('starts a send transaction inside Faucet', async () => {
|
||||||
await driver.executeScript('window.open("https://faucet.metamask.io")')
|
await openNewPage(driver, 'https://faucet.metamask.io')
|
||||||
await delay(waitingNewPageDelayMs)
|
|
||||||
|
|
||||||
const [extension, faucet] = await driver.getAllWindowHandles()
|
const [extension, faucet] = await driver.getAllWindowHandles()
|
||||||
await driver.switchTo().window(faucet)
|
await driver.switchTo().window(faucet)
|
||||||
|
|
||||||
|
const faucetPageTitle = await findElement(driver, By.css('.container-fluid'))
|
||||||
|
await driver.wait(until.elementTextMatches(faucetPageTitle, /MetaMask/))
|
||||||
await delay(regularDelayMs)
|
await delay(regularDelayMs)
|
||||||
|
|
||||||
const send1eth = await findElement(driver, By.xpath(`//button[contains(text(), '10 ether')]`), 14000)
|
const send1eth = await findElement(driver, By.xpath(`//button[contains(text(), '10 ether')]`), 14000)
|
||||||
@ -403,47 +442,133 @@ describe('MetaMask', function () {
|
|||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
describe('Add existing token using search', () => {
|
describe('Deploy contract and call contract methods', () => {
|
||||||
it('clicks on the Add Token button', async () => {
|
let extension
|
||||||
const addToken = await findElement(driver, By.xpath(`//button[contains(text(), 'Add Token')]`))
|
let contractTestPage
|
||||||
await addToken.click()
|
it('confirms a deploy contract transaction', async () => {
|
||||||
|
await openNewPage(driver, 'http://127.0.0.1:8080/');
|
||||||
|
|
||||||
|
[extension, contractTestPage] = await driver.getAllWindowHandles()
|
||||||
await delay(regularDelayMs)
|
await delay(regularDelayMs)
|
||||||
|
|
||||||
|
const deployContractButton = await findElement(driver, By.css('#deployButton'))
|
||||||
|
await deployContractButton.click()
|
||||||
|
await delay(regularDelayMs)
|
||||||
|
|
||||||
|
await driver.switchTo().window(extension)
|
||||||
|
await delay(regularDelayMs)
|
||||||
|
|
||||||
|
const txListItem = await findElement(driver, By.css('.tx-list-item'))
|
||||||
|
await txListItem.click()
|
||||||
|
await delay(regularDelayMs)
|
||||||
|
|
||||||
|
const confirmButton = await findElement(driver, By.xpath(`//button[contains(text(), 'Confirm')]`))
|
||||||
|
await confirmButton.click()
|
||||||
|
await delay(regularDelayMs)
|
||||||
|
|
||||||
|
const txStatuses = await findElements(driver, By.css('.tx-list-status'))
|
||||||
|
await driver.wait(until.elementTextMatches(txStatuses[0], /Confirmed/))
|
||||||
|
|
||||||
|
const txAccounts = await findElements(driver, By.css('.tx-list-account'))
|
||||||
|
assert.equal(await txAccounts[0].getText(), 'Contract Deployment')
|
||||||
})
|
})
|
||||||
|
|
||||||
it('can pick a token from the existing options', async () => {
|
it('calls and confirms a contract method where ETH is sent', async () => {
|
||||||
const tokenSearch = await findElement(driver, By.css('#search-tokens'))
|
await driver.switchTo().window(contractTestPage)
|
||||||
await tokenSearch.sendKeys('BAT')
|
|
||||||
await delay(regularDelayMs)
|
await delay(regularDelayMs)
|
||||||
|
|
||||||
const token = await findElement(driver, By.xpath("//span[contains(text(), 'BAT')]"))
|
const depositButton = await findElement(driver, By.css('#depositButton'))
|
||||||
await token.click()
|
await depositButton.click()
|
||||||
await delay(regularDelayMs)
|
await delay(regularDelayMs)
|
||||||
|
|
||||||
const nextScreen = await findElement(driver, By.xpath(`//button[contains(text(), 'Next')]`))
|
await driver.switchTo().window(extension)
|
||||||
await nextScreen.click()
|
|
||||||
await delay(regularDelayMs)
|
await delay(regularDelayMs)
|
||||||
|
|
||||||
const addTokens = await findElement(driver, By.xpath(`//button[contains(text(), 'Add Tokens')]`))
|
const txListItem = await findElement(driver, By.css('.tx-list-item'))
|
||||||
await addTokens.click()
|
await txListItem.click()
|
||||||
await delay(largeDelayMs)
|
await delay(regularDelayMs)
|
||||||
|
|
||||||
|
// Set the gas limit
|
||||||
|
const configureGas = await findElement(driver, By.css('.sliders-icon-container'))
|
||||||
|
await configureGas.click()
|
||||||
|
await delay(regularDelayMs)
|
||||||
|
|
||||||
|
let gasModal = await driver.findElement(By.css('span .modal'))
|
||||||
|
await driver.wait(until.elementLocated(By.css('.send-v2__customize-gas__title')))
|
||||||
|
|
||||||
|
const [gasPriceInput, gasLimitInput] = await findElements(driver, By.css('.customize-gas-input'))
|
||||||
|
await gasPriceInput.clear()
|
||||||
|
await gasPriceInput.sendKeys('10')
|
||||||
|
await gasLimitInput.clear()
|
||||||
|
await gasLimitInput.sendKeys('60001')
|
||||||
|
|
||||||
|
const save = await findElement(driver, By.xpath(`//button[contains(text(), 'Save')]`))
|
||||||
|
await save.click()
|
||||||
|
await delay(regularDelayMs)
|
||||||
|
|
||||||
|
await driver.wait(until.stalenessOf(gasModal))
|
||||||
|
|
||||||
|
const confirmButton = await findElement(driver, By.xpath(`//button[contains(text(), 'Confirm')]`))
|
||||||
|
await confirmButton.click()
|
||||||
|
await delay(regularDelayMs)
|
||||||
|
|
||||||
|
const txStatuses = await findElements(driver, By.css('.tx-list-status'))
|
||||||
|
await driver.wait(until.elementTextMatches(txStatuses[0], /Confirmed/))
|
||||||
|
|
||||||
|
const txValues = await findElement(driver, By.css('.tx-list-value'))
|
||||||
|
await driver.wait(until.elementTextMatches(txValues, /3\sETH/), 10000)
|
||||||
|
|
||||||
|
const txAccounts = await findElements(driver, By.css('.tx-list-account'))
|
||||||
|
const firstTxAddress = await txAccounts[0].getText()
|
||||||
|
assert(firstTxAddress.match(/^0x\w{8}\.{3}\w{4}$/))
|
||||||
})
|
})
|
||||||
|
|
||||||
it('renders the balance for the chosen token', async () => {
|
it('calls and confirms a contract method where ETH is received', async () => {
|
||||||
|
await driver.switchTo().window(contractTestPage)
|
||||||
|
await delay(regularDelayMs)
|
||||||
|
|
||||||
|
const withdrawButton = await findElement(driver, By.css('#withdrawButton'))
|
||||||
|
await withdrawButton.click()
|
||||||
|
await delay(regularDelayMs)
|
||||||
|
|
||||||
|
await driver.switchTo().window(extension)
|
||||||
|
await delay(regularDelayMs)
|
||||||
|
|
||||||
|
const txListItem = await findElement(driver, By.css('.tx-list-item'))
|
||||||
|
await txListItem.click()
|
||||||
|
await delay(regularDelayMs)
|
||||||
|
|
||||||
|
const confirmButton = await findElement(driver, By.xpath(`//button[contains(text(), 'Confirm')]`))
|
||||||
|
await confirmButton.click()
|
||||||
|
await delay(regularDelayMs)
|
||||||
|
|
||||||
|
const txStatuses = await findElements(driver, By.css('.tx-list-status'))
|
||||||
|
await driver.wait(until.elementTextMatches(txStatuses[0], /Confirmed/))
|
||||||
|
|
||||||
|
const txValues = await findElement(driver, By.css('.tx-list-value'))
|
||||||
|
await driver.wait(until.elementTextMatches(txValues, /0\sETH/), 10000)
|
||||||
|
|
||||||
|
await driver.switchTo().window(contractTestPage)
|
||||||
|
await driver.close()
|
||||||
|
await driver.switchTo().window(extension)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('renders the correct ETH balance', async () => {
|
||||||
const balance = await findElement(driver, By.css('.tx-view .balance-display .token-amount'))
|
const balance = await findElement(driver, By.css('.tx-view .balance-display .token-amount'))
|
||||||
await driver.wait(until.elementTextMatches(balance, /^0\s*BAT\s*$/), 10000)
|
await driver.wait(until.elementTextMatches(balance, /^86.*ETH.*$/), 10000)
|
||||||
const tokenAmount = await balance.getText()
|
const tokenAmount = await balance.getText()
|
||||||
assert.ok(/^0\s*BAT\s*$/.test(tokenAmount))
|
assert.ok(/^86.*ETH.*$/.test(tokenAmount))
|
||||||
await delay(regularDelayMs)
|
await delay(regularDelayMs)
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
describe('Add a custom token from TokenFactory', () => {
|
describe('Add a custom token from TokenFactory', () => {
|
||||||
it('creates a new token', async () => {
|
it('creates a new token', async () => {
|
||||||
await driver.executeScript('window.open("https://tokenfactory.surge.sh/#/factory")')
|
openNewPage(driver, 'https://tokenfactory.surge.sh/#/factory')
|
||||||
await delay(waitingNewPageDelayMs)
|
|
||||||
|
|
||||||
|
await delay(regularDelayMs * 10)
|
||||||
const [extension, tokenFactory] = await driver.getAllWindowHandles()
|
const [extension, tokenFactory] = await driver.getAllWindowHandles()
|
||||||
await driver.switchTo().window(tokenFactory)
|
|
||||||
const [
|
const [
|
||||||
totalSupply,
|
totalSupply,
|
||||||
tokenName,
|
tokenName,
|
||||||
@ -470,12 +595,16 @@ describe('MetaMask', function () {
|
|||||||
|
|
||||||
await driver.switchTo().window(tokenFactory)
|
await driver.switchTo().window(tokenFactory)
|
||||||
await delay(regularDelayMs)
|
await delay(regularDelayMs)
|
||||||
|
|
||||||
const tokenContactAddress = await driver.findElement(By.css('div > div > div:nth-child(2) > span:nth-child(3)'))
|
const tokenContactAddress = await driver.findElement(By.css('div > div > div:nth-child(2) > span:nth-child(3)'))
|
||||||
tokenAddress = await tokenContactAddress.getText()
|
tokenAddress = await tokenContactAddress.getText()
|
||||||
|
|
||||||
await driver.close()
|
await driver.close()
|
||||||
await driver.switchTo().window(extension)
|
await driver.switchTo().window(extension)
|
||||||
await loadExtension(driver, extensionId)
|
await loadExtension(driver, extensionId)
|
||||||
|
await driver.switchTo().window(extension)
|
||||||
await delay(regularDelayMs)
|
await delay(regularDelayMs)
|
||||||
|
|
||||||
})
|
})
|
||||||
|
|
||||||
it('clicks on the Add Token button', async () => {
|
it('clicks on the Add Token button', async () => {
|
||||||
@ -510,4 +639,212 @@ describe('MetaMask', function () {
|
|||||||
await delay(regularDelayMs)
|
await delay(regularDelayMs)
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
describe('Send token from inside MetaMask', () => {
|
||||||
|
let gasModal
|
||||||
|
it('starts to send a transaction', async function () {
|
||||||
|
const sendButton = await findElement(driver, By.xpath(`//button[contains(text(), 'Send')]`))
|
||||||
|
await sendButton.click()
|
||||||
|
await delay(regularDelayMs)
|
||||||
|
|
||||||
|
const inputAddress = await findElement(driver, By.css('input[placeholder="Recipient Address"]'))
|
||||||
|
const inputAmount = await findElement(driver, By.css('.currency-display__input'))
|
||||||
|
await inputAddress.sendKeys('0x2f318C334780961FB129D2a6c30D0763d9a5C970')
|
||||||
|
await inputAmount.sendKeys('50')
|
||||||
|
|
||||||
|
// Set the gas limit
|
||||||
|
const configureGas = await findElement(driver, By.css('.send-v2__gas-fee-display button'))
|
||||||
|
await configureGas.click()
|
||||||
|
await delay(regularDelayMs)
|
||||||
|
|
||||||
|
gasModal = await driver.findElement(By.css('span .modal'))
|
||||||
|
})
|
||||||
|
|
||||||
|
it('customizes gas', async () => {
|
||||||
|
await driver.wait(until.elementLocated(By.css('.send-v2__customize-gas__title')))
|
||||||
|
const save = await findElement(driver, By.xpath(`//button[contains(text(), 'Save')]`))
|
||||||
|
await save.click()
|
||||||
|
await delay(regularDelayMs)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('transitions to the confirm screen', async () => {
|
||||||
|
await driver.wait(until.stalenessOf(gasModal))
|
||||||
|
|
||||||
|
// Continue to next screen
|
||||||
|
const nextScreen = await findElement(driver, By.xpath(`//button[contains(text(), 'Next')]`))
|
||||||
|
await nextScreen.click()
|
||||||
|
await delay(regularDelayMs)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('submits the transaction', async function () {
|
||||||
|
const confirmButton = await findElement(driver, By.xpath(`//button[contains(text(), 'Confirm')]`))
|
||||||
|
await confirmButton.click()
|
||||||
|
await delay(regularDelayMs)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('finds the transaction in the transactions list', async function () {
|
||||||
|
const transactions = await findElements(driver, By.css('.tx-list-item'))
|
||||||
|
assert.equal(transactions.length, 1)
|
||||||
|
|
||||||
|
const txValues = await findElements(driver, By.css('.tx-list-value'))
|
||||||
|
assert.equal(txValues.length, 1)
|
||||||
|
|
||||||
|
// test cancelled on firefox until https://github.com/mozilla/geckodriver/issues/906 is resolved,
|
||||||
|
// or possibly until we use latest version of firefox in the tests
|
||||||
|
if (process.env.SELENIUM_BROWSER !== 'firefox') {
|
||||||
|
await driver.wait(until.elementTextMatches(txValues[0], /50\sTST/), 10000)
|
||||||
|
}
|
||||||
|
|
||||||
|
const txStatuses = await findElements(driver, By.css('.tx-list-status'))
|
||||||
|
const tx = await driver.wait(until.elementTextMatches(txStatuses[0], /Confirmed|Failed/), 10000)
|
||||||
|
assert.equal(await tx.getText(), 'Confirmed')
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('Send a custom token from TokenFactory', () => {
|
||||||
|
let gasModal
|
||||||
|
it('sends an already created token', async () => {
|
||||||
|
openNewPage(driver, `https://tokenfactory.surge.sh/#/token/${tokenAddress}`)
|
||||||
|
|
||||||
|
const [extension, tokenFactory] = await driver.getAllWindowHandles()
|
||||||
|
|
||||||
|
const [
|
||||||
|
transferToAddress,
|
||||||
|
transferToAmount,
|
||||||
|
] = await findElements(driver, By.css('.form-control'))
|
||||||
|
|
||||||
|
await transferToAddress.sendKeys('0x2f318C334780961FB129D2a6c30D0763d9a5C970')
|
||||||
|
await transferToAmount.sendKeys('26')
|
||||||
|
|
||||||
|
const transferAmountButton = await findElement(driver, By.xpath(`//button[contains(text(), 'Transfer Amount')]`))
|
||||||
|
await transferAmountButton.click()
|
||||||
|
await delay(regularDelayMs)
|
||||||
|
|
||||||
|
const [,, popup] = await driver.getAllWindowHandles()
|
||||||
|
await driver.switchTo().window(popup)
|
||||||
|
await driver.close()
|
||||||
|
await driver.switchTo().window(extension)
|
||||||
|
await delay(regularDelayMs)
|
||||||
|
|
||||||
|
const [txListItem] = await findElements(driver, By.css('.tx-list-item'))
|
||||||
|
await txListItem.click()
|
||||||
|
await delay(regularDelayMs)
|
||||||
|
|
||||||
|
// Set the gas limit
|
||||||
|
const configureGas = await driver.wait(until.elementLocated(By.css('.send-v2__gas-fee-display button')))
|
||||||
|
await configureGas.click()
|
||||||
|
await delay(regularDelayMs)
|
||||||
|
|
||||||
|
gasModal = await driver.findElement(By.css('span .modal'))
|
||||||
|
})
|
||||||
|
|
||||||
|
it('customizes gas', async () => {
|
||||||
|
await driver.wait(until.elementLocated(By.css('.send-v2__customize-gas__title')))
|
||||||
|
|
||||||
|
const [gasPriceInput, gasLimitInput] = await findElements(driver, By.css('.customize-gas-input'))
|
||||||
|
await gasPriceInput.clear()
|
||||||
|
await delay(tinyDelayMs)
|
||||||
|
await gasPriceInput.sendKeys('10')
|
||||||
|
await delay(tinyDelayMs)
|
||||||
|
await gasLimitInput.clear()
|
||||||
|
await delay(tinyDelayMs)
|
||||||
|
await gasLimitInput.sendKeys(Key.chord(Key.CONTROL, 'a'))
|
||||||
|
await gasLimitInput.sendKeys('60000')
|
||||||
|
await gasLimitInput.sendKeys(Key.chord(Key.CONTROL, 'e'))
|
||||||
|
|
||||||
|
// Needed for different behaviour of input in different versions of firefox
|
||||||
|
const gasLimitInputValue = await gasLimitInput.getAttribute('value')
|
||||||
|
if (gasLimitInputValue === '600001') {
|
||||||
|
await gasLimitInput.sendKeys(Key.BACK_SPACE)
|
||||||
|
}
|
||||||
|
|
||||||
|
const save = await findElement(driver, By.css('.send-v2__customize-gas__save'))
|
||||||
|
await save.click()
|
||||||
|
await driver.wait(until.stalenessOf(gasModal))
|
||||||
|
|
||||||
|
const gasFeeInput = await findElement(driver, By.css('.currency-display__input'))
|
||||||
|
assert.equal(await gasFeeInput.getAttribute('value'), 0.0006)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('submits the transaction', async function () {
|
||||||
|
const confirmButton = await findElement(driver, By.xpath(`//button[contains(text(), 'Confirm')]`))
|
||||||
|
await confirmButton.click()
|
||||||
|
await delay(regularDelayMs)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('finds the transaction in the transactions list', async function () {
|
||||||
|
const transactions = await findElements(driver, By.css('.tx-list-item'))
|
||||||
|
assert.equal(transactions.length, 2)
|
||||||
|
|
||||||
|
const txValues = await findElements(driver, By.css('.tx-list-value'))
|
||||||
|
await driver.wait(until.elementTextMatches(txValues[0], /26\sTST/))
|
||||||
|
const txStatuses = await findElements(driver, By.css('.tx-list-status'))
|
||||||
|
await driver.wait(until.elementTextMatches(txStatuses[0], /Confirmed/))
|
||||||
|
|
||||||
|
const walletBalance = await findElement(driver, By.css('.wallet-balance'))
|
||||||
|
await walletBalance.click()
|
||||||
|
|
||||||
|
const tokenListItems = await findElements(driver, By.css('.token-list-item'))
|
||||||
|
await tokenListItems[0].click()
|
||||||
|
|
||||||
|
// test cancelled on firefox until https://github.com/mozilla/geckodriver/issues/906 is resolved,
|
||||||
|
// or possibly until we use latest version of firefox in the tests
|
||||||
|
if (process.env.SELENIUM_BROWSER !== 'firefox') {
|
||||||
|
const tokenBalanceAmount = await findElement(driver, By.css('.token-balance__amount'))
|
||||||
|
assert.equal(await tokenBalanceAmount.getText(), '24')
|
||||||
|
}
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('Hide token', () => {
|
||||||
|
it('hides the token when clicked', async () => {
|
||||||
|
const [hideTokenEllipsis] = await findElements(driver, By.css('.token-list-item__ellipsis'))
|
||||||
|
await hideTokenEllipsis.click()
|
||||||
|
|
||||||
|
const byTokenMenuDropdownOption = By.css('.menu__item--clickable')
|
||||||
|
const tokenMenuDropdownOption = await driver.wait(until.elementLocated(byTokenMenuDropdownOption))
|
||||||
|
|
||||||
|
await tokenMenuDropdownOption.click()
|
||||||
|
|
||||||
|
const confirmHideModal = await findElement(driver, By.css('span .modal'))
|
||||||
|
|
||||||
|
const byHideTokenConfirmationButton = By.css('.hide-token-confirmation__button')
|
||||||
|
const hideTokenConfirmationButton = await driver.wait(until.elementLocated(byHideTokenConfirmationButton))
|
||||||
|
await hideTokenConfirmationButton.click()
|
||||||
|
|
||||||
|
await driver.wait(until.stalenessOf(confirmHideModal))
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('Add existing token using search', () => {
|
||||||
|
it('clicks on the Add Token button', async () => {
|
||||||
|
const addToken = await findElement(driver, By.xpath(`//button[contains(text(), 'Add Token')]`))
|
||||||
|
await addToken.click()
|
||||||
|
await delay(regularDelayMs)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('can pick a token from the existing options', async () => {
|
||||||
|
const tokenSearch = await findElement(driver, By.css('#search-tokens'))
|
||||||
|
await tokenSearch.sendKeys('BAT')
|
||||||
|
await delay(regularDelayMs)
|
||||||
|
|
||||||
|
const token = await findElement(driver, By.xpath("//span[contains(text(), 'BAT')]"))
|
||||||
|
await token.click()
|
||||||
|
await delay(regularDelayMs)
|
||||||
|
|
||||||
|
const nextScreen = await findElement(driver, By.xpath(`//button[contains(text(), 'Next')]`))
|
||||||
|
await nextScreen.click()
|
||||||
|
await delay(regularDelayMs)
|
||||||
|
|
||||||
|
const addTokens = await findElement(driver, By.xpath(`//button[contains(text(), 'Add Tokens')]`))
|
||||||
|
await addTokens.click()
|
||||||
|
await delay(largeDelayMs)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('renders the balance for the chosen token', async () => {
|
||||||
|
const balance = await findElement(driver, By.css('.tx-view .balance-display .token-amount'))
|
||||||
|
await driver.wait(until.elementTextMatches(balance, /0\sBAT/))
|
||||||
|
await delay(regularDelayMs)
|
||||||
|
})
|
||||||
|
})
|
||||||
})
|
})
|
||||||
|
@ -6,5 +6,5 @@ set -o pipefail
|
|||||||
|
|
||||||
export PATH="$PATH:./node_modules/.bin"
|
export PATH="$PATH:./node_modules/.bin"
|
||||||
|
|
||||||
shell-parallel -s 'npm run ganache:start' -x 'sleep 5 && mocha test/e2e/beta/metamask-beta-ui.spec'
|
shell-parallel -s 'npm run ganache:start' -x 'sleep 5 && superstatic test/e2e/beta/contract-test/ --port 8080 --host 127.0.0.1' -x 'sleep 5 && mocha test/e2e/beta/metamask-beta-ui.spec'
|
||||||
shell-parallel -s 'npm run ganache:start' -x 'sleep 5 && mocha test/e2e/beta/from-import-beta-ui.spec'
|
shell-parallel -s 'npm run ganache:start -- -d' -x 'sleep 5 && superstatic test/e2e/beta/contract-test/ --port 8080 --host 127.0.0.1' -x 'sleep 5 && mocha test/e2e/beta/from-import-beta-ui.spec'
|
||||||
|
@ -4,7 +4,7 @@ const path = require('path')
|
|||||||
const assert = require('assert')
|
const assert = require('assert')
|
||||||
const pify = require('pify')
|
const pify = require('pify')
|
||||||
const webdriver = require('selenium-webdriver')
|
const webdriver = require('selenium-webdriver')
|
||||||
const { By, Key } = webdriver
|
const { By, Key, until } = webdriver
|
||||||
const { delay, buildChromeWebDriver, buildFirefoxWebdriver, installWebExt, getExtensionIdChrome, getExtensionIdFirefox } = require('./func')
|
const { delay, buildChromeWebDriver, buildFirefoxWebdriver, installWebExt, getExtensionIdChrome, getExtensionIdFirefox } = require('./func')
|
||||||
|
|
||||||
describe('Metamask popup page', function () {
|
describe('Metamask popup page', function () {
|
||||||
@ -229,7 +229,11 @@ describe('Metamask popup page', function () {
|
|||||||
|
|
||||||
it('confirms transaction', async function () {
|
it('confirms transaction', async function () {
|
||||||
await delay(300)
|
await delay(300)
|
||||||
await driver.findElement(By.css('#pending-tx-form > div.flex-row.flex-space-around.conf-buttons > input')).click()
|
const bySubmitButton = By.css('#pending-tx-form > div.flex-row.flex-space-around.conf-buttons > input')
|
||||||
|
const submitButton = await driver.wait(until.elementLocated(bySubmitButton))
|
||||||
|
|
||||||
|
submitButton.click()
|
||||||
|
|
||||||
await delay(500)
|
await delay(500)
|
||||||
})
|
})
|
||||||
|
|
||||||
@ -269,7 +273,8 @@ describe('Metamask popup page', function () {
|
|||||||
it('confirms transaction in MetaMask popup', async function () {
|
it('confirms transaction in MetaMask popup', async function () {
|
||||||
const windowHandles = await driver.getAllWindowHandles()
|
const windowHandles = await driver.getAllWindowHandles()
|
||||||
await driver.switchTo().window(windowHandles[windowHandles.length - 1])
|
await driver.switchTo().window(windowHandles[windowHandles.length - 1])
|
||||||
const metamaskSubmit = await driver.findElement(By.css('#pending-tx-form > div.flex-row.flex-space-around.conf-buttons > input'))
|
const byMetamaskSubmit = By.css('#pending-tx-form > div.flex-row.flex-space-around.conf-buttons > input')
|
||||||
|
const metamaskSubmit = await driver.wait(until.elementLocated(byMetamaskSubmit))
|
||||||
await metamaskSubmit.click()
|
await metamaskSubmit.click()
|
||||||
await delay(1000)
|
await delay(1000)
|
||||||
})
|
})
|
||||||
|
@ -22,12 +22,16 @@ function isValidInput (text) {
|
|||||||
return re.test(text)
|
return re.test(text)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function removeLeadingZeroes (str) {
|
||||||
|
return str.replace(/^0*(?=\d)/, '')
|
||||||
|
}
|
||||||
|
|
||||||
InputNumber.prototype.setValue = function (newValue) {
|
InputNumber.prototype.setValue = function (newValue) {
|
||||||
|
newValue = removeLeadingZeroes(newValue)
|
||||||
if (newValue && !isValidInput(newValue)) return
|
if (newValue && !isValidInput(newValue)) return
|
||||||
const { fixed, min = -1, max = Infinity, onChange } = this.props
|
const { fixed, min = -1, max = Infinity, onChange } = this.props
|
||||||
|
|
||||||
newValue = fixed ? newValue.toFixed(4) : newValue
|
newValue = fixed ? newValue.toFixed(4) : newValue
|
||||||
|
|
||||||
const newValueGreaterThanMin = conversionGTE(
|
const newValueGreaterThanMin = conversionGTE(
|
||||||
{ value: newValue || '0', fromNumericBase: 'dec' },
|
{ value: newValue || '0', fromNumericBase: 'dec' },
|
||||||
{ value: min, fromNumericBase: 'hex' },
|
{ value: min, fromNumericBase: 'hex' },
|
||||||
@ -47,7 +51,7 @@ InputNumber.prototype.setValue = function (newValue) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
InputNumber.prototype.render = function () {
|
InputNumber.prototype.render = function () {
|
||||||
const { unitLabel, step = 1, placeholder, value = 0 } = this.props
|
const { unitLabel, step = 1, placeholder, value } = this.props
|
||||||
|
|
||||||
return h('div.customize-gas-input-wrapper', {}, [
|
return h('div.customize-gas-input-wrapper', {}, [
|
||||||
h('input', {
|
h('input', {
|
||||||
@ -63,11 +67,11 @@ InputNumber.prototype.render = function () {
|
|||||||
h('span.gas-tooltip-input-detail', {}, [unitLabel]),
|
h('span.gas-tooltip-input-detail', {}, [unitLabel]),
|
||||||
h('div.gas-tooltip-input-arrows', {}, [
|
h('div.gas-tooltip-input-arrows', {}, [
|
||||||
h('i.fa.fa-angle-up', {
|
h('i.fa.fa-angle-up', {
|
||||||
onClick: () => this.setValue(addCurrencies(value, step)),
|
onClick: () => this.setValue(addCurrencies(value, step, { toNumericBase: 'dec' })),
|
||||||
}),
|
}),
|
||||||
h('i.fa.fa-angle-down', {
|
h('i.fa.fa-angle-down', {
|
||||||
style: { cursor: 'pointer' },
|
style: { cursor: 'pointer' },
|
||||||
onClick: () => this.setValue(subtractCurrencies(value, step)),
|
onClick: () => this.setValue(subtractCurrencies(value, step, { toNumericBase: 'dec' })),
|
||||||
}),
|
}),
|
||||||
]),
|
]),
|
||||||
])
|
])
|
||||||
|
Loading…
Reference in New Issue
Block a user