Skip to content

Commit 872b76b

Browse files
committed
Add tests for delete asset maintenance endpoint
1 parent 275cf46 commit 872b76b

File tree

1 file changed

+68
-0
lines changed

1 file changed

+68
-0
lines changed
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,68 @@
1+
<?php
2+
3+
namespace Tests\Feature\AssetMaintenances\Api;
4+
5+
use App\Models\AssetMaintenance;
6+
use App\Models\Company;
7+
use App\Models\User;
8+
use Tests\Concerns\TestsMultipleFullCompanySupport;
9+
use Tests\Concerns\TestsPermissionsRequirement;
10+
use Tests\TestCase;
11+
12+
class DeleteAssetMaintenanceTest extends TestCase implements TestsMultipleFullCompanySupport, TestsPermissionsRequirement
13+
{
14+
public function testRequiresPermission()
15+
{
16+
$assetMaintenance = AssetMaintenance::factory()->create();
17+
18+
$this->actingAsForApi(User::factory()->create())
19+
->deleteJson(route('api.maintenances.destroy', $assetMaintenance))
20+
->assertForbidden();
21+
}
22+
23+
public function testCanDeleteAssetMaintenance()
24+
{
25+
$assetMaintenance = AssetMaintenance::factory()->create();
26+
27+
$this->actingAsForApi(User::factory()->editAssets()->create())
28+
->deleteJson(route('api.maintenances.destroy', $assetMaintenance))
29+
->assertStatusMessageIs('success');
30+
31+
$this->assertTrue($assetMaintenance->fresh()->trashed());
32+
}
33+
34+
public function testAdheresToMultipleFullCompanySupportScoping()
35+
{
36+
[$companyA, $companyB] = Company::factory()->count(2)->create();
37+
38+
$assetMaintenanceA = AssetMaintenance::factory()->create();
39+
$assetMaintenanceB = AssetMaintenance::factory()->create();
40+
$assetMaintenanceC = AssetMaintenance::factory()->create();
41+
42+
$assetMaintenanceA->asset->update(['company_id' => $companyA->id]);
43+
$assetMaintenanceB->asset->update(['company_id' => $companyB->id]);
44+
$assetMaintenanceC->asset->update(['company_id' => $companyB->id]);
45+
46+
$superUser = $companyA->users()->save(User::factory()->superuser()->make());
47+
$userInCompanyA = $companyA->users()->save(User::factory()->editAssets()->make());
48+
$userInCompanyB = $companyB->users()->save(User::factory()->editAssets()->make());
49+
50+
$this->settings->enableMultipleFullCompanySupport();
51+
52+
$this->actingAsForApi($userInCompanyA)
53+
->deleteJson(route('api.maintenances.destroy', $assetMaintenanceB))
54+
->assertStatusMessageIs('error');
55+
56+
$this->actingAsForApi($userInCompanyB)
57+
->deleteJson(route('api.maintenances.destroy', $assetMaintenanceA))
58+
->assertStatusMessageIs('error');
59+
60+
$this->actingAsForApi($superUser)
61+
->deleteJson(route('api.maintenances.destroy', $assetMaintenanceC))
62+
->assertStatusMessageIs('success');
63+
64+
$this->assertNull($assetMaintenanceA->fresh()->deleted_at, 'Asset Maintenance unexpectedly deleted');
65+
$this->assertNull($assetMaintenanceB->fresh()->deleted_at, 'Asset Maintenance unexpectedly deleted');
66+
$this->assertNotNull($assetMaintenanceC->fresh()->deleted_at, 'Asset Maintenance was not deleted');
67+
}
68+
}

0 commit comments

Comments
 (0)