snipe-it/tests/Feature/AssetModels/Api/CreateAssetModelsTest.php
snipe 318aff1ef0 Fixed behavior for null model numbers
Signed-off-by: snipe <snipe@snipe.net>
2024-08-17 00:27:44 +01:00

105 lines
3.4 KiB
PHP

<?php
namespace Tests\Feature\AssetModels\Api;
use App\Models\AssetModel;
use App\Models\Category;
use App\Models\User;
use Illuminate\Testing\Fluent\AssertableJson;
use Tests\TestCase;
class CreateAssetModelsTest extends TestCase
{
public function testRequiresPermissionToCreateAssetModel()
{
$this->actingAsForApi(User::factory()->create())
->postJson(route('api.models.store'))
->assertForbidden();
}
public function testCanCreateAssetModelWithAssetModelType()
{
$response = $this->actingAsForApi(User::factory()->superuser()->create())
->postJson(route('api.models.store'), [
'name' => 'Test AssetModel',
'category_id' => Category::factory()->assetLaptopCategory()->create()->id
])
->assertOk()
->assertStatusMessageIs('success')
->assertStatus(200)
->json();
$this->assertTrue(AssetModel::where('name', 'Test AssetModel')->exists());
$model = AssetModel::find($response['payload']['id']);
$this->assertEquals('Test AssetModel', $model->name);
}
public function testCannotCreateAssetModelWithoutCategory()
{
$response = $this->actingAsForApi(User::factory()->superuser()->create())
->postJson(route('api.models.store'), [
'name' => 'Test AssetModel',
])
->assertStatus(200)
->assertOk()
->assertStatusMessageIs('error')
->assertJson([
'messages' => [
'category_id' => ['The category id field is required.'],
],
])
->json();
$this->assertFalse(AssetModel::where('name', 'Test AssetModel')->exists());
}
public function testUniquenessAcrossModelNameAndModelNumber()
{
AssetModel::factory()->create(['name' => 'Test Model', 'model_number'=>'1234']);
$this->actingAsForApi(User::factory()->superuser()->create())
->postJson(route('api.models.store'), [
'name' => 'Test Model',
'model_number' => '1234',
'category_id' => Category::factory()->assetLaptopCategory()->create()->id
])
->assertStatus(200)
->assertOk()
->assertStatusMessageIs('error')
->assertJson([
'messages' => [
'name' => ['The name must be unique across models and model number. '],
'model_number' => ['The model number must be unique across models and name. '],
],
])
->json();
}
public function testUniquenessAcrossModelNameAndModelNumberWithBlankModelNumber()
{
AssetModel::factory()->create(['name' => 'Test Model']);
$this->actingAsForApi(User::factory()->superuser()->create())
->postJson(route('api.models.store'), [
'name' => 'Test Model',
'category_id' => Category::factory()->assetLaptopCategory()->create()->id
])
->assertStatus(200)
->assertOk()
->assertStatusMessageIs('error')
->assertJson([
'messages' => [
'name' => ['The name must be unique across models and model number. '],
],
])
->json();
}
}