Laravel如何编写单元测试和功能测试?(PHPUnit示例)

发布时间 - 2025-12-15 00:00:00    点击率:
Laravel单元测试专注单个类或方法逻辑,使用PHPUnit集成,测试文件置于tests/Unit/目录,类名以Test结尾、方法以test_开头,不依赖HTTP请求或数据库,可用Mockery模拟外部依赖。

在 Laravel 中编写单元测试和功能测试,核心是利用内置的 PHPUnit 集成和丰富的测试辅助方法。Laravel 默认已配置好 phpunit.xml,测试文件放在 tests/ 目录下,通过 php artisan test(或 vendor/bin/phpunit)运行。

单元测试:专注单个类或方法逻辑

单元测试验证模型、服务类、帮助函数等不依赖 HTTP 请求或数据库(或使用内存数据库/模拟)的独立逻辑。Laravel 提供 TestCase 基类,但单元测试通常继承更轻量的 \Tests\TestCase 或直接用 PHPUnit\Framework\TestCase

  • 将测试类放在 tests/Unit/ 目录下,类名以 Test 结尾(如 CalculatorTest.php
  • 方法名以 test_ 开头或用 @test 注释标记
  • 避免使用 $this->get()$this->actingAs() 等 HTTP 相关方法
  • 如需隔离外部依赖,用 Mockery 模拟(Laravel 自带)或 PHP 的 createMock()

示例(测试一个简单的服务类):

// tests/Unit/PriceCalculatorTest.php
withTax(100, 0.15);

        $this->assertEquals(115, $total);
    }
}

功能测试:模拟真实 HTTP 请求与用户交互

功能测试(也称“特性测试”)验证整个请求生命周期:路由 → 控制器 → 视图/响应,常涉及数据库、认证、会话等。Laravel 的 \Tests\TestCase 提供了开箱即用的测试工具链。

  • 测试类放在 tests/Feature/ 目录下
  • 默认启用数据库迁移(每次测试前重置 sqlite:memory),也可用 @database 注解或 RefreshDatabase trait
  • 常用断言:$this->get()$this->post()$this->assertStatus(200)$this->assertSee('Welcome')$this->assertJson(...)
  • 登录用户可用 $this->actingAs($user),无需真实 session

示例(测试文章列表页):

// tests/Feature/ArticleIndexTest.php
count(3)->create();

        $response = $this->get('/articles');

        $response->assertStatus(200);
        $response->assertSee('Articles');
        $response->assertSeeText('Article Title 1');
        $response->assertJsonCount(3, 'data');
    }
}

数据库测试技巧:工厂、种子与事务控制

Laravel 测试中操作数据库最推荐的方式是模型工厂(Factories)+ RefreshDatabase trait,它自动在每个测试前后用事务回滚,速度快且隔离性好。

  • Article::factory()->create() 创建测试数据,支持属性覆盖:['title' => 'Test']
  • 批量创建:Article::factory()->count(5)->create()
  • 关联数据可链式调用:User::factory()->hasPosts(3)->create()
  • 避免在测试中手动写 DB::table(...)->insert(...),破坏可读性和维护性
  • 如需完整迁移(比如测试迁移本身),用 UsesTransactions 替换或禁用 RefreshDatabase

运行与调试测试的实用建议

  • 只运行某个测试类:php artisan test --filter ArticleIndexTest
  • 只运行某个方法:php artisan test --filter test_articles_page_returns_successful_response
  • 查看详细输出(含异常堆栈):php artisan test -v
  • 生成覆盖率报告(需安装 Xdebug 或 PCOV):php artisan test --coverage-html coverage
  • 失败时快速定位:检查是否忘记 use RefreshDatabase;,或模型未加 $fillable 导致工厂创建失败

基本上就这些。Laravel 的测试体验流畅,关键在于分清单元与功能的边界,善用工厂和测试 trait,让测试既可靠又易维护。


# php  # laravel  # html  # count  # Session  # xml  # Filter  # 继承  #   #   # this  # table  # sqlite  # database  # 数据库  # http  # 放在  # 单元测试  # 链式  # 如需  # 目录下  # 不依赖  # 测试中  # 自带  # 速度快  # 既可 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 百度浏览器网页无法复制文字怎么办 百度浏览器复制修复  韩国服务器如何优化跨境访问实现高效连接?  广州网站制作公司哪家好一点,广州欧莱雅百库网络科技有限公司官网?  C#如何调用原生C++ COM对象详解  ,在苏州找工作,上哪个网站比较好?  Laravel如何实现一对一模型关联?(Eloquent示例)  python中快速进行多个字符替换的方法小结  Swift开发中switch语句值绑定模式  如何快速选择适合个人网站的云服务器配置?  合肥制作网站的公司有哪些,合肥聚美网络科技有限公司介绍?  Windows10电脑怎么设置虚拟光驱_Win10右键装载ISO镜像文件  Laravel怎么实现微信登录_Laravel Socialite第三方登录集成  如何在建站之星网店版论坛获取技术支持?  敲碗10年!Mac系列传将迎来「触控与联网」双革新  Claude怎样写约束型提示词_Claude约束提示词写法【教程】  PythonWeb开发入门教程_Flask快速构建Web应用  Win11搜索栏无法输入_解决Win11开始菜单搜索没反应问题【技巧】  如何在景安服务器上快速搭建个人网站?  如何在阿里云香港服务器快速搭建网站?  WordPress 子目录安装中正确处理脚本路径的完整指南  linux top下的 minerd 木马清除方法  php嵌入式断网后怎么恢复_php检测网络重连并恢复硬件控制【操作】  Laravel如何使用Gate和Policy进行权限控制_Laravel权限判定与策略规则配置  Laravel如何实现URL美化Slug功能_Laravel使用eloquent-sluggable生成别名【方法】  简单实现Android验证码  Laravel怎么使用artisan命令缓存配置和视图  Laravel如何创建自定义Facades?(详细步骤)  Laravel怎么实现软删除SoftDeletes_Laravel模型回收站功能与数据恢复【步骤】  如何在腾讯云免费申请建站?  中山网站制作网页,中山新生登记系统登记流程?  制作旅游网站html,怎样注册旅游网站?  laravel怎么用DB facade执行原生SQL查询_laravel DB facade原生SQL执行方法  Laravel怎么在Controller之外的地方验证数据  如何在阿里云虚拟机上搭建网站?步骤解析与避坑指南  使用豆包 AI 辅助进行简单网页 HTML 结构设计  html5如何实现懒加载图片_ intersectionobserver api用法【教程】  Laravel如何自定义分页视图?(Pagination示例)  济南网站建设制作公司,室内设计网站一般都有哪些功能?  网站制作大概要多少钱一个,做一个平台网站大概多少钱?  Laravel如何使用Service Provider服务提供者_Laravel依赖注入与容器绑定【深度】  网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?  微信小程序 配置文件详细介绍  JS碰撞运动实现方法详解  Laravel怎么实现API接口鉴权_Laravel Sanctum令牌生成与请求验证【教程】  三星网站视频制作教程下载,三星w23网页如何全屏?  如何用AWS免费套餐快速搭建高效网站?  动图在线制作网站有哪些,滑动动图图集怎么做?  js实现获取鼠标当前的位置  北京专业网站制作设计师招聘,北京白云观官方网站?  手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?