Laravel fournit une syntaxe de simulation de réponse HTTP concise, simplifiant les tests d'interaction HTTP. Cette approche réduit considérablement la redondance du code tout en rendant votre simulation de test plus intuitive.
L'implémentation de base fournit une variété de raccourcis de type de réponse:
Utiliser illuminate \ support \ faades \ http; Http :: faux ([[ 'google.com' => 'Hello World', 'github.com' => ['foo' => 'bar'], 'forge.laravel.com' => 204, ]));
Cette syntaxe fonctionne bien dans un scénario de test complet:
Classe APIEntegrationtest étend le testcase { fonction publique test_service_communication () { Http :: faux ([[ // Réponse de chaîne 'api.notifications.com/*' => 'message envoyé', // Réponse du tableau (converti en JSON) 'api.products.com/*' => [ 'produits' => [ ['id' => 1, 'name' => 'ordinateur portable'], ['id' => 2, 'name' => 'mobile'] ]] ], // Réponse du code d'état 'api.status.com/check' => 200, 'api.deprecated.com/*' => 410, // différents types de réponse de points de terminaison associés 'api.orders.com/active' => ['status' => 'traitement'], 'api.orders.com/error' => 400, 'api.orders.com/mesage' => 'Le système n'est pas disponible' ])); // tester avec des assertions $ réponse = http :: get ('api.notifications.com/send'); $ this-> assertequals ('message envoyé', $ réponse-> body ()); $ Products = http :: get ('api.products.com/list'); $ this-> ASSERTCOUNT (2, $ Products ['Products']); $ status = http :: get ('api.status.com/check'); $ this-> assertTrue ($ status-> réussi ()); } }
Cette syntaxe concise améliore considérablement la maintenabilité des tests en réduisant la charge cognitive lors de la lecture des tests, vous permettant de vous concentrer sur la logique commerciale plutôt que sur les simulations HTTP.
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!