Ce message explore la construction d'un client SparkPost utilisant PHP, PHPUNIT et MACKERY, mettant l'accent sur le développement (TDD) axé sur les tests. Il vous guide à travers la création d'un client qui interagit avec l'API SparkPost pour envoyer des e-mails.
Concepts clés:
Configuration:
composer require guzzlehttp/guzzle phpunit/phpunit mockery/mockery
phpunit.xml
): (Remarque: La configuration XML fournie dans l'entrée est incomplète et mal formatée. Une version corrigée est nécessaire pour une exécution précise). Un exemple minimal: <?xml version="1.0" encoding="UTF-8"?> <phpunit bootstrap="vendor/autoload.php"> <testsuites> <testsuite name="SparkPost API Client Tests"> <directory suffix="Test.php">./tests</directory> </testsuite> </testsuites> </phpunit>
config.php
) pour stocker votre clé API SparkPost (n'oubliez pas d'ajouter ceci à .gitignore
): <?php return [ "key" => "[your SparkPost API key here]", ];
Conception et test d'interface:
Le post préconise une interface minimaliste et conviviale. Le test initial se concentre sur l'envoi d'un e-mail via une demande postale à l'API SparkPost. La moquerie est utilisée pour se moquer du client Guzzle, permettant de tester le formatage des paramètres du client sans passer d'appels API réels. Une classe de test de base (AbstractTest
) est créée pour gérer le nettoyage des moqueries.
Implémentation du client:
La classe Client
est créée, gérer la gestion des clés de l'API, l'URL de base et le transfert de demande. La méthode createTransmission
simplifie l'envoi des e-mails, fournissant des défauts sensibles. La méthode request
gère la demande de Guzzle réelle à l'API SparkPost.
Exécution de tests et de couverture de code:
Après implémentation de la classe Client
, PHPUnit est exécuté pour vérifier le succès du test. L'analyse de la couverture du code (en utilisant vendor/bin/phpunit --coverage-html coverage
) donne un aperçu des parties testées du code.
Considérations supplémentaires:
Le post met en évidence les domaines d'amélioration, tels que la validation des entrées, le découplage de Guzzle et l'élargissement du client pour gérer davantage l'API Sparkpost.
Résumé de la FAQ:
La section FAQ fournit des réponses concises aux questions clés concernant le TDD, le phpunit, la moquerie, la gestion des erreurs, la sécurité, les performances, l'évolutivité, l'intégration, la maintenance et le soutien communautaire dans le contexte de la construction d'un client Sparkpost.
Cette réponse réécrite fournit un résumé plus clair et plus concis de l'entrée d'origine, en maintenant le sens d'origine et le placement d'image. Il traite également du XML incomplet et mal formaté fourni dans l'entrée d'origine.
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!