diff --git a/rules-tests/CodeQuality/Rector/Property/ImproveDoctrineCollectionDocTypeInEntityRector/Fixture/OneToMany/with_index_by_integer_attribute_read_constant_fetch.php.inc b/rules-tests/CodeQuality/Rector/Property/ImproveDoctrineCollectionDocTypeInEntityRector/Fixture/OneToMany/with_index_by_integer_attribute_read_constant_fetch.php.inc new file mode 100644 index 00000000..56b2cbd8 --- /dev/null +++ b/rules-tests/CodeQuality/Rector/Property/ImproveDoctrineCollectionDocTypeInEntityRector/Fixture/OneToMany/with_index_by_integer_attribute_read_constant_fetch.php.inc @@ -0,0 +1,55 @@ +|TrainingWithIntegerIdAttributeConstantFetch[] + */ + #[ORM\OneToMany(targetEntity: TrainingWithIntegerIdAttributeConstantFetch::class, mappedBy: 'trainer', indexBy: 'id')] + private $trainings = []; + + /** + * @var Collection|TrainingWithIntegerIdAttributeConstantFetch[] + */ + #[ORM\OneToMany(targetEntity: TrainingWithIntegerIdAttributeConstantFetch::class, mappedBy: 'trainer', indexBy: 'id2')] + private $trainings2 = []; +} + +?> +----- + + */ + #[ORM\OneToMany(targetEntity: TrainingWithIntegerIdAttributeConstantFetch::class, mappedBy: 'trainer', indexBy: 'id')] + private $trainings = []; + + /** + * @var \Doctrine\Common\Collections\Collection + */ + #[ORM\OneToMany(targetEntity: TrainingWithIntegerIdAttributeConstantFetch::class, mappedBy: 'trainer', indexBy: 'id2')] + private $trainings2 = []; +} + +?> diff --git a/rules-tests/CodeQuality/Rector/Property/ImproveDoctrineCollectionDocTypeInEntityRector/Source/TrainingWithIntegerIdAttributeConstantFetch.php b/rules-tests/CodeQuality/Rector/Property/ImproveDoctrineCollectionDocTypeInEntityRector/Source/TrainingWithIntegerIdAttributeConstantFetch.php new file mode 100644 index 00000000..e7bb39e9 --- /dev/null +++ b/rules-tests/CodeQuality/Rector/Property/ImproveDoctrineCollectionDocTypeInEntityRector/Source/TrainingWithIntegerIdAttributeConstantFetch.php @@ -0,0 +1,19 @@ +attrs as $attr) { if ($attr->name->toString() === 'Doctrine\ORM\Mapping\Column') { foreach ($attr->args as $arg) { - if ($arg->name instanceof Identifier && $arg->name->name === 'type' && $arg->value instanceof String_) { - $type = $arg->value->value; + if ($arg->name instanceof Identifier && $arg->name->name === 'type') { + $type = $this->valueResolver->getValue($arg->value); return $type === 'string' ? new StringType() : new IntegerType(); } }