/** * 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 body() * * @return void */ public function testBody() { $data = ['property' => 'value']; $encoded = json_encode($data); $response = new Response([], $encoded); $result = $response->body('json_decode'); $this->assertEquals($data['property'], $result->property); $this->assertEquals($encoded, $response->body()); $this->assertEquals($encoded, $response->body); $this->assertTrue(isset($response->body)); }
/** * 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; }