Laravel 5.6:assertSessionHasErrors导致“违反完整性约束:19 NOT NULL约束失败”错误

时间:2019-03-05 13:50:30

标签: php laravel testing laravel-5.6 laravel-testing

我正在尝试建立一个测试,以检查不完整的表单不能提交到数据库,并且不断遇到问题,目前每次运行phpunit时,这就是我得到的:

enter image description here

我的测试设置如下:

public function test_incomplete_form_cannot_be_submitted()
{
  $user = factory(User::class)->states('confirmed', 'normaluser')->create([
      'id' => '1',
  ]);
  $form = factory(Form::class)->states('incomplete')->create(['status' => 'submitted', 'user_id' => '1', 'id' => '5',]);

  $this->actingAs($user)->post(route('forms.store'), $form->toArray());

  $this->assertSessionHasErrors(['company_name', 'form_info', 'uploads', 'state']);
}

设置不完整表格的工厂如下:

 $factory->state(App\Form::class, 'incomplete', function (Faker $faker) {
  return [
    'company_name' => null,
    'form_info' => [
      'contact_fname' => null,
      'contact_lname' => null,
      'address1' => null,
      'dist_city' => null,
      'zip_code' => null,
      'multiple_locations' => null,
      'dist_phone' => null,
      'dist_email' => null,
      'company_website' => null,
      'additional_company_info' => null,
      'company_ownership_structure' => null,
      'business_manager' => [
        '0' => [
          'title' => null,
          'name' => null,
          'phone' => null,
          'email' => null,
        ],
      ],
      'business_planner' => [
        '0' => [
          'title' => null,
          'name' => null,
          'phone' => null,
          'email' => null,
        ],
      ],
      'sales_rep_compensation' => null,
      'midlevel_manager_compensation' => null,
      'sales_state' => null,
      'county' => [
        '0' => null,
      ],
      'split_county' => null,
      'split_county_details' => null,
      'other_brands_represented' => [
        '0' => null,
      ],
      'other_brands_in_territory' => null,
      'company_sales_approach' => null,
      'vision_for_us' => null,
      'who_purchases_the_beer' => null,
      'anticipated_spending_details' => null,
      'what_other_products' => null,
      'chain_retail_coverage' => null,
      'total_size' => null,
      'last_full_year_sales_for_craft' => null,
      'other_breweries_pursue' => null,
      'describe_packaged_beer_space' => null,
      'describe_cooler_space' => null,
      'firkin_handling_procedures' => null,
      'secure_storage' => null,
      'describe_recoup_area' => null,
      'describe_trucks' => null,
      'pos_storage_areas' => null,
      'quality_policies' => null,
      'product_rotation_systems' => null,
      'draft_department_capabilities' => null,
      'channel_focus' => null,
      'channel_focus_details' => null,
      'in_house_signs' => null,
      'sign_printers' => null,
      'sign_shop_employees' => null,
      'other_ownership' => null,
      'other_ownership_details' => null,
    ],
    'state' => 'Alabama',
    'uploads' => [
      'top_25_accounts' => null,
      'first_year_sales_estimate' => null,
      'packaging_space_images' => [
        '0' => null,
      ],
      'storage_images' => [
        '0' => null,
      ],
      'marketing_signage' => [
        '0' => null,
      ],
    ],
  ];
});

我已经尝试将测试从工厂...->创建更改为工厂...-> make,修改assertSessionHasErrors以仅检查['uploads.top_25_accounts'],并使$ form只是一个空数组,但似乎没有任何效果。

1 个答案:

答案 0 :(得分:0)

问题1:

因为工厂上的create()试图在数据库中创建新条目,所以永远不会到达您的断言,但是company_name不能为NULL,并且会引发异常。

解决方案:

create()更改为make()

$form = factory(Form::class)->states('incomplete')->make([
    'status' => 'submitted', 
    'user_id' => '1', 
    'id' => '5',
]);


问题2:

您必须在响应对象上调用assertSessionHasErrors()$this->assertSessionHasErrors)不存在。

解决方案:

public function test_incomplete_form_cannot_be_submitted()
{
  $user = factory(User::class)->states('confirmed', 'normaluser')->create([
      'id' => '1',
  ]);
  $form = factory(Form::class)->states('incomplete')->make([
      'status' => 'submitted', 
      'user_id' => '1', 
      'id' => '5',
  ]);

  $response = $this->actingAs($user)->post(route('forms.store'), $form->toArray());

  $response->assertSessionHasErrors(['company_name', 'form_info', 'uploads', 'state']);
}