@christian-bromann/webdriverio
Version:
A nodejs bindings implementation for selenium 2.0/webdriver
81 lines (72 loc) • 2.43 kB
JavaScript
/**
*
* Wait for an element (selected by css selector) for the provided amount of
* milliseconds to be (in)visible. If multiple elements get queryied by given
* selector, it returns true (or false if reverse flag is set) if at least one
* element is visible.
*
* <example>
:index.html
<div id="elem" style="visibility: hidden;">Hello World!</div>
<script type="text/javascript">
setTimeout(function () {
document.getElementById('elem').style.visibility = 'visible';
}, 2000);
</script>
:waitForTextExample.js
it('should detect when element has text', function () {
elem = browser.element('#elem');
elem.waitForVisible(3000)
});
* </example>
*
* @alias browser.waitForVisible
* @param {String} selector element to wait for
* @param {Number=} ms time in ms (default: 500)
* @param {Boolean=} reverse if true it waits for the opposite (default: false)
* @uses util/waitUntil, property/isVisible
* @type utility
*
*/
import { WaitUntilTimeoutError, isTimeoutError } from '../utils/ErrorHandler'
let waitForVisible = function (selector, ms, reverse) {
/**
* we can't use default values for function parameter here because this would
* break the ability to chain the command with an element if reverse is used, like
*
* ```js
* var elem = browser.element('#elem');
* elem.waitForXXX(10000, true);
* ```
*/
reverse = typeof reverse === 'boolean' ? reverse : false
/*!
* ensure that ms is set properly
*/
if (typeof ms !== 'number') {
ms = this.options.waitforTimeout
}
return this.waitUntil(() => {
return this.isVisible(selector).then((isVisible) => {
if (!Array.isArray(isVisible)) {
return isVisible !== reverse
}
let result = reverse
for (let val of isVisible) {
if (!reverse) {
result = result || val
} else {
result = result && val
}
}
return result !== reverse
})
}, ms).catch((e) => {
if (isTimeoutError(e)) {
let isReversed = reverse ? '' : 'not'
throw new WaitUntilTimeoutError(`element (${selector}) still ${isReversed} visible after ${ms}ms`)
}
throw e
})
}
export default waitForVisible