0

0

laravel如何使用PHPUnit模拟(Mock)对象_Laravel PHPUnit模拟对象使用方法

尼克

尼克

发布时间:2025-10-11 08:15:01

|

168人浏览过

|

来源于php中文网

原创

Laravel中使用PHPUnit模拟对象可隔离外部依赖,提升测试速度与专注度。1. 通过Facade的shouldReceive或fake方法模拟Cache、Mail等门面调用;2. 使用$this->mock()模拟服务容器中的类,实现依赖替换;3. 采用partialMock仅拦截特定方法,保留其余逻辑;4. 利用Event::fake()、Mail::fake()、Notification::fake()断言事件、邮件、通知行为;5. 结合Mockery手动创建复杂模拟对象,并通过$app->instance()注入容器。合理运用这些方式可使测试更快速稳定。

laravel如何使用phpunit模拟(mock)对象_laravel phpunit模拟对象使用方法

Laravel 中使用 PHPUnit 模拟对象,主要是为了在测试过程中隔离外部依赖,比如数据库、队列、第三方服务等,从而让测试更快速、更专注。Laravel 基于 PHPUnit,并集成了强大的 Mockery 集成支持,让你可以轻松创建模拟对象。

1. 使用 Laravel 的 Facade 模拟

当你的代码中使用了 Laravel 的门面(Facade),比如 Cache::get()Mail::send()Http::get(),你可以使用 FakeshouldReceive() 来模拟它们的行为。

示例:模拟 Cache 门面

use Illuminate\Support\Facades\Cache;

public function test_cache_is_used()
{
    Cache::shouldReceive('get')
         ->with('user_count')
         ->andReturn(100);

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

    $response->assertSee('100 users');
}

上面的代码告诉 Laravel:当调用 Cache::get('user_count') 时,返回 100,而不是真实访问缓存。

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

2. 模拟服务容器中的类

如果你在控制器或服务中依赖注入了一个服务类,可以使用 $this->mock()$this->partialMock() 方法来模拟这个类。

示例:模拟 UserService 类

use App\Services\UserService;

public function test_user_profile_is_shown()
{
    $this->mock(UserService::class, function ($mock) {
        $mock->shouldReceive('getProfile')
             ->with(1)
             ->andReturn(['name' => 'John']);
    });

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

    $response->assertJson(['name' => 'John']);
}

这样,当 Laravel 容器解析 UserService 时,会自动使用你定义的模拟对象。

maven使用方法 中文WORD版
maven使用方法 中文WORD版

本文档主要讲述的是maven使用方法;Maven是基于项目对象模型的(pom),可以通过一小段描述信息来管理项目的构建,报告和文档的软件项目管理工具。Maven将你的注意力从昨夜基层转移到项目管理层。Maven项目已经能够知道 如何构建和捆绑代码,运行测试,生成文档并宿主项目网页。希望本文档会给有需要的朋友带来帮助;感兴趣的朋友可以过来看看

下载

3. 部分模拟(Partial Mock)

有时候你只想模拟类中的某个方法,其他方法仍执行原逻辑,这时使用 partialMock

$this->partialMock(UserService::class, function ($mock) {
    $mock->shouldReceive('sendNotification')->once();
});

这表示只拦截 sendNotification 方法,其余方法保持真实调用。

4. 模拟事件、邮件、通知

Laravel 提供了专门的测试辅助函数来模拟常见功能:

  • Event::fake() —— 禁止事件广播,可断言是否触发
  • Mail::fake() —— 拦截邮件发送
  • Notification::fake() —— 模拟通知

示例:验证邮件是否发送

use Illuminate\Support\Facades\Mail;
use App\Mail\WelcomeEmail;

public function test_welcome_email_is_sent()
{
    Mail::fake();

    $response = $this->post('/register', [
        'email' => 'test@example.com'
    ]);

    Mail::assertSent(WelcomeEmail::class, function ($mail) {
        return $mail->hasTo('test@example.com');
    });
}

5. 使用 Mockery 手动创建 Mock 对象

你也可以直接使用 Mockery 创建更复杂的模拟场景。

$mock = \Mockery::mock('App\Services\PaymentGateway');
$mock->shouldReceive('charge')->andReturn(true);

$this->app->instance(PaymentGateway::class, $mock);

通过 $this->app->instance() 将模拟对象绑定到服务容器,替换原始实现。

基本上就这些。Laravel 的测试系统让模拟对象变得简单直观,关键是理解何时使用 shouldReceivefake 和容器绑定。合理使用模拟,能让测试更快更稳定。

相关专题

更多
laravel组件介绍
laravel组件介绍

laravel 提供了丰富的组件,包括身份验证、模板引擎、缓存、命令行工具、数据库交互、对象关系映射器、事件处理、文件操作、电子邮件发送、队列管理和数据验证。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

316

2024.04.09

laravel中间件介绍
laravel中间件介绍

laravel 中间件分为五种类型:全局、路由、组、终止和自定。想了解更多laravel中间件的相关内容,可以阅读本专题下面的文章。

275

2024.04.09

laravel使用的设计模式有哪些
laravel使用的设计模式有哪些

laravel使用的设计模式有:1、单例模式;2、工厂方法模式;3、建造者模式;4、适配器模式;5、装饰器模式;6、策略模式;7、观察者模式。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

369

2024.04.09

thinkphp和laravel哪个简单
thinkphp和laravel哪个简单

对于初学者来说,laravel 的入门门槛较低,更易上手,原因包括:1. 更简单的安装和配置;2. 丰富的文档和社区支持;3. 简洁易懂的语法和 api;4. 平缓的学习曲线。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

370

2024.04.10

laravel入门教程
laravel入门教程

本专题整合了laravel入门教程,想了解更多详细内容,请阅读专题下面的文章。

81

2025.08.05

laravel实战教程
laravel实战教程

本专题整合了laravel实战教程,阅读专题下面的文章了解更多详细内容。

64

2025.08.05

laravel面试题
laravel面试题

本专题整合了laravel面试题相关内容,阅读专题下面的文章了解更多详细内容。

67

2025.08.05

数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

348

2023.06.29

微信聊天记录删除恢复导出教程汇总
微信聊天记录删除恢复导出教程汇总

本专题整合了微信聊天记录相关教程大全,阅读专题下面的文章了解更多详细内容。

36

2026.01.18

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.4万人学习

MongoDB 教程
MongoDB 教程

共17课时 | 2.1万人学习

C# 教程
C# 教程

共94课时 | 7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号