From d275a0f6b8a3d10a48bacd6d17ff9196300dbef1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=C5=81ukasz=20Chru=C5=9Bciel?= Date: Mon, 29 Jul 2024 15:01:57 +0200 Subject: [PATCH] [Maintenance] MIgrate to attributes on class definition --- test/app/AppKernel.php | 4 +-- test/app/config/doctrine/Category.orm.yml | 26 ---------------- test/app/config/doctrine/Product.orm.yml | 16 ---------- test/src/Entity/Category.php | 38 ++++++++++++++++++----- test/src/Entity/Product.php | 27 +++++++++------- 5 files changed, 47 insertions(+), 64 deletions(-) delete mode 100644 test/app/config/doctrine/Category.orm.yml delete mode 100644 test/app/config/doctrine/Product.orm.yml diff --git a/test/app/AppKernel.php b/test/app/AppKernel.php index 587b4d5..9b96b51 100644 --- a/test/app/AppKernel.php +++ b/test/app/AppKernel.php @@ -65,11 +65,11 @@ public function registerContainerConfiguration(LoaderInterface $loader) 'auto_mapping' => false, 'mappings' => [ 'ApiTestCase' => [ - 'dir' => '%kernel.project_dir%/app/config/doctrine', + 'dir' => '%kernel.project_dir%/src/Entity', 'prefix' => 'ApiTestCase\Test\Entity', 'alias' => 'ApiTestCase', 'is_bundle' => false, - 'type' => 'yml', + 'type' => 'attribute', ], ], ], diff --git a/test/app/config/doctrine/Category.orm.yml b/test/app/config/doctrine/Category.orm.yml deleted file mode 100644 index 43d206a..0000000 --- a/test/app/config/doctrine/Category.orm.yml +++ /dev/null @@ -1,26 +0,0 @@ -ApiTestCase\Test\Entity\Category: - type: entity - table: test_category - id: - id: - type: integer - id: true - generator: - strategy: AUTO - fields: - name: - type: string - manyToMany: - products: - targetEntity: ApiTestCase\Test\Entity\Product - cascade: ["all"] - joinTable: - name: app_category_products - joinColumns: - category_id: - referencedColumnName: id - onDelete: "cascade" - inverseJoinColumns: - product_id: - referencedColumnName: id - onDelete: "cascade" diff --git a/test/app/config/doctrine/Product.orm.yml b/test/app/config/doctrine/Product.orm.yml deleted file mode 100644 index 01be61e..0000000 --- a/test/app/config/doctrine/Product.orm.yml +++ /dev/null @@ -1,16 +0,0 @@ -ApiTestCase\Test\Entity\Product: - type: entity - table: test_product - id: - id: - type: integer - id: true - generator: - strategy: AUTO - fields: - name: - type: string - price: - type: integer - uuid: - type: string diff --git a/test/src/Entity/Category.php b/test/src/Entity/Category.php index 41c0eb6..ab95405 100644 --- a/test/src/Entity/Category.php +++ b/test/src/Entity/Category.php @@ -15,17 +15,39 @@ use Doctrine\Common\Collections\ArrayCollection; use Doctrine\Common\Collections\Collection; +use Doctrine\ORM\Mapping as ORM; +#[ORM\Entity] +#[ORM\Table(name: "test_category")] class Category { - /** @var int|null */ - private $id; + #[ORM\Id] + #[ORM\Column(type: "integer")] + #[ORM\GeneratedValue(strategy: "AUTO")] + private ?int $id; - /** @var string */ - private $name; + #[ORM\Column(type: "string")] + private string $name; - /** @var Collection|Product[] */ - private $products; + #[ORM\ManyToMany(targetEntity: Product::class, cascade: ["all"])] + #[ORM\JoinTable( + name: "app_category_products", + joinColumns: [ + new ORM\JoinColumn( + name: "category_id", + referencedColumnName: "id", + onDelete: "cascade" + ) + ], + inverseJoinColumns: [ + new ORM\JoinColumn( + name: "product_id", + referencedColumnName: "id", + onDelete: "cascade" + ) + ] + )] + private Collection $products; public function __construct() { @@ -58,9 +80,9 @@ public function removeProduct(Product $product): void } /** - * @return Collection|Product[] + * @return Product[] */ - public function getProducts() + public function getProducts(): Collection { return $this->products; } diff --git a/test/src/Entity/Product.php b/test/src/Entity/Product.php index 9a25ad8..fda415a 100644 --- a/test/src/Entity/Product.php +++ b/test/src/Entity/Product.php @@ -13,19 +13,25 @@ namespace ApiTestCase\Test\Entity; +use Doctrine\ORM\Mapping as ORM; + +#[ORM\Entity] +#[ORM\Table(name: "test_product")] class Product { - /** @var int|null */ - private $id; + #[ORM\Id] + #[ORM\Column(type: "integer")] + #[ORM\GeneratedValue(strategy: "AUTO")] + private ?int $id; - /** @var string */ - private $name; + #[ORM\Column(type: "string")] + private string $name; - /** @var int */ - private $price; + #[ORM\Column(type: "integer")] + private int $price; - /** @var string */ - private $uuid; + #[ORM\Column(type: "string")] + private string $uuid; public function getId(): ?int { @@ -57,10 +63,7 @@ public function getUuid(): string return $this->uuid; } - /** - * @param string $uuid - */ - public function setUuid($uuid): void + public function setUuid(string $uuid): void { $this->uuid = $uuid; }