Maison > cadre php > Laravel > Développement Laravel : Comment utiliser Laravel Dusk pour les tests automatisés de l'interface utilisateur ?

Développement Laravel : Comment utiliser Laravel Dusk pour les tests automatisés de l'interface utilisateur ?

PHPz
Libérer: 2023-06-13 17:21:27
original
837 Les gens l'ont consulté

Avec le développement des applications web, l'automatisation des tests est devenue un élément indispensable. Dans cet article, nous explorerons Laravel Dusk, un outil puissant du framework Laravel pour les tests automatisés d'interface utilisateur. Laravel Dusk fournit une API simple pour exécuter un navigateur sans tête afin de vérifier que votre application Web fonctionne comme prévu en simulant l'interaction de l'utilisateur.

Quels sont les avantages de l'utilisation de Laravel Dusk pour les tests automatisés de l'interface utilisateur ?

  • Tests rapides et fiables : Laravel Dusk est un outil de test rapide et fiable conçu pour raccourcir les cycles de test tout en simplifiant l'infrastructure de test.
  • Meilleure couverture des tests : utilisez Laravel Dusk pour tester de nombreux aspects de votre application tels que la validation des formulaires, les actions des utilisateurs, l'authentification, etc.
  • Simulez l'interaction réelle de l'utilisateur : Laravel Dusk teste votre application en simulant l'interaction réelle de l'utilisateur, afin que vous puissiez vous assurer que votre application fonctionne réellement comme elle est censée le faire.
  • Tests situationnels : vous pouvez effectuer des tests à travers différents scénarios. Cela signifie que vous pouvez tester de nombreux scénarios différents, tels que tester des pages Web spécifiques, tester différents rôles et autorisations d'utilisateur, etc.

Ensuite, voyons comment utiliser Laravel Dusk pour les tests automatisés de l'interface utilisateur dans Laravel.

Prérequis :

  • Laravel 5.4 ou supérieur
  • PHP 7.0 ou supérieur

Étape 1 : Installer Laravel Dusk

Laravel Dusk fait partie du framework Laravel, nous devons donc d'abord installer le framework Laravel. Pour installer le framework Laravel, exécutez la commande suivante :

$ composer create-project --prefer-dist laravel/laravel project-name
Copier après la connexion

Ensuite, nous devons installer Laravel Dusk en exécutant la commande suivante :

$ composer require --dev laravel/dusk
Copier après la connexion

Étape 2 : Configurer Dusk

Une fois Laravel Dusk installé, vous devez effectuer une quelques étapes de configuration sont nécessaires pour commencer les tests.

Tout d'abord, Dusk nécessite un fichier .env.dusk.local, qui est une extension d'un fichier .env contenant des variables d'environnement à des fins de test. Vous pouvez créer le fichier .env.dusk.local en :

$ cp .env .env.dusk.local
Copier après la connexion

Modifiez le contenu du fichier .env.dusk.local en fonction de vos besoins de test.

Laravel Dusk nécessite également une base de données SQLite pour stocker les données utilisées lors des tests. Vous pouvez créer la base de données en exécutant :

$ touch database/database.sqlite
Copier après la connexion

Enfin, enregistrez un accesseur dans votre AppServiceProvider qui demande à Dusk d'utiliser le ChromeDriver de PHPUnit.

public function register()
{
    if ($this->app->environment('local', 'testing')) {
        $this->app->register(DuskServiceProvider::class);
    }
}
Copier après la connexion

Étape 3 : Rédigez le test

Vous pouvez maintenant commencer à rédiger votre premier test Dusk. Pour écrire des tests, créez un répertoire tests/Browser et créez-y une nouvelle classe de test de navigateur.

Ce fichier peut être facilement créé à l'aide du créateur Artisan, exécutez la commande suivante :

$ php artisan dusk:make LoginTest
Copier après la connexion

L'exécution de cette commande créera un nouveau fichier de classe de test appelé LoginTest.php, veuillez mettre à jour ce fichier selon l'exemple de code suivant :

<?php

namespace TestsBrowser;

use LaravelDuskBrowser;
use TestsDuskTestCase;

class LoginTest extends DuskTestCase
{
    /**
     * A Dusk test example.
     *
     * @return void
     */
    public function testLogin()
    {
        $this->browse(function (Browser $browser) {
            $browser->visit('/login')
                    ->type('email', 'example@domain.com')
                    ->type('password', 'password')
                    ->press('Login')
                    ->assertPathIs('/home');
        });
    }
}
Copier après la connexion

L'exemple Testez en ouvrant l'application locale dans le navigateur Chrome, puis saisissez les exemples de données sur la page de connexion, cliquez sur le bouton de connexion, puis vérifiez que le chemin de redirection est "/home".

Enfin, exécutez la commande suivante pour exécuter le test :

php artisan dusk
Copier après la connexion

Félicitations ! Vous avez maintenant terminé le didacticiel de démarrage avec Laravel Dusk. En utilisant Laravel Dusk, vous pouvez facilement écrire des tests d'interface utilisateur automatisés pour garantir que votre application fonctionne comme prévu.

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!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal