import { ProtractorBrowser } from './browser'; import { ElementFinder } from './element'; /** * Represents a library of canned expected conditions that are useful for * protractor, especially when dealing with non-angular apps. * * Each condition returns a function that evaluates to a promise. You may mix * multiple conditions using `and`, `or`, and/or `not`. You may also * mix these conditions with any other conditions that you write. * * See ExpectedCondition Class in Selenium WebDriver codebase. * http://seleniumhq.github.io/selenium/docs/api/java/org/openqa/selenium/support/ui/ExpectedConditions.html * * * @example * var EC = protractor.ExpectedConditions; * var button = $('#xyz'); * var isClickable = EC.elementToBeClickable(button); * * browser.get(URL); * browser.wait(isClickable, 5000); //wait for an element to become clickable * button.click(); * * // You can define your own expected condition, which is a function that * // takes no parameter and evaluates to a promise of a boolean. * var urlChanged = function() { * return browser.getCurrentUrl().then(function(url) { * return url === 'http://www.angularjs.org'; * }); * }; * * // You can customize the conditions with EC.and, EC.or, and EC.not. * // Here's a condition to wait for url to change, $('abc') element to contain * // text 'bar', and button becomes clickable. * var condition = EC.and(urlChanged, EC.textToBePresentInElement($('abc'), * 'bar'), isClickable); * browser.get(URL); * browser.wait(condition, 5000); //wait for condition to be true. * button.click(); * * @alias ExpectedConditions * @constructor */ export declare class ProtractorExpectedConditions { browser: ProtractorBrowser; constructor(browser: ProtractorBrowser); /** * Negates the result of a promise. * * @example * var EC = protractor.ExpectedConditions; * var titleIsNotFoo = EC.not(EC.titleIs('Foo')); * // Waits for title to become something besides 'foo'. * browser.wait(titleIsNotFoo, 5000); * * @alias ExpectedConditions.not * @param {!function} expectedCondition * * @returns {!function} An expected condition that returns the negated value. */ not(expectedCondition: Function): Function; /** * Helper function that is equivalent to the logical_and if defaultRet==true, * or logical_or if defaultRet==false * * @private * @param {boolean} defaultRet * @param {Array.} fns An array of expected conditions to chain. * * @returns {!function} An expected condition that returns a promise which * evaluates to the result of the logical chain. */ logicalChain_(defaultRet: boolean, fns: Array): Function; /** * Chain a number of expected conditions using logical_and, short circuiting * at the first expected condition that evaluates to false. * * @example * var EC = protractor.ExpectedConditions; * var titleContainsFoo = EC.titleContains('Foo'); * var titleIsNotFooBar = EC.not(EC.titleIs('FooBar')); * // Waits for title to contain 'Foo', but is not 'FooBar' * browser.wait(EC.and(titleContainsFoo, titleIsNotFooBar), 5000); * * @alias ExpectedConditions.and * @param {Array.} fns An array of expected conditions to 'and' * together. * * @returns {!function} An expected condition that returns a promise which * evaluates to the result of the logical and. */ and(...args: Function[]): Function; /** * Chain a number of expected conditions using logical_or, short circuiting * at the first expected condition that evaluates to true. * * @alias ExpectedConditions.or * @example * var EC = protractor.ExpectedConditions; * var titleContainsFoo = EC.titleContains('Foo'); * var titleContainsBar = EC.titleContains('Bar'); * // Waits for title to contain either 'Foo' or 'Bar' * browser.wait(EC.or(titleContainsFoo, titleContainsBar), 5000); * * @param {Array.} fns An array of expected conditions to 'or' * together. * * @returns {!function} An expected condition that returns a promise which * evaluates to the result of the logical or. */ or(...args: Function[]): Function; /** * Expect an alert to be present. * * @example * var EC = protractor.ExpectedConditions; * // Waits for an alert pops up. * browser.wait(EC.alertIsPresent(), 5000); * * @alias ExpectedConditions.alertIsPresent * @returns {!function} An expected condition that returns a promise * representing whether an alert is present. */ alertIsPresent(): Function; /** * An Expectation for checking an element is visible and enabled such that you * can click it. * * @example * var EC = protractor.ExpectedConditions; * // Waits for the element with id 'abc' to be clickable. * browser.wait(EC.elementToBeClickable($('#abc')), 5000); * * @alias ExpectedConditions.elementToBeClickable * @param {!ElementFinder} elementFinder The element to check * * @returns {!function} An expected condition that returns a promise * representing whether the element is clickable. */ elementToBeClickable(elementFinder: ElementFinder): Function; /** * An expectation for checking if the given text is present in the * element. Returns false if the elementFinder does not find an element. * * @example * var EC = protractor.ExpectedConditions; * // Waits for the element with id 'abc' to contain the text 'foo'. * browser.wait(EC.textToBePresentInElement($('#abc'), 'foo'), 5000); * * @alias ExpectedConditions.textToBePresentInElement * @param {!ElementFinder} elementFinder The element to check * @param {!string} text The text to verify against * * @returns {!function} An expected condition that returns a promise * representing whether the text is present in the element. */ textToBePresentInElement(elementFinder: ElementFinder, text: string): Function; /** * An expectation for checking if the given text is present in the element’s * value. Returns false if the elementFinder does not find an element. * * @example * var EC = protractor.ExpectedConditions; * // Waits for the element with id 'myInput' to contain the input 'foo'. * browser.wait(EC.textToBePresentInElementValue($('#myInput'), 'foo'), 5000); * * @alias ExpectedConditions.textToBePresentInElementValue * @param {!ElementFinder} elementFinder The element to check * @param {!string} text The text to verify against * * @returns {!function} An expected condition that returns a promise * representing whether the text is present in the element's value. */ textToBePresentInElementValue(elementFinder: ElementFinder, text: string): Function; /** * An expectation for checking that the title contains a case-sensitive * substring. * * @example * var EC = protractor.ExpectedConditions; * // Waits for the title to contain 'foo'. * browser.wait(EC.titleContains('foo'), 5000); * * @alias ExpectedConditions.titleContains * @param {!string} title The fragment of title expected * * @returns {!function} An expected condition that returns a promise * representing whether the title contains the string. */ titleContains(title: string): Function; /** * An expectation for checking the title of a page. * * @example * var EC = protractor.ExpectedConditions; * // Waits for the title to be 'foo'. * browser.wait(EC.titleIs('foo'), 5000); * * @alias ExpectedConditions.titleIs * @param {!string} title The expected title, which must be an exact match. * * @returns {!function} An expected condition that returns a promise * representing whether the title equals the string. */ titleIs(title: string): Function; /** * An expectation for checking that the URL contains a case-sensitive * substring. * * @example * var EC = protractor.ExpectedConditions; * // Waits for the URL to contain 'foo'. * browser.wait(EC.urlContains('foo'), 5000); * * @alias ExpectedConditions.urlContains * @param {!string} url The fragment of URL expected * * @returns {!function} An expected condition that returns a promise * representing whether the URL contains the string. */ urlContains(url: string): Function; /** * An expectation for checking the URL of a page. * * @example * var EC = protractor.ExpectedConditions; * // Waits for the URL to be 'foo'. * browser.wait(EC.urlIs('foo'), 5000); * * @alias ExpectedConditions.urlIs * @param {!string} url The expected URL, which must be an exact match. * * @returns {!function} An expected condition that returns a promise * representing whether the url equals the string. */ urlIs(url: string): Function; /** * An expectation for checking that an element is present on the DOM * of a page. This does not necessarily mean that the element is visible. * This is the opposite of 'stalenessOf'. * * @example * var EC = protractor.ExpectedConditions; * // Waits for the element with id 'abc' to be present on the dom. * browser.wait(EC.presenceOf($('#abc')), 5000); * * @alias ExpectedConditions.presenceOf * @param {!ElementFinder} elementFinder The element to check * * @returns {!function} An expected condition that returns a promise * representing whether the element is present. */ presenceOf(elementFinder: ElementFinder): Function; /** * An expectation for checking that an element is not attached to the DOM * of a page. This is the opposite of 'presenceOf'. * * @example * var EC = protractor.ExpectedConditions; * // Waits for the element with id 'abc' to be no longer present on the dom. * browser.wait(EC.stalenessOf($('#abc')), 5000); * * @alias ExpectedConditions.stalenessOf * @param {!ElementFinder} elementFinder The element to check * * @returns {!function} An expected condition that returns a promise * representing whether the element is stale. */ stalenessOf(elementFinder: ElementFinder): Function; /** * An expectation for checking that an element is present on the DOM of a * page and visible. Visibility means that the element is not only displayed * but also has a height and width that is greater than 0. This is the * opposite * of 'invisibilityOf'. * * @example * var EC = protractor.ExpectedConditions; * // Waits for the element with id 'abc' to be visible on the dom. * browser.wait(EC.visibilityOf($('#abc')), 5000); * * @alias ExpectedConditions.visibilityOf * @param {!ElementFinder} elementFinder The element to check * * @returns {!function} An expected condition that returns a promise * representing whether the element is visible. */ visibilityOf(elementFinder: ElementFinder): Function; /** * An expectation for checking that an element is either invisible or not * present on the DOM. This is the opposite of 'visibilityOf'. * * @example * var EC = protractor.ExpectedConditions; * // Waits for the element with id 'abc' to be no longer visible on the dom. * browser.wait(EC.invisibilityOf($('#abc')), 5000); * * @alias ExpectedConditions.invisibilityOf * @param {!ElementFinder} elementFinder The element to check * * @returns {!function} An expected condition that returns a promise * representing whether the element is invisible. */ invisibilityOf(elementFinder: ElementFinder): Function; /** * An expectation for checking the selection is selected. * * @example * var EC = protractor.ExpectedConditions; * // Waits for the element with id 'myCheckbox' to be selected. * browser.wait(EC.elementToBeSelected($('#myCheckbox')), 5000); * * @alias ExpectedConditions.elementToBeSelected * @param {!ElementFinder} elementFinder The element to check * * @returns {!function} An expected condition that returns a promise * representing whether the element is selected. */ elementToBeSelected(elementFinder: ElementFinder): Function; }