Merge pull request #15470 from marcusmoore/company_tests

Added UI tests for creating companies
This commit is contained in:
snipe 2024-09-10 11:04:08 +01:00 committed by GitHub
commit e7e5dfbdfa
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
2 changed files with 65 additions and 0 deletions

View file

@ -241,6 +241,11 @@ class UserFactory extends Factory
return $this->appendPermission(['components.view' => '1']);
}
public function createCompanies()
{
return $this->appendPermission(['companies.create' => '1']);
}
public function createComponents()
{
return $this->appendPermission(['components.create' => '1']);

View file

@ -0,0 +1,60 @@
<?php
namespace Tests\Feature\Companies\Ui;
use App\Models\User;
use Tests\TestCase;
class CreateCompaniesTest extends TestCase
{
public function testRequiresPermissionToViewCreateCompanyPage()
{
$this->actingAs(User::factory()->create())
->get(route('companies.create'))
->assertForbidden();
}
public function testCreateCompanyPageRenders()
{
$this->actingAs(User::factory()->createCompanies()->create())
->get(route('companies.create'))
->assertOk()
->assertViewIs('companies.edit');
}
public function testRequiresPermissionToCreateCompany()
{
$this->actingAs(User::factory()->create())
->post(route('companies.store'))
->assertForbidden();
}
public function testValidDataRequiredToCreateCompany()
{
$this->actingAs(User::factory()->createCompanies()->create())
->post(route('companies.store'), [
//
])
->assertSessionHasErrors([
'name',
]);
}
public function testCanCreateCompany()
{
$data = [
'email' => 'email@example.com',
'fax' => '619-666-6666',
'name' => 'My New Company',
'phone' => '619-555-5555',
];
$user = User::factory()->createCompanies()->create();
$this->actingAs($user)
->post(route('companies.store'), array_merge($data, ['redirect_option' => 'index']))
->assertRedirect(route('companies.index'));
$this->assertDatabaseHas('companies', array_merge($data));
}
}