aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorThomas Huang <tmashuang@users.noreply.github.com>2018-03-30 07:21:18 +0800
committerGitHub <noreply@github.com>2018-03-30 07:21:18 +0800
commit5a0523cdfd50dcd4e5680134346ccfcb4bb7cbf4 (patch)
tree4a82ba0d3214eb65f494487f7c38c1a0b0a2a498
parent9ec42a87b3d7cf669082c046c5acbd1bc0f5f747 (diff)
parentf6f8cab5dc9ecf750f6e567d0effe0bacc2495d8 (diff)
downloadtangerine-wallet-browser-5a0523cdfd50dcd4e5680134346ccfcb4bb7cbf4.tar
tangerine-wallet-browser-5a0523cdfd50dcd4e5680134346ccfcb4bb7cbf4.tar.gz
tangerine-wallet-browser-5a0523cdfd50dcd4e5680134346ccfcb4bb7cbf4.tar.bz2
tangerine-wallet-browser-5a0523cdfd50dcd4e5680134346ccfcb4bb7cbf4.tar.lz
tangerine-wallet-browser-5a0523cdfd50dcd4e5680134346ccfcb4bb7cbf4.tar.xz
tangerine-wallet-browser-5a0523cdfd50dcd4e5680134346ccfcb4bb7cbf4.tar.zst
tangerine-wallet-browser-5a0523cdfd50dcd4e5680134346ccfcb4bb7cbf4.zip
Merge pull request #3798 from MetaMask/e2e-selector
test - e2e - generate artifacts on test failure
-rw-r--r--.circleci/config.yml3
-rw-r--r--.gitignore2
-rw-r--r--test/e2e/metamask.spec.js30
3 files changed, 29 insertions, 6 deletions
diff --git a/.circleci/config.yml b/.circleci/config.yml
index 75819fc6e..ae6f44c8a 100644
--- a/.circleci/config.yml
+++ b/.circleci/config.yml
@@ -141,6 +141,9 @@ jobs:
- run:
name: Test
command: npm run test:e2e
+ - store_artifacts:
+ path: test-artifacts
+ destination: test-artifacts
test-unit:
docker:
diff --git a/.gitignore b/.gitignore
index f2a678777..dee5ec220 100644
--- a/.gitignore
+++ b/.gitignore
@@ -28,6 +28,8 @@ test/background.js
test/bundle.js
test/test-bundle.js
+test-artifacts
+
#ignore css output and sourcemaps
ui/app/css/output/
diff --git a/test/e2e/metamask.spec.js b/test/e2e/metamask.spec.js
index b254d9a3c..ff5bdb51b 100644
--- a/test/e2e/metamask.spec.js
+++ b/test/e2e/metamask.spec.js
@@ -1,5 +1,8 @@
+const fs = require('fs')
+const mkdirp = require('mkdirp')
const path = require('path')
const assert = require('assert')
+const pify = require('pify')
const webdriver = require('selenium-webdriver')
const By = webdriver.By
const { delay, buildWebDriver } = require('./func')
@@ -20,6 +23,12 @@ describe('Metamask popup page', function () {
await delay(500)
})
+ afterEach(async function () {
+ if (this.currentTest.state === 'failed') {
+ await verboseReportOnFailure(this.currentTest)
+ }
+ })
+
after(async function () {
await driver.quit()
})
@@ -39,9 +48,7 @@ describe('Metamask popup page', function () {
it('should show privacy notice', async () => {
const privacy = await driver.findElement(By.css('.terms-header')).getText()
assert.equal(privacy, 'PRIVACY NOTICE', 'shows privacy notice')
- driver.findElement(By.css(
- 'button'
- )).click()
+ driver.findElement(By.css('button')).click()
await delay(300)
})
@@ -53,9 +60,7 @@ describe('Metamask popup page', function () {
})
it('should be unable to continue without scolling throught the terms of use', async () => {
- const button = await driver.findElement(By.css(
- 'button'
- )).isEnabled()
+ const button = await driver.findElement(By.css('button')).isEnabled()
assert.equal(button, false, 'disabled continue button')
const element = driver.findElement(By.linkText(
'Attributions'
@@ -118,4 +123,17 @@ describe('Metamask popup page', function () {
await delay(500)
})
})
+
+ async function verboseReportOnFailure(test) {
+ const artifactDir = `./test-artifacts/${test.title}`
+ const filepathBase = `${artifactDir}/test-failure`
+ await pify(mkdirp)(artifactDir)
+ // capture screenshot
+ const screenshot = await driver.takeScreenshot()
+ await pify(fs.writeFile)(`${filepathBase}-screenshot.png`, screenshot, { encoding: 'base64' })
+ // capture dom source
+ const htmlSource = await driver.getPageSource()
+ await pify(fs.writeFile)(`${filepathBase}-dom.html`, htmlSource)
+ }
+
})