首页 > 解决方案 > 记录保存到laravel中的数据透视表的测试失败

问题描述

我有一个板模型和一个引脚模型,它们是多对多的。我正在测试以确保当创建一个引脚并分配一个板时,它会保存到数据透视表中。由于我是测试新手,因此我无法弄清楚这一点。

这是我的测试:

/** @test */
public function a_pin_can_belong_to_a_board()
{
    $board = create('App\Board');
    $pin = make('App\Pin');

    $response = $this->post('/pins/create', $pin->toArray());

    $pin->boards()->sync($board);

    $this->assertDatabaseHas('board_pin', [
        'board_id' => $board->id,
        'pin_id' => $pin->id
    ]);
}

这是我的错误:

1) Tests\Unit\PinTest::a_pin_can_belong_to_a_board
Illuminate\Database\QueryException: SQLSTATE[23000]: Integrity 
constraint violation: 19 NOT NULL constraint failed: board_pin.pin_id 
(SQL: insert into "board_pin" ("board_id", "pin_id") values (1, ))

Caused by
PDOException: SQLSTATE[23000]: Integrity constraint violation: 19 NOT 
NULL constraint failed: board_pin.pin_id

这是我的控制器:

public function store(Request $request)
{
    $this->validate($request, [
        'title' => 'required|max:200',
        'link' => 'required|max:255'
    ]);

    $pin = new Pin();

    $pin->title = $request->title;
    $pin->link = $request->link;
    $pin->user_id = auth()->id();

    $pin->save();

    $pin->boards()->sync($request->boards);

    return redirect("/pins/{$pin->id}");
}

任何帮助将不胜感激!谢谢!

标签: phplaraveltestingeloquentphpunit

解决方案


这是答案!我不只是在 pin 实例上使用 make 方法,而是使用 create 方法并将其持久化到数据库中,然后删除了 post 操作。见下文:

/** @test */
public function a_pin_can_belong_to_a_board()
{
    $board = create('App\Board');
    $pin = create('App\Pin');

    $pin->boards()->sync($board);

    $this->assertDatabaseHas('board_pin', [
        'board_id' => $board->id,
        'pin_id' => $pin->id
    ]);
}

推荐阅读