aboutsummaryrefslogtreecommitdiffstats
path: root/test/e2e/beta/helpers.js
diff options
context:
space:
mode:
authorDan <danjm.com@gmail.com>2018-07-07 06:55:30 +0800
committerDan <danjm.com@gmail.com>2018-07-11 03:48:16 +0800
commit1a0a701de0fe97386a5acb666c4a4e123f27af94 (patch)
tree563df8f2e99a842ee7568f2a93383d6ae462f5ea /test/e2e/beta/helpers.js
parent76e80f631e15fafd7e0bd0117fc1703944cb2fb6 (diff)
downloadtangerine-wallet-browser-1a0a701de0fe97386a5acb666c4a4e123f27af94.tar
tangerine-wallet-browser-1a0a701de0fe97386a5acb666c4a4e123f27af94.tar.gz
tangerine-wallet-browser-1a0a701de0fe97386a5acb666c4a4e123f27af94.tar.bz2
tangerine-wallet-browser-1a0a701de0fe97386a5acb666c4a4e123f27af94.tar.lz
tangerine-wallet-browser-1a0a701de0fe97386a5acb666c4a4e123f27af94.tar.xz
tangerine-wallet-browser-1a0a701de0fe97386a5acb666c4a4e123f27af94.tar.zst
tangerine-wallet-browser-1a0a701de0fe97386a5acb666c4a4e123f27af94.zip
Handles window indeterminancy issues for external dapps in e2e beta tests.
Diffstat (limited to 'test/e2e/beta/helpers.js')
-rw-r--r--test/e2e/beta/helpers.js48
1 files changed, 44 insertions, 4 deletions
diff --git a/test/e2e/beta/helpers.js b/test/e2e/beta/helpers.js
index fcc3e96d6..e7299184e 100644
--- a/test/e2e/beta/helpers.js
+++ b/test/e2e/beta/helpers.js
@@ -6,11 +6,14 @@ const { delay } = require('../func')
module.exports = {
checkBrowserForConsoleErrors,
- loadExtension,
- verboseReportOnFailure,
+ closeAllWindowHandlesExcept,
findElement,
findElements,
+ loadExtension,
openNewPage,
+ switchToWindowWithTitle,
+ verboseReportOnFailure,
+ waitUntilXWindowHandles,
}
async function loadExtension (driver, extensionId) {
@@ -72,9 +75,46 @@ async function openNewPage (driver, url) {
await delay(1000)
const handles = await driver.getAllWindowHandles()
- const secondHandle = handles[1]
- await driver.switchTo().window(secondHandle)
+ const lastHandle = handles[handles.length - 1]
+ await driver.switchTo().window(lastHandle)
await driver.get(url)
await delay(1000)
}
+
+async function waitUntilXWindowHandles (driver, x) {
+ const windowHandles = await driver.getAllWindowHandles()
+ if (windowHandles.length === x) return
+ await delay(1000)
+ return await waitUntilXWindowHandles(driver, x)
+}
+
+async function switchToWindowWithTitle (driver, title, windowHandles) {
+ if (!windowHandles) {
+ windowHandles = await driver.getAllWindowHandles()
+ } else if (windowHandles.length === 0) {
+ throw new Error('No window with title: ' + title)
+ }
+ const firstHandle = windowHandles[0]
+ await driver.switchTo().window(firstHandle)
+ const handleTitle = await driver.getTitle()
+
+ if (handleTitle === title) {
+ return firstHandle
+ } else {
+ return await switchToWindowWithTitle(driver, title, windowHandles.slice(1))
+ }
+}
+
+async function closeAllWindowHandlesExcept (driver, exceptions, windowHandles) {
+ exceptions = typeof exceptions === 'string' ? [ exceptions ] : exceptions
+ windowHandles = windowHandles || await driver.getAllWindowHandles()
+ const lastWindowHandle = windowHandles.pop()
+ if (!exceptions.includes(lastWindowHandle)) {
+ await driver.switchTo().window(lastWindowHandle)
+ await delay(1000)
+ await driver.close()
+ await delay(1000)
+ }
+ return windowHandles.length && await closeAllWindowHandlesExcept(driver, exceptions, windowHandles)
+}