听起来很简单,但我无法弄清楚如何将数据传递到以下可邮寄进行测试。它可以正常使用。
通过控制器工作
Mail::to($user)->send(new C2cMail($this->commitment->data, \App\EModule::findOrFail($this->commitment->module_id), $user));
可邮寄
public function __construct($commitment, Module $module, User $user)
{
$this->commitment = unserialize($commitment);
$this->module = $module;
$this->user = $user;
$this->title = $this->module->title;
}
/**
* Build the message.
*
* @return $this
*/
public function build()
{
try {
if(empty(env('MAIL_FROM')) || !env('MAIL_FROM') || env('MAIL_FROM') == null){
throw new \Exception("You must set your MAIL_FROM environment variable", 406);
}
$this->from(env('MAIL_FROM'))->subject('First email test')->view('mail.c2c-1');
} catch (\Exception $e) {
\Log::error($e->getMessage());
}
}
所以这一切都很好,但是我无法进行单元测试以将数据传递给可邮寄的构造函数。
测试用例
public function testC2cEmailSend()
{
Mail::fake();
// Grab any old C2C entry
$c2c = \App\Commitment::with(['module', 'user'])->first();
$data = $c2c->data;
$user = $c2c->user;
$module = $c2c->module;
$mailable_data = ['data' => $data, 'user' => $user, 'module' => $module];
Mail::assertSent(C2cFirst::class, function($mail) use ($mailable_data) {
return $mail->hasTo($mailable_data['user']->email);
});
}
答案 0 :(得分:0)
已解决
对于Mail::fake()
的实际工作方式存在误解。它劫持Mail
类,并用MailFake
的实例替换;因此将其置于所需功能之上会阻止实际发送。