-
Notifications
You must be signed in to change notification settings - Fork 1.2k
/
Copy pathBrowserTabsUtil.ts
120 lines (91 loc) · 3.97 KB
/
BrowserTabsUtil.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
/*********************************************************************
* Copyright (c) 2019 Red Hat, Inc.
*
* This program and the accompanying materials are made
* available under the terms of the Eclipse Public License 2.0
* which is available at https://www.eclipse.org/legal/epl-2.0/
*
* SPDX-License-Identifier: EPL-2.0
**********************************************************************/
import { injectable, inject } from 'inversify';
import { By, error } from 'selenium-webdriver';
import { CLASSES } from '../inversify.types';
import { DriverHelper } from './DriverHelper';
import { Logger } from './Logger';
import { TimeoutConstants } from '../TimeoutConstants';
@injectable()
export class BrowserTabsUtil {
constructor(@inject(CLASSES.DriverHelper) private readonly driverHelper: DriverHelper) { }
async switchToWindow(windowHandle: string) {
Logger.debug('BrowserTabsUtil.switchToWindow');
await this.driverHelper.getDriver().switchTo().window(windowHandle);
}
async getAllWindowHandles(): Promise<string[]> {
Logger.debug('BrowserTabsUtil.getAllWindowHandles');
return (await this.driverHelper.getDriver()).getAllWindowHandles();
}
async getCurrentWindowHandle(): Promise<string> {
Logger.debug('BrowserTabsUtil.getCurrentWindowHandle');
return await this.driverHelper.getDriver().getWindowHandle();
}
async navigateTo(url: string) {
Logger.debug(`BrowserTabsUtil.navigateTo ${url}`);
await this.driverHelper.getDriver().navigate().to(url);
}
async navigateAndWaitToUrl(url: string, timeout: number = TimeoutConstants.TS_SELENIUM_WAIT_FOR_URL) {
Logger.trace(`BrowserTabsUtil.navigateAndWaitToUrl ${url}`);
await this.navigateTo(url);
await this.waitURL(url, timeout);
}
async waitAndSwitchToAnotherWindow(currentWindowHandle: string, timeout: number) {
Logger.debug('BrowserTabsUtil.waitAndSwitchToAnotherWindow');
await this.driverHelper.waitUntilTrue(async () => {
const windowHandles: string[] = await this.getAllWindowHandles();
return windowHandles.length > 1;
}, timeout);
const windowHandles: string[] = await this.getAllWindowHandles();
windowHandles.forEach(async windowHandle => {
if (windowHandle !== currentWindowHandle) {
await this.switchToWindow(windowHandle);
return;
}
});
}
async waitContentAvailableInTheNewTab(contentLocator: By, timeout: number) {
Logger.debug('BrowserTabsUtil.waitContentAvailableInTheNewTab');
await this.driverHelper.waitVisibility(contentLocator, timeout);
}
async refreshPage() {
Logger.debug('BrowserTabsUtil.refreshPage');
await (await this.driverHelper.getDriver()).navigate().refresh();
}
async refreshForDebug() {
Logger.debug('BrowserTabsUtil.refreshForDebug');
// if refresh triggers debug breakpoint test stucks of the refreshing
// and fail with a timeout error.
try {
await (await this.driverHelper.getDriver()).navigate().refresh();
} catch (err) {
if (!(err instanceof error.TimeoutError)) {
throw err;
}
}
}
async getCurrentUrl(): Promise<string> {
return await this.driverHelper.getDriver().getCurrentUrl();
}
async waitURL(expectedUrl: string, timeout: number) {
Logger.trace(`BrowserTabsUtil.waitURL ${expectedUrl}`);
await this.driverHelper.getDriver().wait(async () => {
const currentUrl: string = await this.driverHelper.getDriver().getCurrentUrl();
const urlEquals: boolean = currentUrl === expectedUrl;
if (urlEquals) {
return true;
}
}, timeout);
}
public async maximize() {
Logger.trace(`BrowserTabsUtil.maximize`);
await this.driverHelper.getDriver().manage().window().maximize();
}
}