import { By, ByHash, promise as wdpromise, WebDriver, WebElement } from 'selenium-webdriver'; export declare class WebdriverBy { className: (className: string) => By; css: (css: string) => By; id: (id: string) => By; linkText: (linkText: string) => By; js: (js: string | Function, ...var_args: any[]) => By; name: (name: string) => By; partialLinkText: (partialText: string) => By; tagName: (tagName: string) => By; xpath: (xpath: string) => By; } export declare type WebDriverLocator = By | ByHash | Function; export interface ProtractorLocator { findElementsOverride: (driver: WebDriver, using: WebElement, rootSelector: string) => wdpromise.Promise; row?: (index: number) => Locator; column?: (index: string) => Locator; toString?: () => string; } export declare type Locator = ProtractorLocator | WebDriverLocator; export declare function isProtractorLocator(x: Locator): x is ProtractorLocator; /** * The Protractor Locators. These provide ways of finding elements in * Angular applications by binding, model, etc. * * @alias by * @extends {webdriver.By} */ export declare class ProtractorBy extends WebdriverBy { [key: string]: any; /** * Add a locator to this instance of ProtractorBy. This locator can then be * used with element(by.locatorName(args)). * * @view * * * @example * // Add the custom locator. * by.addLocator('buttonTextSimple', * function(buttonText, opt_parentElement, opt_rootSelector) { * // This function will be serialized as a string and will execute in the * // browser. The first argument is the text for the button. The second * // argument is the parent element, if any. * var using = opt_parentElement || document, * buttons = using.querySelectorAll('button'); * * // Return an array of buttons with the text. * return Array.prototype.filter.call(buttons, function(button) { * return button.textContent === buttonText; * }); * }); * * // Use the custom locator. * element(by.buttonTextSimple('Go!')).click(); * * @alias by.addLocator(locatorName, functionOrScript) * @param {string} name The name of the new locator. * @param {Function|string} script A script to be run in the context of * the browser. This script will be passed an array of arguments * that contains any args passed into the locator followed by the * element scoping the search and the css selector for the root angular * element. It should return an array of elements. */ addLocator(name: string, script: Function | string): void; /** * Find an element by text binding. Does a partial match, so any elements * bound to variables containing the input string will be returned. * * Note: For AngularJS version 1.2, the interpolation brackets, (usually * {{}}), are optionally allowed in the binding description string. For * Angular version 1.3+, they are not allowed, and no elements will be found * if they are used. * * @view * {{person.name}} * * * @example * var span1 = element(by.binding('person.name')); * expect(span1.getText()).toBe('Foo'); * * var span2 = element(by.binding('person.email')); * expect(span2.getText()).toBe('foo@bar.com'); * * // You can also use a substring for a partial match * var span1alt = element(by.binding('name')); * expect(span1alt.getText()).toBe('Foo'); * * // This works for sites using Angular 1.2 but NOT 1.3 * var deprecatedSyntax = element(by.binding('{{person.name}}')); * * @param {string} bindingDescriptor * @returns {ProtractorLocator} location strategy */ binding(bindingDescriptor: string): ProtractorLocator; /** * Find an element by exact binding. * * @view * {{ person.name }} * * {{person_phone|uppercase}} * * @example * expect(element(by.exactBinding('person.name')).isPresent()).toBe(true); * expect(element(by.exactBinding('person-email')).isPresent()).toBe(true); * expect(element(by.exactBinding('person')).isPresent()).toBe(false); * expect(element(by.exactBinding('person_phone')).isPresent()).toBe(true); * expect(element(by.exactBinding('person_phone|uppercase')).isPresent()).toBe(true); * expect(element(by.exactBinding('phone')).isPresent()).toBe(false); * * @param {string} bindingDescriptor * @returns {ProtractorLocator} location strategy */ exactBinding(bindingDescriptor: string): ProtractorLocator; /** * Find an element by ng-model expression. * * @alias by.model(modelName) * @view * * * @example * var input = element(by.model('person.name')); * input.sendKeys('123'); * expect(input.getAttribute('value')).toBe('Foo123'); * * @param {string} model ng-model expression. * @returns {ProtractorLocator} location strategy */ model(model: string): ProtractorLocator; /** * Find a button by text. * * @view * * * @example * element(by.buttonText('Save')); * * @param {string} searchText * @returns {ProtractorLocator} location strategy */ buttonText(searchText: string): ProtractorLocator; /** * Find a button by partial text. * * @view * * * @example * element(by.partialButtonText('Save')); * * @param {string} searchText * @returns {ProtractorLocator} location strategy */ partialButtonText(searchText: string): ProtractorLocator; private byRepeaterInner(exact, repeatDescriptor); /** * Find elements inside an ng-repeat. * * @view *
* {{cat.name}} * {{cat.age}} *
* *
* {{$index}} *
*
*

{{book.name}}

*

{{book.blurb}}

*
* * @example * // Returns the DIV for the second cat. * var secondCat = element(by.repeater('cat in pets').row(1)); * * // Returns the SPAN for the first cat's name. * var firstCatName = element(by.repeater('cat in pets'). * row(0).column('cat.name')); * * // Returns a promise that resolves to an array of WebElements from a column * var ages = element.all( * by.repeater('cat in pets').column('cat.age')); * * // Returns a promise that resolves to an array of WebElements containing * // all top level elements repeated by the repeater. For 2 pets rows * // resolves to an array of 2 elements. * var rows = element.all(by.repeater('cat in pets')); * * // Returns a promise that resolves to an array of WebElements containing * // all the elements with a binding to the book's name. * var divs = element.all(by.repeater('book in library').column('book.name')); * * // Returns a promise that resolves to an array of WebElements containing * // the DIVs for the second book. * var bookInfo = element.all(by.repeater('book in library').row(1)); * * // Returns the H4 for the first book's name. * var firstBookName = element(by.repeater('book in library'). * row(0).column('book.name')); * * // Returns a promise that resolves to an array of WebElements containing * // all top level elements repeated by the repeater. For 2 books divs * // resolves to an array of 4 elements. * var divs = element.all(by.repeater('book in library')); * * @param {string} repeatDescriptor * @returns {ProtractorLocator} location strategy */ repeater(repeatDescriptor: string): ProtractorLocator; /** * Find an element by exact repeater. * * @view *
  • *
  • * * @example * expect(element(by.exactRepeater('person in * peopleWithRedHair')).isPresent()) * .toBe(true); * expect(element(by.exactRepeater('person in * people')).isPresent()).toBe(false); * expect(element(by.exactRepeater('car in cars')).isPresent()).toBe(true); * * @param {string} repeatDescriptor * @returns {ProtractorLocator} location strategy */ exactRepeater(repeatDescriptor: string): ProtractorLocator; /** * Find elements by CSS which contain a certain string. * * @view * * * @example * // Returns the li for the dog, but not cat. * var dog = element(by.cssContainingText('.pet', 'Dog')); * * @param {string} cssSelector css selector * @param {string|RegExp} searchString text search * @returns {ProtractorLocator} location strategy */ cssContainingText(cssSelector: string, searchText: string | RegExp): ProtractorLocator; /** * Find an element by ng-options expression. * * @alias by.options(optionsDescriptor) * @view * * * @example * var allOptions = element.all(by.options('c for c in colors')); * expect(allOptions.count()).toEqual(2); * var firstOption = allOptions.first(); * expect(firstOption.getText()).toEqual('red'); * * @param {string} optionsDescriptor ng-options expression. * @returns {ProtractorLocator} location strategy */ options(optionsDescriptor: string): ProtractorLocator; /** * Find an element by css selector within the Shadow DOM. * * @alias by.deepCss(selector) * @view *
    * * <"shadow tree"> * * <"shadow tree"> * * * *
    * @example * var spans = element.all(by.deepCss('span')); * expect(spans.count()).toEqual(3); * * @param {string} selector a css selector within the Shadow DOM. * @returns {Locator} location strategy */ deepCss(selector: string): Locator; }