You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

242 lines
4.8 KiB

<?php
/*
** Zabbix
** Copyright (C) 2001-2023 Zabbix SIA
**
** This program is free software; you can redistribute it and/or modify
** it under the terms of the GNU General Public License as published by
** the Free Software Foundation; either version 2 of the License, or
** (at your option) any later version.
**
** This program is distributed in the hope that it will be useful,
** but WITHOUT ANY WARRANTY; without even the implied warranty of
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
** GNU General Public License for more details.
**
** You should have received a copy of the GNU General Public License
** along with this program; if not, write to the Free Software
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
**/
use Facebook\WebDriver\WebDriverBy;
use Facebook\WebDriver\Remote\RemoteWebElement;
use Facebook\WebDriver\Exception\StaleElementReferenceException;
/**
* Base class for web page elements.
*/
abstract class CBaseElement extends RemoteWebElement {
/**
* Option that allows to disable auto reload of staled elements.
*
* @var boolead
*/
protected $reload_staled = true;
/**
* Method called when element is stalled.
* This method should be overridden to provide logic of reloading stalled elements.
*/
public abstract function reload();
/**
* Execute element action in a stale safe context.
*
* @param string $method method to be executed
* @param array $params method execution params
*
* @return mixed
*/
private function executeStaleSafe($method, $params = []) {
try {
return call_user_func_array([parent::class, $method], $params);
}
catch (StaleElementReferenceException $exception) {
if (!$this->reload_staled) {
throw $exception;
}
$this->reload();
}
return call_user_func_array([parent::class, $method], $params);
}
/**
* Check if element is in stalled state.
*
* @return boolean
*/
public function isStalled() {
try {
parent::isEnabled();
}
catch (StaleElementReferenceException $exception) {
return true;
}
catch (Exception $exception) {
// Code is not missing here.
}
return false;
}
/**
* Alias for sendKeys.
* @see RemoteWebElement::sendKeys
*
* @param string $text
*
* @return $this
*/
public function type($text) {
return $this->sendKeys($text);
}
/**
* Alias for isDisplayed.
* @see isDisplayed
*
* @param boolean $displayed if element should be visible
*
* @return boolean
*/
public function isVisible($displayed = true) {
return $this->isDisplayed($displayed);
}
/**
* @inheritdoc
*/
public function clear() {
return $this->executeStaleSafe(__FUNCTION__);
}
/**
* @inheritdoc
*/
public function click() {
return $this->executeStaleSafe(__FUNCTION__);
}
/**
* @inheritdoc
*/
public function getAttribute($attribute_name) {
return $this->executeStaleSafe(__FUNCTION__, [$attribute_name]);
}
/**
* @inheritdoc
*/
public function getCSSValue($css_property_name) {
return $this->executeStaleSafe(__FUNCTION__, [$css_property_name]);
}
/**
* @inheritdoc
*/
public function getLocation() {
return $this->executeStaleSafe(__FUNCTION__);
}
/**
* @inheritdoc
*/
public function getLocationOnScreenOnceScrolledIntoView() {
return $this->executeStaleSafe(__FUNCTION__);
}
/**
* @inheritdoc
*/
public function getCoordinates() {
return $this->executeStaleSafe(__FUNCTION__);
}
/**
* @inheritdoc
*/
public function getSize() {
return $this->executeStaleSafe(__FUNCTION__);
}
/**
* @inheritdoc
*/
public function getTagName() {
return $this->executeStaleSafe(__FUNCTION__);
}
/**
* @inheritdoc
*/
public function getText() {
return $this->executeStaleSafe(__FUNCTION__);
}
/**
* @inheritdoc
*/
public function sendKeys($value) {
return $this->executeStaleSafe(__FUNCTION__, [$value]);
}
/**
* @inheritdoc
*/
public function submit() {
return $this->executeStaleSafe(__FUNCTION__);
}
/**
* @inheritdoc
*/
public function findElement(WebDriverBy $by) {
return $this->executeStaleSafe(__FUNCTION__, [$by]);
}
/**
* @inheritdoc
*/
public function findElements(WebDriverBy $by) {
return $this->executeStaleSafe(__FUNCTION__, [$by]);
}
/**
* @inheritdoc
*/
public function isDisplayed($displayed = true) {
try {
return (parent::isDisplayed() === $displayed);
}
catch (StaleElementReferenceException $exception) {
return ($displayed === false);
}
}
/**
* @inheritdoc
*/
public function isEnabled($enabled = true) {
return (parent::isEnabled() === $enabled);
}
/**
* @inheritdoc
*/
public function isSelected($selected = true) {
return (parent::isSelected() === $selected);
}
/**
* Check if element is valid (all non-null elements are considered valid).
*
* @return boolean
*/
public function isValid() {
return true;
}
}