使用 Event::fake() 拦截事件后,可通过 assertDispatched 断言事件被触发、assertDispatchedTimes 验证触发次数、assertNotDispatched 确保未触发,并可结合闭包验证事件数据。

使用 `expectsEvents` 断言特定事件被分发
如果你只想确认某个事件被触发,而不想执行该事件的监听器,可以使用 `expectsEvents` 方法:示例代码:
use Illuminate\Support\Facades\Event;
use App\Events\UserRegistered;
public function test_user_registration_dispatches_event()
{
Event::fake();
$this->expectsEvents(UserRegistered::class);
// 执行触发事件的操作
$this->post('/register', [
'name' => 'John Doe',
'email' => 'john@example.com',
'password' => 'secret'
]);
}
注意:`expectsEvents` 是一个便捷方式,它本质上会配合 `Event::fake()` 使用,确保只有列出的事件被允许触发。
使用 `Event::fake()` 配合 `assertDispatched`
更灵活的方式是使用 `Event::fake()` 捕获所有事件,然后通过 `assertDispatched` 来断言某个事件被分发。常用方法包括:
- assertDispatched():断言事件至少被触发一次
- assertDispatchedTimes():断言事件被触发指定次数
- assertNotDispatched():断言事件未被触发
- 还可以传递闭包来检查事件的属性
use Illuminate\Support\Facades\Event;
use App\Events\OrderShipped;
public function test_order_shipment_dispatches_event()
{
Event::fake();
// 执行业务逻辑
$order = Order::factory()->create();
$order->ship();
// 断言事件被触发
Event::assertDispatched(OrderShipped::class);
// 断言事件触发一次
Event::assertDispatchedTimes(OrderShipped::class, 1);
// 断言事件带有特定数据
Event::assertDispatched(OrderShipped::class, function ($event) use ($order) {
return $event->order->id === $order->id;
});
}
断言事件未被触发
有时候你需要确保某个事件**没有**被触发,比如在条件不满足时:Event::fake(); // 执行某些操作 $user = User::factory()->make(); $user->save(); // 假设未触发 UserRegistered Event::assertNotDispatched(UserRegistered::class);这种方法常用于避免重复触发或条件性触发场景。 基本上就这些。只要记得先调用 `Event::fake()` 拦截事件,再用 `assertDispatched` 系列方法做判断,就能轻松完成事件断言。










