卓越飞翔博客卓越飞翔博客

卓越飞翔 - 您值得收藏的技术分享站
技术文章68952本站已运行4220

使用 PHPUnit 在 Laravel 中进行测试的综合指南

laravel 测试简介

测试是软件开发的一个重要方面,可确保您的应用程序按预期工作。 laravel 通过 phpunit(一种流行的 php 测试框架)提供了一个强大的开箱即用的测试套件。本指南将引导您在 laravel 中设置和运行测试,解释单元测试和功能测试之间的差异,并提供各种测试场景的示例。

文件夹结构:单元测试与功能测试

在 laravel 中,测试通常被组织到两个主要目录中:unit 和 feature。

单元测试:这些测试旨在测试应用程序的小型、独立部分,例如单个方法或类。它们通常位于tests/unit 目录中。每个测试函数都应该以单词 test 开头。

示例:

public function testexamplefunction() {
    $this->asserttrue(true);
}

功能测试:这些测试处理更复杂的交互,通常测试多个组件一起工作。它们位于测试/功能目录中。功能测试通常涉及发出 http 请求和检查响应。

在 laravel 中运行测试

要在 laravel 应用程序中运行所有测试,请使用以下命令:

./vendor/bin/phpunit

配置测试环境

在运行测试之前,配置测试环境非常重要。修改 phpunit.xml 文件以设置用于测试的环境变量。例如,要使用 sqlite 内存数据库进行更快的测试:

<php><env name="app_env" value="testing"></env><env name="app_maintenance_driver" value="file"></env><env name="bcrypt_rounds" value="4"></env><env name="cache_store" value="array"></env><env name="db_connection" value="sqlite"></env><env name="db_database" value=":memory:"></env><env name="mail_mailer" value="array"></env><env name="pulse_enabled" value="false"></env><env name="queue_connection" value="sync"></env><env name="session_driver" value="array"></env><env name="telescope_enabled" value="false"></env></php>

启用 sqlite 作为测试环境后,清除配置缓存:

php artisan config:clear

*示例:测试配置文件路由是否存在并正常工作
*

为配置文件路由创建测试:

php artisan make:test profiletest

添加测试方法来检查个人资料页面是否显示特定文本:

public function testprofilepage(){
    $response = $this-&gt;get('/profile');
    $response-&gt;assertseetext('your profile');
}

测试数据库交互

设置测试数据库

立即学习“PHP免费学习笔记(深入)”;

在测试数据库交互之前,在 config/database.php 中创建一个测试数据库配置:

'mysqltesting' =&gt; [
    'driver' =&gt; 'mysql',
    'url' =&gt; env('db_url'),
    'host' =&gt; env('db_host', '127.0.0.1'),
    'port' =&gt; env('db_port', '3306'),
    'database' =&gt; 'laravel_testing',
    'username' =&gt; env('db_username', 'root'),
    'password' =&gt; env('db_password', ''),
    'unix_socket' =&gt; env('db_socket', ''),
    'charset' =&gt; 'utf8mb4',
    'collation' =&gt; 'utf8mb4_unicode_ci',
    'prefix' =&gt; '',
    'prefix_indexes' =&gt; true,
    'strict' =&gt; true,
    'engine' =&gt; null,
    'options' =&gt; extension_loaded('pdo_mysql') ? array_filter([
        pdo::mysql_attr_ssl_ca =&gt; env('mysql_attr_ssl_ca'),
    ]) : [],
],

运行数据库测试

运行 phpunit 命令以确保测试数据库已创建并正常工作:

./vendor/bin/phpunit

使用 PHPUnit 在 Laravel 中进行测试的综合指南

示例:测试用户注册

创建用户注册测试:

php artisan make:test usertest

添加测试方法来验证用户是否可以创建并保存到数据库:

public function test_registration(): void
{
    $user = new user();
    $user-&gt;name = 'test user';
    $user-&gt;email = 'email@example.com';
    $user-&gt;password = bcrypt('password');

    $user-&gt;save();

    $this-&gt;assertdatabasehas('users', ['email' =&gt; 'email@example.com']);
}

测试商店操作

在 posttest 类中创建存储操作的测试:

public function testpoststorevalid()
{
    $data = [
        'title'=&gt; 'test post',
        'slug' =&gt; 'test-post',
        'content' =&gt; 'content of the post',
        'active' =&gt; true,
    ];

    $this-&gt;post('/posts', $data)
         -&gt;assertstatus(302)
         -&gt;assertsessionhas('status');

    $this-&gt;assertequals(session('status'), 'post was created!');
}

故障测试

添加测试方法来检查验证错误:

public function testpostfail()
{
    $data = [
        'title'=&gt; '',
        'content' =&gt; '',
    ];

    $this-&gt;post('/posts', $data)
         -&gt;assertstatus(302)
         -&gt;assertsessionhas('errors');

    $messages = session('errors')-&gt;getmessages();

    $this-&gt;assertequals($messages['title'][0], 'the title must be at least 4 characters.');
    $this-&gt;assertequals($messages['title'][1], 'the title field is required.');
    $this-&gt;assertequals($messages['content'][0], 'the content field is required.');
}

*测试更新操作
*

添加更新帖子的测试方法:

public function testpostupdate()
{
    $post = new post();

    $post-&gt;title = "initial title";
    $post-&gt;slug = str::slug($post-&gt;title, '-');
    $post-&gt;content = "initial content";
    $post-&gt;active = true;

    $post-&gt;save();

    $this-&gt;assertdatabasehas('posts', $post-&gt;toarray());

    $data = [
        'title' =&gt; 'updated title',
        'slug' =&gt; 'updated-title',
        'content' =&gt; 'updated content',
        'active' =&gt; false,
    ];

    $this-&gt;put("/posts/{$post-&gt;id}", $data)
         -&gt;assertstatus(302)
         -&gt;assertsessionhas('status');

    $this-&gt;assertdatabasehas('posts', ['title' =&gt; $data['title']]);
    $this-&gt;assertdatabasemissing('posts', ['title' =&gt; $post-&gt;title]);
}

测试删除操作

添加删除帖子的测试方法:

public function testpostdelete()
{
    $post = new post();

    $post-&gt;title = "title to delete";
    $post-&gt;slug = str::slug($post-&gt;title, '-');
    $post-&gt;content = "content to delete";
    $post-&gt;active = true;

    $post-&gt;save();

    $this-&gt;assertdatabasehas('posts', $post-&gt;toarray());

    $this-&gt;delete("/posts/{$post-&gt;id}")
         -&gt;assertstatus(302)
         -&gt;assertsessionhas('status');

    $this-&gt;assertdatabasemissing('posts', $post-&gt;toarray());
}

**

使用 phpunit 运行特定测试

**

要运行特定的测试方法或类,请在 phpunit 中使用 --filter 选项。以下是一些例子:

运行特定的测试方法

./vendor/bin/phpunit --filter posttest::testpostdelete

运行特定类中的所有测试

./vendor/bin/phpunit --filter posttest

在特定文件中运行测试

./vendor/bin/phpunit tests/feature/posttest.php

详细输出

想要更详细的输出,请添加 -v 选项:

./vendor/bin/phpunit --filter PostTest::testPostDelete -v
卓越飞翔博客
上一篇: golang 微服务框架的选型和最佳实践
下一篇: 返回列表
留言与评论(共有 0 条评论)
   
验证码:
隐藏边栏