Aperçu des outils d'assurance qualité PHP: un guide pratique pour améliorer la qualité du code PHP
Cet article met en évidence les principaux outils d'assurance de la qualité PHP tels que le phpunit, le concombre, l'atoum, le sélénium, le crépuscule, le kahlan et la testabilité PHP, chacun offrant des tests de test et de code de code uniques. De plus, les services d'intégration continue (CI) tels que PHPCI, Travisci, Semaphoreci et Jenkins sont essentiels pour les projets d'équipe car ils vérifient automatiquement le code avant qu'il ne soit fusionné dans le référentiel de projet officiel.
Bien que la construction d'une culture de test soit difficile, il est crucial pour la qualité du code. L'utilisation des outils ci-dessus peut aider les développeurs à démarrer avec les tests et à assurer la qualité de leurs pratiques de codage PHP.
(Cet article populaire a été mis à jour le 30 juin 2017 pour inclure les dernières technologies et outils.)
Pour fournir du code de haute qualité, nous devons envisager des tests lors du codage (sinon de développement axé sur les tests (TDD). Cependant, étant donné la grande variété d'outils de test PHP, il est difficile de faire un choix! Explorer PHP est une aventure amusante, mais il est difficile de former une boîte à outils qui ne sera pas trop lourde!
Cet article se concentrera sur les outils de test les plus populaires et a été mis à jour pour refléter l'état actuel des outils d'assurance qualité en 2017.
Le code non testé est le code en question.
phpunit est le cadre de test préféré pour PHP. Il a été créé en 2004 par Sebastian Bergmann et a actuellement la version 6 et nécessite PHP 7.
Nous avons beaucoup de tutoriels à ce sujet à venir bientôt.
Le concombre est un cadre pour créer des tests d'acceptation en fonction des spécifications. Il est connu pour ses textes générés descriptivement qui peuvent être lus comme un anglais normal. La mise en œuvre officielle de PHP du concombre est Behat.
Nous avons un tutoriel sur le démarrage sur SitePoint ici. Les exemples suivants extraits de la documentation illustrent bien comment ces expressions souhaitées sont exprimées.
<code>Feature: Listing command In order to change the structure of the folder I am currently in As a UNIX user I need to be able see the currently available files and folders there Scenario: Listing two files in a directory Given I am in a directory "test" And I have a file named "foo" And I have a file named "bar" When I run "ls" Then I should get: """ bar foo """</code>
ATOUM est un autre cadre de test unitaire pour PHP. Il s'agit d'un package autonome que vous pouvez installer via GitHub, Composer ou Phar Executiles.
Le testATOUM est très lisible, avec des noms de méthode clairs et des expressions de liaison.
<code>$this->integer($classInstance->myMethod()) ->isEqualTo(10); $this->string($classInstance->myMethod()) ->contains("Something heppened"); </code>
Si vous souhaitez en savoir plus sur l'utilisation d'ATOUM pour les tests d'unité PHP, vous pouvez lire ce tutoriel.
Sélénium est un outil pour les tests automatisés du navigateur (test d'intégration et d'acceptation). Il convertit les tests en commandes d'API du navigateur et affirme les résultats attendus. Il prend en charge la plupart des navigateurs disponibles.
Nous pouvons utiliser des extensions pour utiliser le sélénium avec du phpunit.
<code>Feature: Listing command In order to change the structure of the folder I am currently in As a UNIX user I need to be able see the currently available files and folders there Scenario: Listing two files in a directory Given I am in a directory "test" And I have a file named "foo" And I have a file named "bar" When I run "ls" Then I should get: """ bar foo """</code>
Ceci est un exemple simple:
<code>$this->integer($classInstance->myMethod()) ->isEqualTo(10); $this->string($classInstance->myMethod()) ->contains("Something heppened"); </code>
Si vous souhaitez en savoir plus sur les tests avec Phpunit et Selenium, vous pouvez lire cette série d'articles.
Le crépuscule de Laravel est un autre outil d'automatisation du navigateur. Il peut être utilisé indépendamment (en utilisant Chromedriver) ou en conjonction avec le sélénium. Il dispose d'une API facile à utiliser qui couvre toutes les possibilités de test telles que l'attente des éléments, des téléchargements de fichiers, des commandes de souris, etc. Voici un exemple simple:
<code>composer require --dev phpunit/phpunit composer require --dev phpunit/phpunit-selenium </code>
Vous pouvez vérifier ce tutoriel pour commencer avec le crépuscule pour les tests.
Kahlan est une unité entièrement fonctionnelle et un cadre de test BDD qui utilise la syntaxe décrite-it.
<code>class UserSubscriptionTest extends PHPUnit_Extensions_Selenium2TestCase { public function testFormSubmissionWithUsername() { $this->byName('username')->value('name'); $this->byId('subscriptionForm')->submit(); } } </code>
Comme le montre la syntaxe ci-dessus, il est similaire au test de Behat. Kahlan prend en charge les talons et les simulations prêts à l'emploi, sans dépendances, la couverture du code, les rapports, etc.
<code>class LanguagesControllerTest extends DuskTestCase { public function testCreate() { $this->browse(function (Browser $browser) { $user = $this->getAdminUser(); $browser->loginAs($user) ->visit('/panel/core/languages') ->click('#add') ->assertPathIs('/panel/core/languages/create') ->type('name', 'Arabic') ->select('direction', 'rtl') ->press('Submit') ->assertSee('Language: Arabic') ->assertSee('ar') ->assertSee('rtl') ->assertSee('Language created'); }); } } </code>
Le dernier package à mentionner est la testabilité PHP. Il s'agit d'un outil d'analyse statique qui vous indique les problèmes de testabilité dans votre programme et génère des rapports détaillés.
Le package n'a actuellement pas de version marquée sur laquelle vous pouvez compter, mais vous pouvez l'utiliser en toute sécurité en développement. Vous pouvez l'installer via Composer:
<code>describe("Positive Expectation", function() { it("expects that 5 > 4", function() { expect(5)->toBeGreaterThan(4); }); }); </code>
puis exécutez-le comme ceci:
<code>it("makes a instance double with a parent class", function() { $double = Double::instance(['extends' => 'Kahlan\Util\Text']); expect(is_object($double))->toBe(true); expect(get_parent_class($double))->toBe('Kahlan\Util\Text'); }); </code>
Une partie importante du travail avec une équipe pour livrer du code est la possibilité de vérifier automatiquement le code avant de le fuir dans le référentiel officiel du projet. La plupart des services / outils CI disponibles peuvent tester le code sur différentes plates-formes et configurations pour vous assurer que votre code peut être fusionné en toute sécurité.
Il existe de nombreux services qui offrent de bonnes notes de prix, mais vous pouvez également utiliser des outils open source:
Construire une culture d'essai est difficile, mais elle se développera lentement avec la pratique. Si vous vous souciez de votre code, vous devez le tester! Les outils et ressources ci-dessus vous aideront à démarrer rapidement.
Comment est votre expérience avec les outils ci-dessus? Avons-nous manqué quelque chose? Veuillez nous faire savoir que nous ferons de notre mieux pour étendre la liste avec les outils nécessaires!
Lors du choix d'un outil d'assurance qualité PHP, plusieurs fonctionnalités clés doivent être prises en compte. Premièrement, l'outil devrait être en mesure d'effectuer une analyse de code statique, qui consiste à vérifier le code source pour les erreurs potentielles, les bogues ou les violations des normes de codage sans exécuter de programme. Deuxièmement, l'outil doit fournir un cadre de test unitaire qui vous permet de tester les unités individuelles du code source pour déterminer s'ils conviennent à une utilisation. Les autres caractéristiques importantes incluent l'analyse de la couverture du code (mesurer le degré de test de code) et l'intégration continue (fusionnez régulièrement les copies de travail de tous les développeurs sur la ligne principale partagée).
Les outils d'assurance qualité PHP peuvent augmenter considérablement l'efficacité du processus de développement en automatisant de nombreuses tâches de temps et sujettes aux erreurs. Par exemple, l'analyse du code statique peut détecter automatiquement les erreurs potentielles et les violations des normes de codage, éliminant les tracas de vérifier manuellement votre code. De même, le cadre des tests unitaires peut tester automatiquement les unités individuelles du code source, garantissant qu'ils peuvent fonctionner correctement avant d'être intégrés dans un système plus grand. Cela peut vous faire économiser beaucoup de temps et d'efforts pour le débogage et le dépannage.
Oui, il existe de nombreux outils d'assurance qualité PHP open source disponibles. Ceux-ci incluent PHP_CODESNIFFER (vérification des violations des normes de codage dans le code); Ces outils sont gratuits et peuvent être personnalisés selon vos besoins spécifiques.
(La réponse FAQ suivante est également réécrite, en gardant la signification originale inchangée et en ajustant le style de langue pour le rendre plus lisse et plus naturel.)
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!