mirror of
https://github.com/snipe/snipe-it.git
synced 2024-11-12 16:44:08 -08:00
Updated tests
Signed-off-by: snipe <snipe@snipe.net>
This commit is contained in:
parent
f56006fb6b
commit
2f0c74aef0
|
@ -35,33 +35,42 @@ class AccessoryCheckoutTest extends TestCase
|
||||||
])
|
])
|
||||||
->assertOk()
|
->assertOk()
|
||||||
->assertStatusMessageIs('error')
|
->assertStatusMessageIs('error')
|
||||||
->assertJson([
|
->assertJson(
|
||||||
'messages' => [
|
[
|
||||||
'assigned_to' => ['The assigned to field must be an integer.'],
|
'status' => 'error',
|
||||||
|
'messages' =>
|
||||||
|
[
|
||||||
|
'checkout_qty' =>
|
||||||
|
[
|
||||||
|
trans_choice('admin/accessories/message.checkout.checkout_qty.lte', 0,
|
||||||
|
[
|
||||||
|
'number_currently_remaining' => 0,
|
||||||
|
'checkout_qty' => 1,
|
||||||
|
'number_remaining_after_checkout' => 0
|
||||||
|
])
|
||||||
],
|
],
|
||||||
|
|
||||||
|
],
|
||||||
|
'payload' => null,
|
||||||
])
|
])
|
||||||
->assertStatus(200)
|
->assertStatus(200)
|
||||||
->json();
|
->json();
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testAccessoryCanBeCheckedOut()
|
public function testAccessoryCanBeCheckedOutWithoutQty()
|
||||||
{
|
{
|
||||||
$accessory = Accessory::factory()->create();
|
$accessory = Accessory::factory()->create();
|
||||||
$user = User::factory()->create();
|
$user = User::factory()->create();
|
||||||
$admin = User::factory()->checkoutAccessories()->create();
|
$admin = User::factory()->checkoutAccessories()->create();
|
||||||
|
|
||||||
$this->actingAsForApi(User::factory()->checkoutAccessories()->create())
|
$this->actingAsForApi($admin)
|
||||||
->postJson(route('api.accessories.checkout', $accessory), [
|
->postJson(route('api.accessories.checkout', $accessory), [
|
||||||
'assigned_to' => $user->id,
|
'assigned_to' => $user->id,
|
||||||
])
|
])
|
||||||
->assertOk()
|
->assertOk()
|
||||||
->assertStatusMessageIs('success')
|
->assertStatusMessageIs('success')
|
||||||
->assertStatus(200)
|
->assertStatus(200)
|
||||||
->assertJson([
|
->assertJson(['messages' => trans('admin/accessories/message.checkout.success')])
|
||||||
'messages' => [
|
|
||||||
'assigned_to' => ['Accessory checked out successfully.'],
|
|
||||||
],
|
|
||||||
])
|
|
||||||
->json();
|
->json();
|
||||||
|
|
||||||
$this->assertTrue($accessory->users->contains($user));
|
$this->assertTrue($accessory->users->contains($user));
|
||||||
|
@ -75,9 +84,7 @@ class AccessoryCheckoutTest extends TestCase
|
||||||
'item_id' => $accessory->id,
|
'item_id' => $accessory->id,
|
||||||
'item_type' => Accessory::class,
|
'item_type' => Accessory::class,
|
||||||
'user_id' => $admin->id,
|
'user_id' => $admin->id,
|
||||||
'note' => 'oh hi there',
|
])->count(),'Log entry either does not exist or there are more than expected'
|
||||||
])->count(),
|
|
||||||
'Log entry either does not exist or there are more than expected'
|
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -87,7 +94,7 @@ class AccessoryCheckoutTest extends TestCase
|
||||||
$user = User::factory()->create();
|
$user = User::factory()->create();
|
||||||
$admin = User::factory()->checkoutAccessories()->create();
|
$admin = User::factory()->checkoutAccessories()->create();
|
||||||
|
|
||||||
$this->actingAsForApi(User::factory()->checkoutAccessories()->create())
|
$this->actingAsForApi($admin)
|
||||||
->postJson(route('api.accessories.checkout', $accessory), [
|
->postJson(route('api.accessories.checkout', $accessory), [
|
||||||
'assigned_to' => $user->id,
|
'assigned_to' => $user->id,
|
||||||
'checkout_qty' => 2,
|
'checkout_qty' => 2,
|
||||||
|
@ -95,11 +102,7 @@ class AccessoryCheckoutTest extends TestCase
|
||||||
->assertOk()
|
->assertOk()
|
||||||
->assertStatusMessageIs('success')
|
->assertStatusMessageIs('success')
|
||||||
->assertStatus(200)
|
->assertStatus(200)
|
||||||
->assertJson([
|
->assertJson(['messages' => trans('admin/accessories/message.checkout.success')])
|
||||||
'messages' => [
|
|
||||||
'assigned_to' => ['The assigned to field must be an integer.'],
|
|
||||||
],
|
|
||||||
])
|
|
||||||
->json();
|
->json();
|
||||||
|
|
||||||
$this->assertTrue($accessory->users->contains($user));
|
$this->assertTrue($accessory->users->contains($user));
|
||||||
|
@ -113,7 +116,6 @@ class AccessoryCheckoutTest extends TestCase
|
||||||
'item_id' => $accessory->id,
|
'item_id' => $accessory->id,
|
||||||
'item_type' => Accessory::class,
|
'item_type' => Accessory::class,
|
||||||
'user_id' => $admin->id,
|
'user_id' => $admin->id,
|
||||||
'note' => 'oh hi there',
|
|
||||||
])->count(),
|
])->count(),
|
||||||
'Log entry either does not exist or there are more than expected'
|
'Log entry either does not exist or there are more than expected'
|
||||||
);
|
);
|
||||||
|
@ -131,15 +133,10 @@ class AccessoryCheckoutTest extends TestCase
|
||||||
])
|
])
|
||||||
->assertOk()
|
->assertOk()
|
||||||
->assertStatusMessageIs('error')
|
->assertStatusMessageIs('error')
|
||||||
->assertJson([
|
|
||||||
'messages' => [
|
|
||||||
'assigned_to' => ['The assigned to field must be an integer.'],
|
|
||||||
],
|
|
||||||
])
|
|
||||||
->assertStatus(200)
|
->assertStatus(200)
|
||||||
->json();
|
->json();
|
||||||
|
|
||||||
$this->assertTrue($accessory->users->contains($user));
|
$this->assertFalse($accessory->users->contains($user));
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testUserSentNotificationUponCheckout()
|
public function testUserSentNotificationUponCheckout()
|
||||||
|
|
|
@ -20,23 +20,33 @@ class AccessoryCheckoutTest extends TestCase
|
||||||
|
|
||||||
public function testValidationWhenCheckingOutAccessory()
|
public function testValidationWhenCheckingOutAccessory()
|
||||||
{
|
{
|
||||||
$this->actingAs(User::factory()->checkoutAccessories()->create())
|
$accessory = Accessory::factory()->create();
|
||||||
->post(route('accessories.checkout.store', Accessory::factory()->create()), [
|
$response = $this->actingAs(User::factory()->superuser()->create())
|
||||||
|
->post(route('accessories.checkout.store', $accessory), [
|
||||||
// missing assigned_to
|
// missing assigned_to
|
||||||
])
|
])
|
||||||
->assertSessionHas('error');
|
->assertStatus(302)
|
||||||
|
->assertSessionHas('errors')
|
||||||
|
->assertRedirect(route('accessories.checkout.store', $accessory));
|
||||||
|
|
||||||
|
$this->followRedirects($response)->assertSee(trans('general.error'));
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testAccessoryMustBeAvailableWhenCheckingOut()
|
public function testAccessoryMustBeAvailableWhenCheckingOut()
|
||||||
{
|
{
|
||||||
$this->actingAs(User::factory()->checkoutAccessories()->create())
|
|
||||||
|
$response = $this->actingAs(User::factory()->viewAccessories()->checkoutAccessories()->create())
|
||||||
->post(route('accessories.checkout.store', Accessory::factory()->withoutItemsRemaining()->create()), [
|
->post(route('accessories.checkout.store', Accessory::factory()->withoutItemsRemaining()->create()), [
|
||||||
'assigned_to' => User::factory()->create()->id,
|
'assigned_to' => User::factory()->create()->id,
|
||||||
])
|
])
|
||||||
->assertSessionHas('error');
|
->assertStatus(302)
|
||||||
|
->assertSessionHas('error')
|
||||||
|
->assertRedirect(route('accessories.index'));
|
||||||
|
|
||||||
|
$this->followRedirects($response)->assertSee(trans('general.error'));
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testAccessoryCanBeCheckedOut()
|
public function testAccessoryCanBeCheckedOutWithoutQuantity()
|
||||||
{
|
{
|
||||||
$accessory = Accessory::factory()->create();
|
$accessory = Accessory::factory()->create();
|
||||||
$user = User::factory()->create();
|
$user = User::factory()->create();
|
||||||
|
@ -44,9 +54,43 @@ class AccessoryCheckoutTest extends TestCase
|
||||||
$this->actingAs(User::factory()->checkoutAccessories()->create())
|
$this->actingAs(User::factory()->checkoutAccessories()->create())
|
||||||
->post(route('accessories.checkout.store', $accessory), [
|
->post(route('accessories.checkout.store', $accessory), [
|
||||||
'assigned_to' => $user->id,
|
'assigned_to' => $user->id,
|
||||||
|
'note' => 'oh hi there',
|
||||||
]);
|
]);
|
||||||
|
|
||||||
$this->assertTrue($accessory->users->contains($user));
|
$this->assertTrue($accessory->users->contains($user));
|
||||||
|
|
||||||
|
$this->assertDatabaseHas('action_logs', [
|
||||||
|
'action_type' => 'checkout',
|
||||||
|
'target_id' => $user->id,
|
||||||
|
'target_type' => User::class,
|
||||||
|
'item_id' => $accessory->id,
|
||||||
|
'item_type' => Accessory::class,
|
||||||
|
'note' => 'oh hi there',
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testAccessoryCanBeCheckedOutWithQuantity()
|
||||||
|
{
|
||||||
|
$accessory = Accessory::factory()->count(5)->create();
|
||||||
|
$user = User::factory()->create();
|
||||||
|
|
||||||
|
$this->actingAs(User::factory()->checkoutAccessories()->create())
|
||||||
|
->post(route('accessories.checkout.store', $accessory), [
|
||||||
|
'assigned_to' => $user->id,
|
||||||
|
'checkout_qty' => 3,
|
||||||
|
'note' => 'oh hi there',
|
||||||
|
]);
|
||||||
|
|
||||||
|
$this->assertTrue($accessory->users->contains($user));
|
||||||
|
|
||||||
|
$this->assertDatabaseHas('action_logs', [
|
||||||
|
'action_type' => 'checkout',
|
||||||
|
'target_id' => $user->id,
|
||||||
|
'target_type' => User::class,
|
||||||
|
'item_id' => $accessory->id,
|
||||||
|
'item_type' => Accessory::class,
|
||||||
|
'note' => 'oh hi there',
|
||||||
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testUserSentNotificationUponCheckout()
|
public function testUserSentNotificationUponCheckout()
|
||||||
|
|
Loading…
Reference in a new issue