Laravel单元测试使用示例

Date: 2025-05-28 17:35:46 author: lijianzhan

在 Laravel 框架中,单元测试是一种常用的测试方法,它是允许你测试应用程序中的最小可测试单元,通常是方法或函数。Laravel 提供了内置的测试工具PHPUnit,实践中进行单元测试是保障代码质量的核心。以下是关键要点和最佳实践指南:

运行环境

操作系统:Windows X64

PHP版本:8.2.9nts

Laravel Framework:10.48.28

IDE:phpstorm2024.1.5

Laravel 测试体系结构

测试类型 存放路径 特点
单元测试(Unit) tests/Unit 测试独立类/方法,不依赖框架
-- -- --
功能测试 (Feature) tests/Feature 测试完整业务流(含路由、数据库)
  1. 通过 Composer 来安装或更新 PHPUnit测试库依赖,以下命令:
bash 复制代码
composer require --dev phpunit/phpunit
  1. 通过Artisan 命令创建测试类
bash 复制代码
		// 创建模型测试
        php artisan make:test ExampleTest
        
        // 创建控制器测试
        php artisan make:test ExampleControllerTest
        
        // 创建模型测试
        php artisan make:test ExampleServiceTest
  1. 编写测试用例
php 复制代码
<?php

namespace Tests\Feature;

use Tests\TestCase;

class ExampleTest extends TestCase
{
    /**
     * A basic test example.
     *
     * @return void
     */
    public function test_example()
    {
        $result = "start unit success!";
        dd($result);
    }

}
  1. 运行测试

(1)使用Artisan 命令运行test测试用例

bash 复制代码
php artisan test

(2)运行命令后返回信息

(3)或者使用Artisan 命令运行test指定目录测试用例

bash 复制代码
php artisan test tests/Feature/ExampleTest.php

(4)使用代码编辑器自带Debug方法

  1. 运行测试用例返回结果

  2. 常用断言方法示例

php 复制代码
$this->assertTrue($condition);
$this->assertEquals($expected, $actual);
$this->assertCount(3, $array);
$this->assertInstanceOf(User::class, $object);
$this->assertDatabaseHas('users', ['email' => 'test@example.com']);
// 数据库事务回滚
$this->assertDatabaseCount('users', 1);
  1. 测试覆盖率分析
bash 复制代码
# 1. 安装 Xdebug 或 PCOV
sudo apt install php8.1-xdebug

# 2. 运行测试并生成报告
php artisan test --coverage-html=coverage-report

# 3. 查看报告
open coverage-report/index.html
  1. 测试金字塔原则

总结:Laravel的构建考虑到了测试。事实上,对PHPUnit测试的支持是现成的,并且已经为您的应用程序设置了PHPUnit.xml文件。该框架还附带了方便的辅助方法,允许您对应用程序进行富有表现力的测试。

相关推荐
不正经的小寒10 小时前
PHP 8.2 核心特性
php
不正经的小寒10 小时前
PHP 8.1 核心特性
php
SEO_juper13 小时前
CDN 地域节点优化:匹配 GEO 信号,提升加载速度
服务器·ai·php·seo·cdn·geo·谷歌优化
dog25014 小时前
解析几何的现代范式-算力,拟合与对偶
服务器·开发语言·网络·线性代数·php
淘矿人15 小时前
【AI大模型】AI 大模型推理平台完整测评:8 家主流聚合服务对比分析
人工智能·sql·gpt·学习·github·php
XiYang-DING17 小时前
【Java EE】TCP—滑动窗口
tcp/ip·java-ee·php
.千余18 小时前
【Linux】网络基础2---Socket编程预备
linux·网络·php
雪度娃娃19 小时前
Asio异步读写——简单服务器和客户端异步通信
运维·服务器·网络·c++·php
中科三方20 小时前
域名解析修改后,用户仍访问旧IP?原因排查与高效解决指南
网络协议·tcp/ip·php
码农老李1 天前
openEuler2403服务器版 原生官方镜像和飞腾定制镜像
开发语言·php