aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDan <danjm.com@gmail.com>2018-06-11 21:08:24 +0800
committerDan <danjm.com@gmail.com>2018-06-27 21:31:25 +0800
commit797a3ee686bd3ed87ea0669a1a21da45f02d7e81 (patch)
tree4d2330e9db5a2ff3f7f68f967e3e05da88eabf76
parente293233c5e5f2f85054af1918ecb3f0e9c4dbd8b (diff)
downloadtangerine-wallet-browser-797a3ee686bd3ed87ea0669a1a21da45f02d7e81.tar
tangerine-wallet-browser-797a3ee686bd3ed87ea0669a1a21da45f02d7e81.tar.gz
tangerine-wallet-browser-797a3ee686bd3ed87ea0669a1a21da45f02d7e81.tar.bz2
tangerine-wallet-browser-797a3ee686bd3ed87ea0669a1a21da45f02d7e81.tar.lz
tangerine-wallet-browser-797a3ee686bd3ed87ea0669a1a21da45f02d7e81.tar.xz
tangerine-wallet-browser-797a3ee686bd3ed87ea0669a1a21da45f02d7e81.tar.zst
tangerine-wallet-browser-797a3ee686bd3ed87ea0669a1a21da45f02d7e81.zip
e2e beta tests for contract deployment and calling a contract method.
-rw-r--r--test/e2e/beta/helpers.js29
-rw-r--r--test/e2e/beta/metamask-beta-ui.spec.js108
2 files changed, 135 insertions, 2 deletions
diff --git a/test/e2e/beta/helpers.js b/test/e2e/beta/helpers.js
index 31c41d8b7..949fece96 100644
--- a/test/e2e/beta/helpers.js
+++ b/test/e2e/beta/helpers.js
@@ -3,12 +3,41 @@ const mkdirp = require('mkdirp')
const pify = require('pify')
const {until} = require('selenium-webdriver')
+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,
+ testContract,
}
async function loadExtension (driver, extensionId) {
diff --git a/test/e2e/beta/metamask-beta-ui.spec.js b/test/e2e/beta/metamask-beta-ui.spec.js
index 736cbc916..5b257ff65 100644
--- a/test/e2e/beta/metamask-beta-ui.spec.js
+++ b/test/e2e/beta/metamask-beta-ui.spec.js
@@ -16,6 +16,7 @@ const {
checkBrowserForConsoleErrors,
loadExtension,
verboseReportOnFailure,
+ testContract,
} = require('./helpers')
describe('MetaMask', function () {
@@ -353,6 +354,7 @@ describe('MetaMask', function () {
await delay(regularDelayMs)
const gasModal = await driver.findElement(By.css('span .modal'))
+
const save = await findElement(driver, By.xpath(`//button[contains(text(), 'Save')]`))
await save.click()
await driver.wait(until.stalenessOf(gasModal))
@@ -412,6 +414,108 @@ describe('MetaMask', function () {
})
})
+ describe('Deploy contract and call contract method from Remix', () => {
+ it('writes a contract to remix', async () => {
+ await driver.executeScript('window.open("https://remix.ethereum.org/")')
+ await delay(waitingNewPageDelayMs)
+
+ const [extension, remix] = await driver.getAllWindowHandles()
+ await driver.switchTo().window(remix)
+
+ const newContractButton = await findElement(driver, By.css('.fa-plus-circle'))
+ await newContractButton.click()
+ await delay(regularDelayMs)
+
+ const modalFooterOkay = await findElement(driver, By.css('#modal-footer-ok'))
+ await modalFooterOkay.click()
+ await delay(regularDelayMs)
+
+ await driver.executeScript('window.document.getElementById("input").editor.session.setValue(arguments[0])', testContract)
+ await delay(regularDelayMs)
+ })
+
+ it('compiles the contract', async () => {
+ const [extension, remix] = await driver.getAllWindowHandles()
+
+ const compileButton = await findElement(driver, By.css('#compile'))
+ compileButton.click()
+ const byOption = By.xpath(`//option[contains(text(), 'PiggyBank')]`)
+ await driver.wait(until.elementLocated(byOption, 10000))
+ await delay(regularDelayMs)
+
+ const runTab = await findElement(driver, By.xpath(`//li[contains(text(), 'Run')]`))
+ await runTab.click()
+ await delay(regularDelayMs)
+
+ const deployButton = await findElement(driver, By.xpath(`//button[contains(text(), 'Deploy')]`))
+ await deployButton.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)
+
+ 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('calls and confirms a contract method', async () => {
+ const [extension, remix] = await driver.getAllWindowHandles()
+ await driver.switchTo().window(remix)
+ await delay(regularDelayMs)
+
+ const depositButton = await findElement(driver, By.xpath(`//button[contains(text(), 'deposit')]`))
+ await depositButton.click()
+ await delay(regularDelayMs)
+
+ await driver.switchTo().window(extension)
+ await loadExtension(driver, extensionId)
+ 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'))
+
+ 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 txAccounts = await findElements(driver, By.css('.tx-list-account'))
+ const firstTxAddress = await txAccounts[0].getText()
+ assert(firstTxAddress.match(/^0x\w{8}\.{3}\w{4}$/))
+
+ await driver.switchTo().window(remix)
+ await driver.close()
+ await driver.switchTo().window(extension)
+ 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")')
@@ -677,10 +781,10 @@ describe('MetaMask', function () {
it('finds the transaction in the transactions list', async function () {
const transactions = await findElements(driver, By.css('.tx-list-item'))
- assert.equal(transactions.length, 5)
+ assert.equal(transactions.length, 7)
const txValues = await findElements(driver, By.css('.tx-list-value'))
- assert.equal(txValues.length, 5)
+ assert.equal(txValues.length, 7)
assert.equal(await txValues[0].getText(), '26 TST')
const txStatuses = await findElements(driver, By.css('.tx-list-status'))
await driver.wait(until.elementTextMatches(txStatuses[0], /Confirmed/))