mirror of
https://github.com/snipe/snipe-it.git
synced 2025-01-19 09:41:30 -08:00
Merge pull request #15864 from marcusmoore/testing/api-component-checkout
Added tests for component checkout api endpoint
This commit is contained in:
commit
e05f443886
140
tests/Feature/Checkouts/Api/ComponentCheckoutTest.php
Normal file
140
tests/Feature/Checkouts/Api/ComponentCheckoutTest.php
Normal file
|
@ -0,0 +1,140 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Tests\Feature\Checkouts\Api;
|
||||||
|
|
||||||
|
use App\Models\Asset;
|
||||||
|
use App\Models\Company;
|
||||||
|
use App\Models\Component;
|
||||||
|
use App\Models\Location;
|
||||||
|
use App\Models\User;
|
||||||
|
use Carbon\Carbon;
|
||||||
|
use Tests\Concerns\TestsFullMultipleCompaniesSupport;
|
||||||
|
use Tests\Concerns\TestsPermissionsRequirement;
|
||||||
|
use Tests\TestCase;
|
||||||
|
|
||||||
|
class ComponentCheckoutTest extends TestCase implements TestsFullMultipleCompaniesSupport, TestsPermissionsRequirement
|
||||||
|
{
|
||||||
|
public function testRequiresPermission()
|
||||||
|
{
|
||||||
|
$component = Component::factory()->create();
|
||||||
|
|
||||||
|
$this->actingAsForApi(User::factory()->create())
|
||||||
|
->postJson(route('api.components.checkout', $component->id))
|
||||||
|
->assertForbidden();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testCannotCheckoutNonExistentComponent()
|
||||||
|
{
|
||||||
|
$this->actingAsForApi(User::factory()->checkoutComponents()->create())
|
||||||
|
->postJson(route('api.components.checkout', 1000))
|
||||||
|
->assertOk()
|
||||||
|
->assertStatusMessageIs('error')
|
||||||
|
->assertMessagesAre('Component does not exist.');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testCheckingOutComponentRequiresValidFields()
|
||||||
|
{
|
||||||
|
$component = Component::factory()->create();
|
||||||
|
|
||||||
|
$this->actingAsForApi(User::factory()->checkoutComponents()->create())
|
||||||
|
->postJson(route('api.components.checkout', $component->id), [
|
||||||
|
//
|
||||||
|
])
|
||||||
|
->assertOk()
|
||||||
|
->assertStatusMessageIs('error')
|
||||||
|
->assertPayloadContains('assigned_to')
|
||||||
|
->assertPayloadContains('assigned_qty');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testCannotCheckoutComponentIfRequestedAmountIsMoreThanComponentQuantity()
|
||||||
|
{
|
||||||
|
$asset = Asset::factory()->create();
|
||||||
|
$component = Component::factory()->create(['qty' => 2]);
|
||||||
|
|
||||||
|
$this->actingAsForApi(User::factory()->checkoutComponents()->create())
|
||||||
|
->postJson(route('api.components.checkout', $component->id), [
|
||||||
|
'assigned_to' => $asset->id,
|
||||||
|
'assigned_qty' => 3,
|
||||||
|
])
|
||||||
|
->assertOk()
|
||||||
|
->assertStatusMessageIs('error')
|
||||||
|
->assertMessagesAre(trans('admin/components/message.checkout.unavailable', ['remaining' => 2, 'requested' => 3]));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testCannotCheckoutComponentIfRequestedAmountIsMoreThanWhatIsRemaining()
|
||||||
|
{
|
||||||
|
$asset = Asset::factory()->create();
|
||||||
|
$component = Component::factory()->create(['qty' => 2]);
|
||||||
|
$component->assets()->attach($component->id, [
|
||||||
|
'component_id' => $component->id,
|
||||||
|
'created_at' => Carbon::now(),
|
||||||
|
'assigned_qty' => 1,
|
||||||
|
'asset_id' => $asset->id,
|
||||||
|
]);
|
||||||
|
|
||||||
|
$this->actingAsForApi(User::factory()->checkoutComponents()->create())
|
||||||
|
->postJson(route('api.components.checkout', $component->id), [
|
||||||
|
'assigned_to' => $asset->id,
|
||||||
|
'assigned_qty' => 3,
|
||||||
|
])
|
||||||
|
->assertOk()
|
||||||
|
->assertStatusMessageIs('error');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testCanCheckoutComponent()
|
||||||
|
{
|
||||||
|
$user = User::factory()->checkoutComponents()->create();
|
||||||
|
$asset = Asset::factory()->create();
|
||||||
|
$component = Component::factory()->create();
|
||||||
|
|
||||||
|
$this->actingAsForApi($user)
|
||||||
|
->postJson(route('api.components.checkout', $component->id), [
|
||||||
|
'assigned_to' => $asset->id,
|
||||||
|
'assigned_qty' => 1,
|
||||||
|
])
|
||||||
|
->assertOk()
|
||||||
|
->assertStatusMessageIs('success');
|
||||||
|
|
||||||
|
$this->assertTrue($component->assets->first()->is($asset));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testComponentCheckoutIsLogged()
|
||||||
|
{
|
||||||
|
$user = User::factory()->checkoutComponents()->create();
|
||||||
|
$location = Location::factory()->create();
|
||||||
|
$asset = Asset::factory()->create(['location_id' => $location->id]);
|
||||||
|
$component = Component::factory()->create();
|
||||||
|
|
||||||
|
$this->actingAsForApi($user)
|
||||||
|
->postJson(route('api.components.checkout', $component->id), [
|
||||||
|
'assigned_to' => $asset->id,
|
||||||
|
'assigned_qty' => 1,
|
||||||
|
]);
|
||||||
|
|
||||||
|
$this->assertDatabaseHas('action_logs', [
|
||||||
|
'created_by' => $user->id,
|
||||||
|
'action_type' => 'checkout',
|
||||||
|
'target_id' => $asset->id,
|
||||||
|
'target_type' => Asset::class,
|
||||||
|
'location_id' => $location->id,
|
||||||
|
'item_type' => Component::class,
|
||||||
|
'item_id' => $component->id,
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testAdheresToFullMultipleCompaniesSupportScoping()
|
||||||
|
{
|
||||||
|
[$companyA, $companyB] = Company::factory()->count(2)->create();
|
||||||
|
|
||||||
|
$userForCompanyA = User::factory()->for($companyA)->create();
|
||||||
|
$assetForCompanyB = Asset::factory()->for($companyB)->create();
|
||||||
|
$componentForCompanyB = Component::factory()->for($companyB)->create();
|
||||||
|
|
||||||
|
$this->actingAsForApi($userForCompanyA)
|
||||||
|
->postJson(route('api.components.checkout', $componentForCompanyB->id), [
|
||||||
|
'assigned_to' => $assetForCompanyB->id,
|
||||||
|
'assigned_qty' => 1,
|
||||||
|
])
|
||||||
|
->assertForbidden();
|
||||||
|
}
|
||||||
|
}
|
|
@ -121,5 +121,26 @@ trait CustomTestMacros
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
|
TestResponse::macro(
|
||||||
|
'assertPayloadContains',
|
||||||
|
function (array|string $keys) {
|
||||||
|
Assert::assertArrayHasKey('payload', $this, 'Response did not contain a payload');
|
||||||
|
|
||||||
|
if (is_string($keys)) {
|
||||||
|
$keys = [$keys];
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach ($keys as $key) {
|
||||||
|
Assert::assertArrayHasKey(
|
||||||
|
$key,
|
||||||
|
$this['payload'],
|
||||||
|
"Response messages did not contain the key: {$key}"
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue