/** * Internal logged wrapper for HTTP GET request * * @param string $url URL for GET request * * @return type */ protected function _get($url) { $start = microtime(true); try { $result = $this->client()->get($url); } catch (Exception $e) { $result = new Response(['HTTP/1.1 ' . $e->getCode()], $e->getMessage()); } $timeTook = microtime(true) - $start; if (!$result->isOk()) { $this->_httpErrors[] = $result->statusCode() . ' - ' . $result->body(); } if ($this->_connection->logQueries() && $this->_connection->logger()) { $log = new LoggedQuery(); $log->query = $url; $log->took = round($timeTook * 1000); if ($result->isOk()) { $log->numRows = strlen($result->body()); } else { $log->error = new Exception('HTTP Error ' . $result->statusCode() . "\n" . $result->body()); } $this->_connection->logger()->log($log); } return $result; }
/** * Test statusCode() * * @return void */ public function testStatusCode() { $headers = ['HTTP/1.0 404 Not Found', 'Content-Type: text/html']; $response = new Response($headers, ''); $this->assertEquals(404, $response->statusCode()); $this->assertEquals(404, $response->code); $this->assertTrue(isset($response->code)); }
/** * Verifica si la respuesta del servidor tenía errores * @param \Cake\Network\Http\Response $response * @return bool */ public function responseHasError($response) { return $response->statusCode() != 200 || $response->body() == null || strpos(strtolower($response->body()), 'error') !== false; }