aboutsummaryrefslogtreecommitdiffstats
path: root/test/e2e/beta/metamask-beta-ui.spec.js
diff options
context:
space:
mode:
authorDan <danjm.com@gmail.com>2018-06-08 00:53:54 +0800
committerDan <danjm.com@gmail.com>2018-06-27 21:28:55 +0800
commit9cb15d44a055399c320d4544a2c71ffb7bf152c9 (patch)
tree610f9ccc4f9fd94f20726f54d453e0ccb1a0427d /test/e2e/beta/metamask-beta-ui.spec.js
parent67894ef2e282f67539c4e7e00b1014f3854db8e0 (diff)
downloadtangerine-wallet-browser-9cb15d44a055399c320d4544a2c71ffb7bf152c9.tar
tangerine-wallet-browser-9cb15d44a055399c320d4544a2c71ffb7bf152c9.tar.gz
tangerine-wallet-browser-9cb15d44a055399c320d4544a2c71ffb7bf152c9.tar.bz2
tangerine-wallet-browser-9cb15d44a055399c320d4544a2c71ffb7bf152c9.tar.lz
tangerine-wallet-browser-9cb15d44a055399c320d4544a2c71ffb7bf152c9.tar.xz
tangerine-wallet-browser-9cb15d44a055399c320d4544a2c71ffb7bf152c9.tar.zst
tangerine-wallet-browser-9cb15d44a055399c320d4544a2c71ffb7bf152c9.zip
Adds e2e tests for sending tokens from token factory.
Diffstat (limited to 'test/e2e/beta/metamask-beta-ui.spec.js')
-rw-r--r--test/e2e/beta/metamask-beta-ui.spec.js64
1 files changed, 61 insertions, 3 deletions
diff --git a/test/e2e/beta/metamask-beta-ui.spec.js b/test/e2e/beta/metamask-beta-ui.spec.js
index bbebecc39..add730271 100644
--- a/test/e2e/beta/metamask-beta-ui.spec.js
+++ b/test/e2e/beta/metamask-beta-ui.spec.js
@@ -616,6 +616,7 @@ describe('MetaMask', function () {
})
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()
@@ -631,11 +632,23 @@ describe('MetaMask', function () {
await configureGas.click()
await delay(regularDelayMs)
- const gasModal = await driver.findElement(By.css('span .modal'))
+ gasModal = await driver.findElement(By.css('span .modal'))
+ })
+
+ it('customizes gas', async () => {
+ const [gasPriceInput, gasLimitInput] = await findElements(driver, By.css('.customize-gas-input'))
+ await gasPriceInput.clear()
+ await gasPriceInput.sendKeys('12.5')
+ await gasLimitInput.clear()
+ await gasLimitInput.sendKeys('56789')
+
const save = await findElement(driver, By.xpath(`//button[contains(text(), 'Save')]`))
await save.click()
- await driver.wait(until.stalenessOf(gasModal))
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')]`))
@@ -643,7 +656,7 @@ describe('MetaMask', function () {
await delay(regularDelayMs)
})
- it('confirms the transaction', async function () {
+ it('submits the transaction', async function () {
const confirmButton = await findElement(driver, By.xpath(`//button[contains(text(), 'Confirm')]`))
await confirmButton.click()
await delay(regularDelayMs)
@@ -656,6 +669,51 @@ describe('MetaMask', function () {
const txValues = await findElements(driver, By.css('.tx-list-value'))
assert.equal(txValues.length, 1)
assert.equal(await txValues[0].getText(), '50 TST')
+ const txStatuses = await findElements(driver, By.css('.tx-list-status'))
+ await driver.wait(until.elementTextMatches(txStatuses[0], /Confirmed/))
+ })
+ })
+
+ describe('Send a custom token from TokenFactory', () => {
+ it('sends an already created token', async () => {
+ await driver.executeScript(`window.open("https://tokenfactory.surge.sh/#/token/${tokenAddress}")`)
+ await delay(waitingNewPageDelayMs)
+
+ const [extension, tokenFactory] = await driver.getAllWindowHandles()
+ await driver.switchTo().window(tokenFactory)
+ 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)
+
+ 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)
+ })
+
+ 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)
+
+ const txValues = await findElements(driver, By.css('.tx-list-value'))
+ assert.equal(txValues.length, 5)
+ assert.equal(await txValues[0].getText(), '26 TST')
+ const txStatuses = await findElements(driver, By.css('.tx-list-status'))
+ await driver.wait(until.elementTextMatches(txStatuses[1], /Confirmed/))
+
+ const tokenBalanceAmount = await findElement(driver, By.css('.token-balance__amount'))
+ assert.equal(tokenBalanceAmount.getText(), '24 TST')
})
})
})