mep
This commit is contained in:
parent
e958163a4a
commit
b8a5a1ff58
79 changed files with 15113 additions and 0 deletions
223
tests/Feature/Repository/OrderRepositoryTest.php
Normal file
223
tests/Feature/Repository/OrderRepositoryTest.php
Normal file
|
@ -0,0 +1,223 @@
|
|||
<?php
|
||||
|
||||
declare(strict_types=1);
|
||||
|
||||
namespace Tests\Feature\Repository;
|
||||
|
||||
use Override;
|
||||
use Tests\TestCase;
|
||||
use App\Entity\DrinkType;
|
||||
use App\Entity\Order;
|
||||
use App\Entity\OrderItem;
|
||||
use App\Repository\DrinkTypeRepository;
|
||||
use App\Repository\OrderRepository;
|
||||
use App\Repository\OrderItemRepository;
|
||||
use DateTimeImmutable;
|
||||
|
||||
class OrderRepositoryTest extends TestCase
|
||||
{
|
||||
private OrderRepository $repository;
|
||||
private DrinkTypeRepository $drinkTypeRepository;
|
||||
private OrderItemRepository $orderItemRepository;
|
||||
private DrinkType $drinkType;
|
||||
|
||||
#[Override]
|
||||
public function setUp(): void
|
||||
{
|
||||
parent::setUp();
|
||||
$this->setUpDB();
|
||||
$this->repository = $this->container->get(OrderRepository::class);
|
||||
$this->drinkTypeRepository = $this->container->get(DrinkTypeRepository::class);
|
||||
$this->orderItemRepository = $this->container->get(OrderItemRepository::class);
|
||||
|
||||
// Create a drink type for testing
|
||||
$this->drinkType = new DrinkType('Cola', 'Refreshing cola drink', 10);
|
||||
$this->drinkTypeRepository->save($this->drinkType);
|
||||
}
|
||||
|
||||
public function testFindAll(): void
|
||||
{
|
||||
// Initially the repository should be empty
|
||||
$this->assertCount(0, $this->repository->findAll());
|
||||
|
||||
// Create some orders
|
||||
$order1 = new Order(Order::STATUS_NEW, new DateTimeImmutable('2023-01-01'));
|
||||
$order2 = new Order(Order::STATUS_FULFILLED, new DateTimeImmutable('2023-01-02'));
|
||||
|
||||
// Save them to the repository
|
||||
$this->repository->save($order1);
|
||||
$this->repository->save($order2);
|
||||
|
||||
// Now findAll should return both orders
|
||||
$orders = $this->repository->findAll();
|
||||
$this->assertCount(2, $orders);
|
||||
$this->assertContainsOnlyInstancesOf(Order::class, $orders);
|
||||
}
|
||||
|
||||
public function testFind(): void
|
||||
{
|
||||
// Create an order
|
||||
$order = new Order(Order::STATUS_NEW, new DateTimeImmutable('2023-01-01'));
|
||||
$this->repository->save($order);
|
||||
|
||||
// Get the ID
|
||||
$id = $order->getId();
|
||||
$this->assertNotNull($id);
|
||||
|
||||
// Find by ID
|
||||
$foundOrder = $this->repository->find($id);
|
||||
$this->assertInstanceOf(Order::class, $foundOrder);
|
||||
$this->assertEquals(Order::STATUS_NEW, $foundOrder->getStatus());
|
||||
$this->assertEquals('2023-01-01', $foundOrder->getCreatedAt()->format('Y-m-d'));
|
||||
|
||||
// Try to find a non-existent ID
|
||||
$nonExistentId = 9999;
|
||||
$this->assertNull($this->repository->find($nonExistentId));
|
||||
}
|
||||
|
||||
public function testFindByStatus(): void
|
||||
{
|
||||
// Create orders with different statuses
|
||||
$order1 = new Order(Order::STATUS_NEW, new DateTimeImmutable('2023-01-01'));
|
||||
$order2 = new Order(Order::STATUS_IN_WORK, new DateTimeImmutable('2023-01-02'));
|
||||
$order3 = new Order(Order::STATUS_ORDERED, new DateTimeImmutable('2023-01-03'));
|
||||
$order4 = new Order(Order::STATUS_FULFILLED, new DateTimeImmutable('2023-01-04'));
|
||||
$order5 = new Order(Order::STATUS_NEW, new DateTimeImmutable('2023-01-05'));
|
||||
|
||||
// Save them to the repository
|
||||
$this->repository->save($order1);
|
||||
$this->repository->save($order2);
|
||||
$this->repository->save($order3);
|
||||
$this->repository->save($order4);
|
||||
$this->repository->save($order5);
|
||||
|
||||
// Find by status
|
||||
$newOrders = $this->repository->findByStatus(Order::STATUS_NEW);
|
||||
$this->assertCount(2, $newOrders);
|
||||
$this->assertContainsOnlyInstancesOf(Order::class, $newOrders);
|
||||
|
||||
// Check that the orders have the correct status
|
||||
foreach ($newOrders as $order) {
|
||||
$this->assertEquals(Order::STATUS_NEW, $order->getStatus());
|
||||
}
|
||||
|
||||
// Find by another status
|
||||
$fulfilledOrders = $this->repository->findByStatus(Order::STATUS_FULFILLED);
|
||||
$this->assertCount(1, $fulfilledOrders);
|
||||
$this->assertEquals(Order::STATUS_FULFILLED, $fulfilledOrders[0]->getStatus());
|
||||
}
|
||||
|
||||
public function testFindByDateRange(): void
|
||||
{
|
||||
// Create orders with different dates
|
||||
$order1 = new Order(Order::STATUS_NEW, new DateTimeImmutable('2023-01-01'));
|
||||
$order2 = new Order(Order::STATUS_NEW, new DateTimeImmutable('2023-01-02'));
|
||||
$order3 = new Order(Order::STATUS_NEW, new DateTimeImmutable('2023-01-03'));
|
||||
$order4 = new Order(Order::STATUS_NEW, new DateTimeImmutable('2023-01-04'));
|
||||
$order5 = new Order(Order::STATUS_NEW, new DateTimeImmutable('2023-01-05'));
|
||||
|
||||
// Save them to the repository
|
||||
$this->repository->save($order1);
|
||||
$this->repository->save($order2);
|
||||
$this->repository->save($order3);
|
||||
$this->repository->save($order4);
|
||||
$this->repository->save($order5);
|
||||
|
||||
// Find orders in a specific date range
|
||||
$start = new DateTimeImmutable('2023-01-02');
|
||||
$end = new DateTimeImmutable('2023-01-04');
|
||||
$orders = $this->repository->findByDateRange($start, $end);
|
||||
|
||||
$this->assertCount(3, $orders);
|
||||
|
||||
// Check that the orders are within the date range
|
||||
foreach ($orders as $order) {
|
||||
$createdAt = $order->getCreatedAt();
|
||||
$this->assertTrue($createdAt >= $start && $createdAt <= $end);
|
||||
}
|
||||
}
|
||||
|
||||
public function testFindLastOrdersForDrinkType(): void
|
||||
{
|
||||
// Create orders with different dates
|
||||
$order1 = new Order(Order::STATUS_FULFILLED, new DateTimeImmutable('2023-01-01'));
|
||||
$order2 = new Order(Order::STATUS_FULFILLED, new DateTimeImmutable('2023-01-02'));
|
||||
$order3 = new Order(Order::STATUS_FULFILLED, new DateTimeImmutable('2023-01-03'));
|
||||
$order4 = new Order(Order::STATUS_FULFILLED, new DateTimeImmutable('2023-01-04'));
|
||||
$order5 = new Order(Order::STATUS_FULFILLED, new DateTimeImmutable('2023-01-05'));
|
||||
|
||||
// Save them to the repository
|
||||
$this->repository->save($order1);
|
||||
$this->repository->save($order2);
|
||||
$this->repository->save($order3);
|
||||
$this->repository->save($order4);
|
||||
$this->repository->save($order5);
|
||||
|
||||
// Create order items for the drink type
|
||||
$orderItem1 = new OrderItem($this->drinkType, 5, $order1);
|
||||
$orderItem2 = new OrderItem($this->drinkType, 10, $order2);
|
||||
$orderItem3 = new OrderItem($this->drinkType, 15, $order3);
|
||||
$orderItem4 = new OrderItem($this->drinkType, 20, $order4);
|
||||
$orderItem5 = new OrderItem($this->drinkType, 25, $order5);
|
||||
|
||||
// Save them to the repository
|
||||
$this->orderItemRepository->save($orderItem1);
|
||||
$this->orderItemRepository->save($orderItem2);
|
||||
$this->orderItemRepository->save($orderItem3);
|
||||
$this->orderItemRepository->save($orderItem4);
|
||||
$this->orderItemRepository->save($orderItem5);
|
||||
|
||||
// Find the last 3 orders for the drink type
|
||||
$orders = $this->repository->findLastOrdersForDrinkType($this->drinkType, 3);
|
||||
|
||||
$this->assertCount(3, $orders);
|
||||
|
||||
// Check that the orders are the most recent ones
|
||||
$this->assertEquals('2023-01-05', $orders[0]->getCreatedAt()->format('Y-m-d'));
|
||||
$this->assertEquals('2023-01-04', $orders[1]->getCreatedAt()->format('Y-m-d'));
|
||||
$this->assertEquals('2023-01-03', $orders[2]->getCreatedAt()->format('Y-m-d'));
|
||||
}
|
||||
|
||||
public function testSave(): void
|
||||
{
|
||||
// Create an order
|
||||
$order = new Order(Order::STATUS_NEW, new DateTimeImmutable('2023-01-01'));
|
||||
|
||||
// Save it
|
||||
$this->repository->save($order);
|
||||
|
||||
// Check that it was saved
|
||||
$id = $order->getId();
|
||||
$this->assertNotNull($id);
|
||||
|
||||
// Find it by ID to confirm it's in the database
|
||||
$foundOrder = $this->repository->find($id);
|
||||
$this->assertInstanceOf(Order::class, $foundOrder);
|
||||
$this->assertEquals(Order::STATUS_NEW, $foundOrder->getStatus());
|
||||
|
||||
// Update it
|
||||
$order->setStatus(Order::STATUS_IN_WORK);
|
||||
$this->repository->save($order);
|
||||
|
||||
// Find it again to confirm the update
|
||||
$foundOrder = $this->repository->find($id);
|
||||
$this->assertEquals(Order::STATUS_IN_WORK, $foundOrder->getStatus());
|
||||
}
|
||||
|
||||
public function testRemove(): void
|
||||
{
|
||||
// Create an order
|
||||
$order = new Order(Order::STATUS_NEW, new DateTimeImmutable('2023-01-01'));
|
||||
$this->repository->save($order);
|
||||
|
||||
// Get the ID
|
||||
$id = $order->getId();
|
||||
$this->assertNotNull($id);
|
||||
|
||||
// Remove it
|
||||
$this->repository->remove($order);
|
||||
|
||||
// Try to find it by ID to confirm it's gone
|
||||
$this->assertNull($this->repository->find($id));
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue