


J'ai commencé à apprendre le PHP pur mi-2015. Ensuite, je me suis familiarisé avec CodeIgniter 3 et Laravel 5.1. Au fil des années, Laravel est mon framework de prédilection, et je m'y tiens toujours. Comme d'autres projets PHP populaires, je vois que PHPUnit est le seul choix pour les tests unitaires. Mais il y a eu un petit changement en 2021 avec l’arrivée de Pest. Il est créé par Nuno Maduro - un ingénieur chez Laravel, qui réalise également de nombreux projets/packages géniaux largement utilisés dans la communauté PHP et Laravel.
Depuis le tout premier jour de Pest, je m'en fiche car PHPUnit me suffit et j'ai la flemme d'apprendre ce nouvel outil de test. Mais plus la communauté Laravel grandit, plus Pest est recommandé. De nombreux projets/packages Laravel de Spatie, Livewire, Filament, ... utilisent Pest. Le problème est donc que lorsque je teste des éléments qui leur sont liés, je dois effectuer un portage sur PHPUnit. Il me semble que je n'ai pas le choix. Il est temps pour moi de jeter un œil à Pest.
Le premier regard
Suite à la section installation, je crée mon premier projet PHP en utilisant Pest.
mkdir ~/Herd/lerning-pest cd ~/Herd/learning-pest composer require pestphp/pest --dev --with-all-dependencies ./vendor/bin/pest --init
La structure des répertoires est presque la même que celle de PHPUnit. La différence est à quoi ressemble un test. C'est basé sur la fermeture plutôt que sur la classe.
<?php // tests/Unit/ExampleTest.php test('example', function () { expect(true)->toBeTrue(); });
Je sais utiliser Closure qui peut attacher paresseusement des méthodes à un objet au moment de l'exécution. Donc cela peut être réécrit en PHPUnit comme ça.
<?php // tests/Unit/ExampleTest.php class ExampleTest extends \PHPUnit\Framework\TestCase { public function test_example() { $this->assertTrue(true); } }
Il est indiqué que la syntaxe d'assertion Pest est inspirée de Rspec et Jest de Ruby, que je ne connais pas. Donc, eux non plus ne m'intéressent pas trop. Pour moi, peu importe la syntaxe des assertions.
J'aime juste le résultat affiché lors de l'exécution des tests. C'est beaucoup plus joli et plus propre que PHPUnit, je pense.
Affirmations
Ce sont les assertions que j'ai le plus utilisées dans PHPUnit.
$this->assertSame($expected, $actual); $this->assertTrue($condition); $this->assertFalse($condition); $this->assertNull($actual); $this->assertEmpty($array); $this->assertCount($count, $countable); $this->assertInstanceof($type, $instance);
Ils peuvent être facilement réécrits dans Pest.
expect($actual)->toBe($expected); expect($condition)->toBeTrue(); expect($condition)->toBeFalse(); expect($actual)->toBeNull(); expect($actual)->toBeEmpty(); expect($actual)->toBeInstanceOf($type);
Comme je l'ai mentionné plus tôt, la syntaxe d'assertion Pest est correcte, mais je m'en tiens actuellement à PHPUnit car je n'ai pas besoin d'étudier de nouvelles API. Quoi qu'il en soit, je préfère les assertions PHPUnit et n'utilise que des éléments uniques dans Pest. Les tests d'architecture en sont un exemple. Mon fichier de test ressemble à ceci.
<?php test("all PHP files in LearningPest namespace must have strict mode enabled", function () { arch() ->expect('LearningPest') ->toUseStrictTypes(); }); test('all PHPUnit assertions are available for Pest', function () { $instance = new \stdClass(); $getInstance = function () use ($instance) { return $instance; }; $this->assertSame($instance, $getInstance()); $this->assertInstanceOf(stdClass::class, $instance); $this->assertTrue(1 assertFalse(1 > 2); $value = null; $this->assertNull($value); $this->assertEmpty([]); $array = [1, 2, 3]; $this->assertCount(3, $array); });
Fonctionnalités obligatoires
Il existe un certain nombre de fonctionnalités obligatoires qui me permettent de travailler dans Pest de la même manière que PHPUnit. Les voici :
- PHPUnit a un fournisseur de données. Pest a des ensembles de données.
- PHPUnit a setUp, TearDown, setUpBeforeClass et TearDownAfterClass. Le ravageur a avantChac, aprèsChacun, avantTout et aprèsTout.
- Les deux ont des contrôles d'exception et peuvent ignorer/regrouper/filtrer les tests.
Mockery est une bibliothèque autonome, donc je ne la liste pas ici.
D'un autre côté, Pest a beaucoup de choses qui peuvent s'avérer utiles, comme l'architecture, les instantanés ou les tests de stress et les plugins. Je les découvrirai lors de la rédaction des tests.
Conclusion
- Pest est construit sur PHPUnit, largement utilisé et recommandé récemment dans la communauté PHP et Laravel.
- En utilisant Pest, je peux travailler presque de la même manière qu'avant, mais avec une CLI plus jolie et des fonctionnalités plus utiles.
- Maintenant, Pest est le framework de test par défaut pour mes applications PHP et Laravel.
Si vous êtes un développeur PHP qui n'a pas utilisé Pest, essayez-le.
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!

PHP et Python ont chacun leurs propres avantages, et le choix doit être basé sur les exigences du projet. 1.Php convient au développement Web, avec une syntaxe simple et une efficacité d'exécution élevée. 2. Python convient à la science des données et à l'apprentissage automatique, avec une syntaxe concise et des bibliothèques riches.

Le PHP n'est pas en train de mourir, mais d'adapter et d'évoluer constamment. 1) PHP a subi plusieurs itérations de version depuis 1994 pour s'adapter aux nouvelles tendances technologiques. 2) Il est actuellement largement utilisé dans le commerce électronique, les systèmes de gestion de contenu et d'autres domaines. 3) PHP8 introduit le compilateur JIT et d'autres fonctions pour améliorer les performances et la modernisation. 4) Utilisez OPCACHE et suivez les normes PSR-12 pour optimiser les performances et la qualité du code.

L'avenir de PHP sera réalisé en s'adaptant aux nouvelles tendances technologiques et en introduisant des fonctionnalités innovantes: 1) s'adapter aux architectures de cloud computing, de conteneurisation et de microservice, en prenant en charge Docker et Kubernetes; 2) introduire des compilateurs JIT et des types d'énumération pour améliorer l'efficacité des performances et du traitement des données; 3) Optimiser en continu les performances et promouvoir les meilleures pratiques.

En PHP, le trait convient aux situations où la réutilisation de la méthode est requise mais ne convient pas à l'héritage. 1) Le trait permet aux méthodes de multiplexage des classes pour éviter une complexité de succession multiple. 2) Lorsque vous utilisez un trait, vous devez faire attention aux conflits de méthode, qui peuvent être résolus par l'alternative et comme mots clés. 3) La surutilisation du trait doit être évitée et sa responsabilité unique doit être maintenue pour optimiser les performances et améliorer la maintenabilité du code.

Le conteneur d'injection de dépendance (DIC) est un outil qui gère et fournit des dépendances d'objets à utiliser dans les projets PHP. Les principaux avantages du DIC comprennent: 1. Le découplage, rendre les composants indépendants, et le code est facile à entretenir et à tester; 2. Flexibilité, facile à remplacer ou à modifier les dépendances; 3. Testabilité, pratique pour injecter des objets simulés pour les tests unitaires.

SPLFixedArray est un tableau de taille fixe en PHP, adapté aux scénarios où des performances élevées et une faible utilisation de la mémoire sont nécessaires. 1) Il doit spécifier la taille lors de la création pour éviter les frais généraux causés par un ajustement dynamique. 2) Sur la base du tableau de langue C, fonctionne directement de la mémoire et de la vitesse d'accès rapide. 3) Convient pour le traitement des données à grande échelle et les environnements sensibles à la mémoire, mais il doit être utilisé avec prudence car sa taille est fixe.

PHP gère les téléchargements de fichiers via la variable de fichiers $ \ _. Les méthodes pour garantir la sécurité incluent: 1. Vérifiez les erreurs de téléchargement, 2. Vérifiez le type et la taille du fichier, 3. Empêchez l'écrasement des fichiers, 4. Déplacez les fichiers vers un emplacement de stockage permanent.

Dans JavaScript, vous pouvez utiliser nullcoalescingoperator (??) et nullcoalescingAssIgnmentOperator (?? =). 1.? 2.?? Ces opérateurs simplifient la logique du code, améliorent la lisibilité et les performances.


Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

DVWA
Damn Vulnerable Web App (DVWA) est une application Web PHP/MySQL très vulnérable. Ses principaux objectifs sont d'aider les professionnels de la sécurité à tester leurs compétences et leurs outils dans un environnement juridique, d'aider les développeurs Web à mieux comprendre le processus de sécurisation des applications Web et d'aider les enseignants/étudiants à enseigner/apprendre dans un environnement de classe. Application Web sécurité. L'objectif de DVWA est de mettre en pratique certaines des vulnérabilités Web les plus courantes via une interface simple et directe, avec différents degrés de difficulté. Veuillez noter que ce logiciel

Navigateur d'examen sécurisé
Safe Exam Browser est un environnement de navigation sécurisé permettant de passer des examens en ligne en toute sécurité. Ce logiciel transforme n'importe quel ordinateur en poste de travail sécurisé. Il contrôle l'accès à n'importe quel utilitaire et empêche les étudiants d'utiliser des ressources non autorisées.

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

MantisBT
Mantis est un outil Web de suivi des défauts facile à déployer, conçu pour faciliter le suivi des défauts des produits. Cela nécessite PHP, MySQL et un serveur Web. Découvrez nos services de démonstration et d'hébergement.