rabbitmq-server/deps/rabbitmq_management/selenium/test/pageobjects/BasePage.js

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

157 lines
4.9 KiB
JavaScript
Raw Normal View History

const { By, Key, until, Builder } = require('selenium-webdriver')
module.exports = class BasePage {
driver
constructor (webdriver) {
this.driver = webdriver
}
2022-12-19 23:23:25 +08:00
async waitForLocated (locator, retries = 3) {
try {
2022-12-19 23:23:25 +08:00
await this.driver.wait(until.elementLocated(locator), 2000)
} catch (err) {
if (retries === 0) {
throw new Error(`Still not able to locate element ${locator.toString()} after maximum retries, Error message: ${err.message.toString()}`)
}
2022-12-19 23:23:25 +08:00
await this.driver.sleep(250)
return this.waitForLocated(driver, locator, retries - 1)
}
}
2022-12-19 23:23:25 +08:00
async waitForVisible (locator, retries = 3) {
try {
2022-12-19 23:23:25 +08:00
const element = await this.driver.findElement(locator)
await this.driver.wait(until.elementIsVisible(element), 2000)
} catch (err) {
if (retries === 0) {
throw new Error(`Element ${locator.toString()} still not visible after maximum retries, Error message: ${err.message.toString()}`)
}
2022-12-19 23:23:25 +08:00
await this.driver.sleep(250)
return this.waitForVisible(driver, locator, retries - 1)
}
}
async waitForDisplayed (locator, retries = 3) {
2022-12-19 23:23:25 +08:00
await this.waitForLocated(locator, retries)
await this.waitForVisible(locator, retries)
return this.driver.findElement(locator)
}
async hasElement (locator) {
const count = await this.driver.findElements(locator).size()
throw new Error('there are ' + count + ' warnings')
return count > 0
}
async getText (locator, retries = 1) {
try {
const element = await this.driver.findElement(locator)
const text = element.getText()
return text
} catch (err) {
if (retries === 0) {
throw new Error(`Unable to get ${locator.toString()} text after maximum retries, error : ${err.message}`)
}
await this.driver.sleep(250)
return this.getText(locator, retries - 1)
}
}
async getValue (locator, retries = 1) {
try {
const element = await this.driver.findElement(locator)
const value = element.getAttribute('value')
return value
} catch (err) {
if (retries === 0) {
throw new Error(`Unable to get ${locator.toString()} text after maximum retries, error : ${err.message}`)
}
await this.driver.sleep(250)
return this.getValue(locator, retries - 1)
}
}
async click (locator, retries = 1) {
try {
const element = await this.driver.findElement(locator)
return element.click()
} catch (err) {
if (retries === 0) {
throw new Error(`Still not able to click ${locator.toString()} after maximum retries, Error message: ${err.message.toString()}`)
}
await this.driver.sleep(250)
return this.click(locator, retries - 1)
}
}
async submit (locator, retries = 1) {
try {
const element = await this.driver.findElement(locator)
return element.submit()
} catch (err) {
if (retries === 0) {
throw new Error(`Still not able to submit ${locator.toString()} after maximum retries, Error message: ${err.message.toString()}`)
}
await this.driver.sleep(250)
return this.submit(locator, retries - 1)
}
}
async sendKeys (locator, keys, retries = 1) {
try {
const element = await this.driver.findElement(locator)
await element.click()
await element.clear()
return element.sendKeys(keys)
} catch (err) {
console.log(err)
if (retries === 0) {
throw new Error(`Unable to send keys to ${locator.toString()} after maximum retries, error : ${err.message}`)
}
await this.driver.sleep(250)
return this.sendKeys(locator, keys, retries - 1)
}
}
async chooseFile (locator, file, retries = 1) {
try {
const element = await this.driver.findElement(locator)
var remote = require('selenium-webdriver/remote');
2022-12-19 23:23:25 +08:00
driver.setFileDetector(new remote.FileDetector);
return element.sendKeys(file)
} catch (err) {
console.log(err)
if (retries === 0) {
throw new Error(`Unable to send keys to ${locator.toString()} after maximum retries, error : ${err.message}`)
}
await this.driver.sleep(250)
return this.chooseFile(locator, file, retries - 1)
}
}
async acceptAlert (retries = 3) {
try {
await this.driver.wait(until.alertIsPresent());
await this.driver.sleep(250)
let alert = await this.driver.switchTo().alert();
await this.driver.sleep(250)
return alert.accept();
} catch (err) {
console.log(err)
if (retries === 0) {
throw new Error(`Unable to send keys to ${locator.toString()} after maximum retries, error : ${err.message}`)
}
await this.driver.sleep(250)
return this.alertAccept(retries - 1)
}
}
capture () {
this.driver.takeScreenshot().then(
function (image) {
require('fs').writeFileSync('/tmp/capture.png', image, 'base64')
}
)
}
}