Évitez les exceptions non gérées avec Guzzle
Lors du test des API, il est crucial de gérer les erreurs HTTP pour empêcher les exceptions d'interrompre l'exécution. Guzzle fournit des moyens d'intercepter ces exceptions, mais parfois votre code peut encore rencontrer des exceptions non gérées.
Le problème auquel vous êtes confronté peut être résolu en désactivant les exceptions pour Guzzle. Cela vous permet de gérer les codes d'état manuellement sans interférence d'exceptions. Voici comment y parvenir :
Guzzle 3
$client = new \Guzzle\Http\Client($httpBase, array( 'request.options' => array( 'exceptions' => false, ) ));
Guzzle 5.3
$client = new \GuzzleHttp\Client(['defaults' => [ 'exceptions' => false ]] );
Guzzle 6
$client = new \GuzzleHttp\Client(['http_errors' => false]);
Une fois les exceptions désactivées, vous pouvez récupérer le code d'état HTTP à partir de la réponse :
$request = $client->get($uri); $response = $request->send(); $statuscode = $response->getStatusCode();
Vous pouvez alors gérer différents codes d'état en conséquence :
if ($statuscode > 300) { // Do some error handling }
Ou gérez des codes attendus spécifiques :
if (200 === $statuscode) { // Do something } elseif (304 === $statuscode) { // Nothing to do } elseif (404 === $statuscode) { // Clean up DB or something like this } else { throw new MyException("Invalid response from api..."); }
En désactivant les exceptions et en gérant manuellement les codes d'état, vous pouvez avoir un contrôle total sur la gestion des erreurs et éviter les interruptions dans l'exécution de vos tests.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!