123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557 |
- <?php
- // Copyright 2004-present Facebook. All Rights Reserved.
- //
- // Licensed under the Apache License, Version 2.0 (the "License");
- // you may not use this file except in compliance with the License.
- // You may obtain a copy of the License at
- //
- // http://www.apache.org/licenses/LICENSE-2.0
- //
- // Unless required by applicable law or agreed to in writing, software
- // distributed under the License is distributed on an "AS IS" BASIS,
- // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- // See the License for the specific language governing permissions and
- // limitations under the License.
- namespace Facebook\WebDriver;
- use Facebook\WebDriver\Exception\NoAlertOpenException;
- use Facebook\WebDriver\Exception\NoSuchElementException;
- use Facebook\WebDriver\Exception\NoSuchFrameException;
- use Facebook\WebDriver\Exception\StaleElementReferenceException;
- /**
- * Canned ExpectedConditions which are generally useful within webdriver tests.
- *
- * @see WebDriverWait
- */
- class WebDriverExpectedCondition
- {
- /**
- * A callable function to be executed by WebDriverWait. It should return
- * a truthy value, mostly boolean or a WebDriverElement, on success.
- * @var callable
- */
- private $apply;
- /**
- * @return callable A callable function to be executed by WebDriverWait
- */
- public function getApply()
- {
- return $this->apply;
- }
- protected function __construct(callable $apply)
- {
- $this->apply = $apply;
- }
- /**
- * An expectation for checking the title of a page.
- *
- * @param string $title The expected title, which must be an exact match.
- * @return WebDriverExpectedCondition<bool> Condition returns whether current page title equals given string.
- */
- public static function titleIs($title)
- {
- return new static(
- function (WebDriver $driver) use ($title) {
- return $title === $driver->getTitle();
- }
- );
- }
- /**
- * An expectation for checking substring of a page Title.
- *
- * @param string $title The expected substring of Title.
- * @return WebDriverExpectedCondition<bool> Condition returns whether current page title contains given string.
- */
- public static function titleContains($title)
- {
- return new static(
- function (WebDriver $driver) use ($title) {
- return strpos($driver->getTitle(), $title) !== false;
- }
- );
- }
- /**
- * An expectation for checking current page title matches the given regular expression.
- *
- * @param string $titleRegexp The regular expression to test against.
- * @return WebDriverExpectedCondition<bool> Condition returns whether current page title matches the regular
- * expression.
- */
- public static function titleMatches($titleRegexp)
- {
- return new static(
- function (WebDriver $driver) use ($titleRegexp) {
- return (bool) preg_match($titleRegexp, $driver->getTitle());
- }
- );
- }
- /**
- * An expectation for checking the URL of a page.
- *
- * @param string $url The expected URL, which must be an exact match.
- * @return WebDriverExpectedCondition<bool> Condition returns whether current URL equals given one.
- */
- public static function urlIs($url)
- {
- return new static(
- function (WebDriver $driver) use ($url) {
- return $url === $driver->getCurrentURL();
- }
- );
- }
- /**
- * An expectation for checking substring of the URL of a page.
- *
- * @param string $url The expected substring of the URL
- * @return WebDriverExpectedCondition<bool> Condition returns whether current URL contains given string.
- */
- public static function urlContains($url)
- {
- return new static(
- function (WebDriver $driver) use ($url) {
- return strpos($driver->getCurrentURL(), $url) !== false;
- }
- );
- }
- /**
- * An expectation for checking current page URL matches the given regular expression.
- *
- * @param string $urlRegexp The regular expression to test against.
- * @return WebDriverExpectedCondition<bool> Condition returns whether current URL matches the regular expression.
- */
- public static function urlMatches($urlRegexp)
- {
- return new static(
- function (WebDriver $driver) use ($urlRegexp) {
- return (bool) preg_match($urlRegexp, $driver->getCurrentURL());
- }
- );
- }
- /**
- * 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.
- *
- * @param WebDriverBy $by The locator used to find the element.
- * @return WebDriverExpectedCondition<WebDriverElement> Condition returns the element which is located.
- */
- public static function presenceOfElementLocated(WebDriverBy $by)
- {
- return new static(
- function (WebDriver $driver) use ($by) {
- return $driver->findElement($by);
- }
- );
- }
- /**
- * An expectation for checking that there is at least one element present on a web page.
- *
- * @param WebDriverBy $by The locator used to find the element.
- * @return WebDriverExpectedCondition<array> Condition returns an array of WebDriverElements once they are located.
- */
- public static function presenceOfAllElementsLocatedBy(WebDriverBy $by)
- {
- return new static(
- function (WebDriver $driver) use ($by) {
- $elements = $driver->findElements($by);
- return count($elements) > 0 ? $elements : null;
- }
- );
- }
- /**
- * 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.
- *
- * @param WebDriverBy $by The locator used to find the element.
- * @return WebDriverExpectedCondition<WebDriverElement> Condition returns the element which is located and visible.
- */
- public static function visibilityOfElementLocated(WebDriverBy $by)
- {
- return new static(
- function (WebDriver $driver) use ($by) {
- try {
- $element = $driver->findElement($by);
- return $element->isDisplayed() ? $element : null;
- } catch (StaleElementReferenceException $e) {
- return null;
- }
- }
- );
- }
- /**
- * An expectation for checking that an element, known to be present on the DOM of a page, is visible.
- * Visibility means that the element is not only displayed but also has a height and width that is greater than 0.
- *
- * @param WebDriverElement $element The element to be checked.
- * @return WebDriverExpectedCondition<WebDriverElement> Condition returns the same WebDriverElement once it is
- * visible.
- */
- public static function visibilityOf(WebDriverElement $element)
- {
- return new static(
- function () use ($element) {
- return $element->isDisplayed() ? $element : null;
- }
- );
- }
- /**
- * An expectation for checking if the given text is present in the specified element.
- * To check exact text match use elementTextIs() condition.
- *
- * @codeCoverageIgnore
- * @deprecated Use WebDriverExpectedCondition::elementTextContains() instead
- * @param WebDriverBy $by The locator used to find the element.
- * @param string $text The text to be presented in the element.
- * @return WebDriverExpectedCondition<bool> Condition returns whether the text is present in the element.
- */
- public static function textToBePresentInElement(WebDriverBy $by, $text)
- {
- return self::elementTextContains($by, $text);
- }
- /**
- * An expectation for checking if the given text is present in the specified element.
- * To check exact text match use elementTextIs() condition.
- *
- * @param WebDriverBy $by The locator used to find the element.
- * @param string $text The text to be presented in the element.
- * @return WebDriverExpectedCondition<bool> Condition returns whether the partial text is present in the element.
- */
- public static function elementTextContains(WebDriverBy $by, $text)
- {
- return new static(
- function (WebDriver $driver) use ($by, $text) {
- try {
- $element_text = $driver->findElement($by)->getText();
- return strpos($element_text, $text) !== false;
- } catch (StaleElementReferenceException $e) {
- return null;
- }
- }
- );
- }
- /**
- * An expectation for checking if the given text exactly equals the text in specified element.
- * To check only partial substring of the text use elementTextContains() condition.
- *
- * @param WebDriverBy $by The locator used to find the element.
- * @param string $text The expected text of the element.
- * @return WebDriverExpectedCondition<bool> Condition returns whether the element has text value equal to given one.
- */
- public static function elementTextIs(WebDriverBy $by, $text)
- {
- return new static(
- function (WebDriver $driver) use ($by, $text) {
- try {
- return $driver->findElement($by)->getText() == $text;
- } catch (StaleElementReferenceException $e) {
- return null;
- }
- }
- );
- }
- /**
- * An expectation for checking if the given regular expression matches the text in specified element.
- *
- * @param WebDriverBy $by The locator used to find the element.
- * @param string $regexp The regular expression to test against.
- * @return WebDriverExpectedCondition<bool> Condition returns whether the element has text value equal to given one.
- */
- public static function elementTextMatches(WebDriverBy $by, $regexp)
- {
- return new static(
- function (WebDriver $driver) use ($by, $regexp) {
- try {
- return (bool) preg_match($regexp, $driver->findElement($by)->getText());
- } catch (StaleElementReferenceException $e) {
- return null;
- }
- }
- );
- }
- /**
- * An expectation for checking if the given text is present in the specified elements value attribute.
- *
- * @param WebDriverBy $by The locator used to find the element.
- * @param string $text The text to be presented in the element value.
- * @return WebDriverExpectedCondition<bool> Condition returns whether the text is present in value attribute.
- */
- public static function textToBePresentInElementValue(WebDriverBy $by, $text)
- {
- return new static(
- function (WebDriver $driver) use ($by, $text) {
- try {
- $element_text = $driver->findElement($by)->getAttribute('value');
- return strpos($element_text, $text) !== false;
- } catch (StaleElementReferenceException $e) {
- return null;
- }
- }
- );
- }
- /**
- * Expectation for checking if iFrame exists. If iFrame exists switches driver's focus to the iFrame.
- *
- * @param string $frame_locator The locator used to find the iFrame
- * expected to be either the id or name value of the i/frame
- * @return WebDriverExpectedCondition<WebDriver|bool> Condition returns object focused on new frame when frame is
- * found, false otherwise.
- */
- public static function frameToBeAvailableAndSwitchToIt($frame_locator)
- {
- return new static(
- function (WebDriver $driver) use ($frame_locator) {
- try {
- return $driver->switchTo()->frame($frame_locator);
- } catch (NoSuchFrameException $e) {
- return false;
- }
- }
- );
- }
- /**
- * An expectation for checking that an element is either invisible or not present on the DOM.
- *
- * @param WebDriverBy $by The locator used to find the element.
- * @return WebDriverExpectedCondition<bool> Condition returns whether no visible element located.
- */
- public static function invisibilityOfElementLocated(WebDriverBy $by)
- {
- return new static(
- function (WebDriver $driver) use ($by) {
- try {
- return !$driver->findElement($by)->isDisplayed();
- } catch (NoSuchElementException $e) {
- return true;
- } catch (StaleElementReferenceException $e) {
- return true;
- }
- }
- );
- }
- /**
- * An expectation for checking that an element with text is either invisible or not present on the DOM.
- *
- * @param WebdriverBy $by The locator used to find the element.
- * @param string $text The text of the element.
- * @return WebDriverExpectedCondition<bool> Condition returns whether the text is found in the element located.
- */
- public static function invisibilityOfElementWithText(WebDriverBy $by, $text)
- {
- return new static(
- function (WebDriver $driver) use ($by, $text) {
- try {
- return !($driver->findElement($by)->getText() === $text);
- } catch (NoSuchElementException $e) {
- return true;
- } catch (StaleElementReferenceException $e) {
- return true;
- }
- }
- );
- }
- /**
- * An expectation for checking an element is visible and enabled such that you can click it.
- *
- * @param WebDriverBy $by The locator used to find the element
- * @return WebDriverExpectedCondition<WebDriverElement> Condition return the WebDriverElement once it is located,
- * visible and clickable.
- */
- public static function elementToBeClickable(WebDriverBy $by)
- {
- $visibility_of_element_located =
- self::visibilityOfElementLocated($by);
- return new static(
- function (WebDriver $driver) use ($visibility_of_element_located) {
- $element = call_user_func(
- $visibility_of_element_located->getApply(),
- $driver
- );
- try {
- if ($element !== null && $element->isEnabled()) {
- return $element;
- }
- return null;
- } catch (StaleElementReferenceException $e) {
- return null;
- }
- }
- );
- }
- /**
- * Wait until an element is no longer attached to the DOM.
- *
- * @param WebDriverElement $element The element to wait for.
- * @return WebDriverExpectedCondition<bool> Condition returns whether the element is still attached to the DOM.
- */
- public static function stalenessOf(WebDriverElement $element)
- {
- return new static(
- function () use ($element) {
- try {
- $element->isEnabled();
- return false;
- } catch (StaleElementReferenceException $e) {
- return true;
- }
- }
- );
- }
- /**
- * Wrapper for a condition, which allows for elements to update by redrawing.
- *
- * This works around the problem of conditions which have two parts: find an element and then check for some
- * condition on it. For these conditions it is possible that an element is located and then subsequently it is
- * redrawn on the client. When this happens a StaleElementReferenceException is thrown when the second part of
- * the condition is checked.
- *
- * @param WebDriverExpectedCondition $condition The condition wrapped.
- * @return WebDriverExpectedCondition<mixed> Condition returns the return value of the getApply() of the given
- * condition.
- */
- public static function refreshed(WebDriverExpectedCondition $condition)
- {
- return new static(
- function (WebDriver $driver) use ($condition) {
- try {
- return call_user_func($condition->getApply(), $driver);
- } catch (StaleElementReferenceException $e) {
- return null;
- }
- }
- );
- }
- /**
- * An expectation for checking if the given element is selected.
- *
- * @param mixed $element_or_by Either the element or the locator.
- * @return WebDriverExpectedCondition<bool> Condition returns whether the element is selected.
- */
- public static function elementToBeSelected($element_or_by)
- {
- return self::elementSelectionStateToBe(
- $element_or_by,
- true
- );
- }
- /**
- * An expectation for checking if the given element is selected.
- *
- * @param mixed $element_or_by Either the element or the locator.
- * @param bool $selected The required state.
- * @return WebDriverExpectedCondition<bool> Condition returns whether the element is selected.
- */
- public static function elementSelectionStateToBe($element_or_by, $selected)
- {
- if ($element_or_by instanceof WebDriverElement) {
- return new static(
- function () use ($element_or_by, $selected) {
- return $element_or_by->isSelected() === $selected;
- }
- );
- } else {
- if ($element_or_by instanceof WebDriverBy) {
- return new static(
- function (WebDriver $driver) use ($element_or_by, $selected) {
- try {
- $element = $driver->findElement($element_or_by);
- return $element->isSelected() === $selected;
- } catch (StaleElementReferenceException $e) {
- return null;
- }
- }
- );
- }
- }
- }
- /**
- * An expectation for whether an alert() box is present.
- *
- * @return WebDriverExpectedCondition<?WebDriverAlert> Condition returns WebDriverAlert if alert() is present,
- * null otherwise.
- */
- public static function alertIsPresent()
- {
- return new static(
- function (WebDriver $driver) {
- try {
- // Unlike the Java code, we get a WebDriverAlert object regardless
- // of whether there is an alert. Calling getText() will throw
- // an exception if it is not really there.
- $alert = $driver->switchTo()->alert();
- $alert->getText();
- return $alert;
- } catch (NoAlertOpenException $e) {
- return null;
- }
- }
- );
- }
- /**
- * An expectation checking the number of opened windows.
- *
- * @param int $expectedNumberOfWindows
- * @return WebDriverExpectedCondition
- */
- public static function numberOfWindowsToBe($expectedNumberOfWindows)
- {
- return new static(
- function (WebDriver $driver) use ($expectedNumberOfWindows) {
- return count($driver->getWindowHandles()) == $expectedNumberOfWindows;
- }
- );
- }
- /**
- * An expectation with the logical opposite condition of the given condition.
- *
- * @param WebDriverExpectedCondition $condition The condition to be negated.
- * @return mixed The negation of the result of the given condition.
- */
- public static function not(WebDriverExpectedCondition $condition)
- {
- return new static(
- function (WebDriver $driver) use ($condition) {
- $result = call_user_func($condition->getApply(), $driver);
- return !$result;
- }
- );
- }
- }
|