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 】 【 网络技术251811 】 【 AI营销90571


相关推荐: 在Oracle关闭情况下如何修改spfile的参数  网站图片在线制作软件,怎么在图片上做链接?  Laravel怎么实现模型属性的自动加密  网站制作怎么样才能赚钱,用自己的电脑做服务器架设网站有什么利弊,能赚钱吗?  如何用IIS7快速搭建并优化网站站点?  Laravel模型关联查询教程_Laravel Eloquent一对多关联写法  简历在线制作网站免费版,如何创建个人简历?  Laravel如何实现文件上传和存储?(本地与S3配置)  Laravel队列由Redis驱动怎么配置_Laravel Redis队列使用教程  Laravel如何将应用部署到生产服务器_Laravel生产环境部署流程  头像制作网站在线观看,除了站酷,还有哪些比较好的设计网站?  消息称 OpenAI 正研发的神秘硬件设备或为智能笔,富士康代工  Laravel如何设置定时任务(Cron Job)_Laravel调度器与任务计划配置  如何在IIS中配置站点IP、端口及主机头?  如何在建站之星网店版论坛获取技术支持?  Win11怎么更改系统语言为中文_Windows11安装语言包并设为显示语言  如何在万网主机上快速搭建网站?  如何确认建站备案号应放置的具体位置?  浅谈javascript alert和confirm的美化  浅谈Javascript中的Label语句  Bootstrap整体框架之CSS12栅格系统  如何用PHP工具快速搭建高效网站?  如何快速生成ASP一键建站模板并优化安全性?  大型企业网站制作流程,做网站需要注册公司吗?  Laravel如何使用Eloquent ORM进行数据库操作?(CRUD示例)  详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)  创业网站制作流程,创业网站可靠吗?  如何在云主机上快速搭建网站?  Win11怎样安装网易有道词典_Win11安装词典教程【步骤】  Laravel Session怎么存储_Laravel Session驱动配置详解  Win11怎么恢复误删照片_Win11数据恢复工具使用【推荐】  ,交易猫的商品怎么发布到网站上去?  javascript事件捕获机制【深入分析IE和DOM中的事件模型】  谷歌Google入口永久地址_Google搜索引擎官网首页永久入口  Laravel怎么防止CSRF攻击_Laravel CSRF保护中间件原理与实践  如何在Windows服务器上快速搭建网站?  如何在云虚拟主机上快速搭建个人网站?  如何在 React 中条件性地遍历数组并渲染元素  如何挑选最适合建站的高性能VPS主机?  如何彻底卸载建站之星软件?  Python制作简易注册登录系统  阿里云网站搭建费用解析:服务器价格与建站成本优化指南  php485函数参数是什么意思_php485各参数详细说明【介绍】  iOS正则表达式验证手机号、邮箱、身份证号等  Laravel如何实现密码重置功能_Laravel密码找回与重置流程  Laravel如何实现全文搜索_Laravel Scout集成Algolia或Meilisearch教程  简单实现jsp分页  JS中使用new Date(str)创建时间对象不兼容firefox和ie的解决方法(两种)  JavaScript实现Fly Bird小游戏  合肥制作网站的公司有哪些,合肥聚美网络科技有限公司介绍?