X-Git-Url: http://www.aleph1.co.uk/gitweb/?a=blobdiff_plain;ds=sidebyside;f=vendor%2Finstaclick%2Fphp-webdriver%2Flib%2FWebDriver%2FAbstractWebDriver.php;fp=vendor%2Finstaclick%2Fphp-webdriver%2Flib%2FWebDriver%2FAbstractWebDriver.php;h=0000000000000000000000000000000000000000;hb=af6d1fb995500ae68849458ee10d66abbdcfb252;hp=0d69023cf41f05da84a6439a447ec698154b57fd;hpb=680c79a86e3ed402f263faeac92e89fb6d9edcc0;p=yaffs-website diff --git a/vendor/instaclick/php-webdriver/lib/WebDriver/AbstractWebDriver.php b/vendor/instaclick/php-webdriver/lib/WebDriver/AbstractWebDriver.php deleted file mode 100644 index 0d69023cf..000000000 --- a/vendor/instaclick/php-webdriver/lib/WebDriver/AbstractWebDriver.php +++ /dev/null @@ -1,248 +0,0 @@ - - * @author Anthon Pang - * @author Fabrizio Branca - * @author Tsz Ming Wong - */ - -namespace WebDriver; - -use WebDriver\Exception as WebDriverException; - -/** - * Abstract WebDriver\AbstractWebDriver class - * - * @package WebDriver - */ -abstract class AbstractWebDriver -{ - /** - * URL - * - * @var string - */ - protected $url; - - /** - * Return array of supported method names and corresponding HTTP request methods - * - * @return array - */ - abstract protected function methods(); - - /** - * Return array of obsolete method names and corresponding HTTP request methods - * - * @return array - */ - protected function obsoleteMethods() - { - return array(); - } - - /** - * Constructor - * - * @param string $url URL to Selenium server - */ - public function __construct($url = 'http://localhost:4444/wd/hub') - { - $this->url = $url; - } - - /** - * Magic method which returns URL to Selenium server - * - * @return string - */ - public function __toString() - { - return $this->url; - } - - /** - * Returns URL to Selenium server - * - * @return string - */ - public function getURL() - { - return $this->url; - } - - /** - * Curl request to webdriver server. - * - * @param string $requestMethod HTTP request method, e.g., 'GET', 'POST', or 'DELETE' - * @param string $command If not defined in methods() this function will throw. - * @param array $parameters If an array(), they will be posted as JSON parameters - * If a number or string, "/$params" is appended to url - * @param array $extraOptions key=>value pairs of curl options to pass to curl_setopt() - * - * @return array array('value' => ..., 'info' => ...) - * - * @throws \WebDriver\Exception if error - */ - protected function curl($requestMethod, $command, $parameters = null, $extraOptions = array()) - { - if ($parameters && is_array($parameters) && $requestMethod !== 'POST') { - throw WebDriverException::factory( - WebDriverException::NO_PARAMETERS_EXPECTED, - sprintf( - 'The http request method called for %s is %s but it has to be POST if you want to pass the JSON parameters %s', - $command, - $requestMethod, - json_encode($parameters) - ) - ); - } - - $url = sprintf('%s%s', $this->url, $command); - - if ($parameters && (is_int($parameters) || is_string($parameters))) { - $url .= '/' . $parameters; - } - - list($rawResult, $info) = ServiceFactory::getInstance()->getService('service.curl')->execute($requestMethod, $url, $parameters, $extraOptions); - - $httpCode = $info['http_code']; - - // According to https://w3c.github.io/webdriver/webdriver-spec.html all 4xx responses are to be considered - // an error and return plaintext, while 5xx responses are json encoded - if ($httpCode >= 400 && $httpCode <= 499) { - throw WebDriverException::factory( - WebDriverException::CURL_EXEC, - 'Webdriver http error: ' . $httpCode . ', payload :' . substr($rawResult, 0, 1000) - ); - } - - $result = json_decode($rawResult, true); - - if (!empty($rawResult) && $result === null && json_last_error() != JSON_ERROR_NONE) { - throw WebDriverException::factory( - WebDriverException::CURL_EXEC, - 'Payload received from webdriver is not valid json: ' . substr($rawResult, 0, 1000) - ); - } - - if (is_array($result) && !array_key_exists('status', $result)) { - throw WebDriverException::factory( - WebDriverException::CURL_EXEC, - 'Payload received from webdriver is valid but unexpected json: ' . substr($rawResult, 0, 1000) - ); - } - - $value = (is_array($result) && array_key_exists('value', $result)) ? $result['value'] : null; - $message = (is_array($value) && array_key_exists('message', $value)) ? $value['message'] : null; - - // if not success, throw exception - if ((int) $result['status'] !== 0) { - throw WebDriverException::factory($result['status'], $message); - } - - $sessionId = isset($result['sessionId']) - ? $result['sessionId'] - : (isset($value['webdriver.remote.sessionid']) - ? $value['webdriver.remote.sessionid'] - : null - ); - - return array( - 'value' => $value, - 'info' => $info, - 'sessionId' => $sessionId, - 'sessionUrl' => $sessionId ? $this->url . '/session/' . $sessionId : $info['url'], - ); - } - - /** - * Magic method that maps calls to class methods to execute WebDriver commands - * - * @param string $name Method name - * @param array $arguments Arguments - * - * @return mixed - * - * @throws \WebDriver\Exception if invalid WebDriver command - */ - public function __call($name, $arguments) - { - if (count($arguments) > 1) { - throw WebDriverException::factory( - WebDriverException::JSON_PARAMETERS_EXPECTED, - 'Commands should have at most only one parameter, which should be the JSON Parameter object' - ); - } - - if (preg_match('/^(get|post|delete)/', $name, $matches)) { - $requestMethod = strtoupper($matches[0]); - $webdriverCommand = strtolower(substr($name, strlen($requestMethod))); - } else { - $webdriverCommand = $name; - $requestMethod = $this->getRequestMethod($webdriverCommand); - } - - $methods = $this->methods(); - - if (!in_array($requestMethod, (array) $methods[$webdriverCommand])) { - throw WebDriverException::factory( - WebDriverException::INVALID_REQUEST, - sprintf( - '%s is not an available http request method for the command %s.', - $requestMethod, - $webdriverCommand - ) - ); - } - - $result = $this->curl( - $requestMethod, - '/' . $webdriverCommand, - array_shift($arguments) - ); - - return $result['value']; - } - - /** - * Get default HTTP request method for a given WebDriver command - * - * @param string $webdriverCommand - * - * @return string - * - * @throws \WebDriver\Exception if invalid WebDriver command - */ - private function getRequestMethod($webdriverCommand) - { - if (!array_key_exists($webdriverCommand, $this->methods())) { - throw WebDriverException::factory( - array_key_exists($webdriverCommand, $this->obsoleteMethods()) - ? WebDriverException::OBSOLETE_COMMAND : WebDriverException::UNKNOWN_COMMAND, - sprintf('%s is not a valid WebDriver command.', $webdriverCommand) - ); - } - - $methods = $this->methods(); - $requestMethods = (array) $methods[$webdriverCommand]; - - return array_shift($requestMethods); - } -}