Skip to content

Commit

Permalink
refactor: [5.x] mixed types & trailing comma (#2396)
Browse files Browse the repository at this point in the history
## Description

Adds `mixed` php type in code & allows trailing comma's to be used in
[PHP-CS-Fixer](https://github.com/PHP-CS-Fixer/PHP-CS-Fixer)

## What type of PR is this? (check all applicable)
- [ ] Bug Fix
- [ ] Feature
- [x] Refactor
- [ ] Deprecation
- [ ] Breaking Change
- [ ] Documentation Update
- [ ] CI

## Checklist
- [ ] I have made corresponding changes to the documentation (`docs/`)
- [ ] I have made corresponding changes to the changelog
(`CHANGELOG.md`)
  • Loading branch information
DjordyKoert authored Nov 15, 2024
1 parent 4e94b3a commit 6217051
Show file tree
Hide file tree
Showing 18 changed files with 32 additions and 33 deletions.
1 change: 0 additions & 1 deletion .php-cs-fixer.dist.php
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,5 @@
file that was distributed with this source code.
HEADER
],
'trailing_comma_in_multiline' => false,
])
->setFinder($finder);
2 changes: 1 addition & 1 deletion src/Attribute/Model.php
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,7 @@ public function __construct(
string $type = Generator::UNDEFINED,
?array $groups = null,
array $options = [],
array $serializationContext = []
array $serializationContext = [],
) {
parent::__construct($properties + [
'type' => $type,
Expand Down
2 changes: 1 addition & 1 deletion src/Attribute/Security.php
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,7 @@ class Security extends AbstractAnnotation
public function __construct(
array $properties = [],
?string $name = null,
array $scopes = []
array $scopes = [],
) {
parent::__construct($properties + [
'name' => $name,
Expand Down
2 changes: 1 addition & 1 deletion src/ModelDescriber/Annotations/AnnotationsReader.php
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@ class AnnotationsReader
public function __construct(
ModelRegistry $modelRegistry,
array $mediaTypes,
bool $useValidationGroups = false
bool $useValidationGroups = false,
) {
$this->phpDocReader = new PropertyPhpDocReader();
$this->openApiAnnotationsReader = new OpenApiAnnotationsReader($modelRegistry, $mediaTypes);
Expand Down
2 changes: 1 addition & 1 deletion src/ModelDescriber/Annotations/ReflectionReader.php
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,7 @@ final class ReflectionReader
*/
public function updateProperty(
$reflection,
OA\Property $property
OA\Property $property,
): void {
// The default has been set by an Annotation or Attribute
// We leave that as it is!
Expand Down
2 changes: 1 addition & 1 deletion src/ModelDescriber/ApplyOpenApiDiscriminatorTrait.php
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,7 @@ protected function applyOpenApiDiscriminator(
OA\Schema $schema,
ModelRegistry $modelRegistry,
string $discriminatorProperty,
array $typeMap
array $typeMap,
): void {
$weakContext = Util::createWeakContext($schema->_context);

Expand Down
2 changes: 1 addition & 1 deletion src/ModelDescriber/FormModelDescriber.php
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,7 @@ public function __construct(
FormFactoryInterface $formFactory,
array $mediaTypes,
bool $useValidationGroups,
bool $isFormCsrfExtensionEnabled
bool $isFormCsrfExtensionEnabled,
) {
$this->formFactory = $formFactory;
$this->mediaTypes = $mediaTypes;
Expand Down
2 changes: 1 addition & 1 deletion src/ModelDescriber/JMSModelDescriber.php
Original file line number Diff line number Diff line change
Expand Up @@ -71,7 +71,7 @@ public function __construct(
array $mediaTypes,
?PropertyNamingStrategyInterface $namingStrategy = null,
bool $useValidationGroups = false,
?SerializationContextFactoryInterface $contextFactory = null
?SerializationContextFactoryInterface $contextFactory = null,
) {
$this->factory = $factory;
$this->namingStrategy = $namingStrategy;
Expand Down
2 changes: 1 addition & 1 deletion src/ModelDescriber/ObjectModelDescriber.php
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,7 @@ public function __construct(
array $mediaTypes,
?NameConverterInterface $nameConverter = null,
bool $useValidationGroups = false,
?ClassMetadataFactoryInterface $classMetadataFactory = null
?ClassMetadataFactoryInterface $classMetadataFactory = null,
) {
$this->propertyInfo = $propertyInfo;
$this->propertyDescriber = $propertyDescribers;
Expand Down
2 changes: 1 addition & 1 deletion src/OpenApiPhp/ModelRegister.php
Original file line number Diff line number Diff line change
Expand Up @@ -164,7 +164,7 @@ private function createContentForMediaType(
string $type,
array $properties,
OA\AbstractAnnotation $annotation,
Analysis $analysis
Analysis $analysis,
): void {
switch ($type) {
case 'json':
Expand Down
6 changes: 3 additions & 3 deletions src/OpenApiPhp/Util.php
Original file line number Diff line number Diff line change
Expand Up @@ -252,7 +252,7 @@ public static function getCollectionItem(OA\AbstractAnnotation $parent, string $
*
* @see OA\AbstractAnnotation::$_nested
*/
public static function getIndexedCollectionItem(OA\AbstractAnnotation $parent, string $class, $value): OA\AbstractAnnotation
public static function getIndexedCollectionItem(OA\AbstractAnnotation $parent, string $class, mixed $value): OA\AbstractAnnotation
{
$nested = $parent::$_nested;
[$collection, $property] = $nested[$class];
Expand Down Expand Up @@ -302,7 +302,7 @@ public static function searchCollectionItem(array $collection, array $properties
*
* @return false|int|string
*/
public static function searchIndexedCollectionItem(array $collection, string $member, $value)
public static function searchIndexedCollectionItem(array $collection, string $member, mixed $value)
{
foreach ($collection as $i => $child) {
if ($child->{$member} === $value) {
Expand Down Expand Up @@ -508,7 +508,7 @@ private static function mergeFromArray(OA\AbstractAnnotation $annotation, array
* @param class-string<T> $className
* @param mixed $value The value of the property
*/
private static function mergeChild(OA\AbstractAnnotation $annotation, string $className, $value, bool $overwrite): void
private static function mergeChild(OA\AbstractAnnotation $annotation, string $className, mixed $value, bool $overwrite): void
{
self::merge(self::getChild($annotation, $className), $value, $overwrite);
}
Expand Down
2 changes: 1 addition & 1 deletion src/PropertyDescriber/PropertyDescriber.php
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,7 @@ final class PropertyDescriber implements PropertyDescriberInterface, ModelRegist
* @param iterable<PropertyDescriberInterface> $propertyDescribers
*/
public function __construct(
iterable $propertyDescribers
iterable $propertyDescribers,
) {
$this->propertyDescribers = $propertyDescribers;
}
Expand Down
2 changes: 1 addition & 1 deletion src/RouteDescriber/RouteArgumentDescriber.php
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@ final class RouteArgumentDescriber implements RouteDescriberInterface, ModelRegi
*/
public function __construct(
private ArgumentMetadataFactoryInterface $argumentMetadataFactory,
private iterable $inlineParameterDescribers
private iterable $inlineParameterDescribers,
) {
}

Expand Down
2 changes: 1 addition & 1 deletion src/Routing/FilteredRouteCollectionBuilder.php
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@ final class FilteredRouteCollectionBuilder
public function __construct(
ControllerReflector $controllerReflector,
string $area,
array $options = []
array $options = [],
) {
$resolver = new OptionsResolver();
$resolver
Expand Down
2 changes: 1 addition & 1 deletion tests/Functional/Controller/ApiController.php
Original file line number Diff line number Diff line change
Expand Up @@ -465,7 +465,7 @@ public function securityOverrideActionAttributes()
#[Route('/inline_path_parameters')]
#[OA\Response(response: '200', description: '')]
public function inlinePathParameters(
#[OA\PathParameter] string $product_id
#[OA\PathParameter] string $product_id,
) {
}

Expand Down
6 changes: 3 additions & 3 deletions tests/Functional/Controller/MapQueryStringController.php
Original file line number Diff line number Diff line change
Expand Up @@ -27,14 +27,14 @@ class MapQueryStringController
#[Route('/article_map_query_string', methods: ['GET'])]
#[OA\Response(response: '200', description: '')]
public function fetchArticleFromMapQueryString(
#[MapQueryString] SymfonyMapQueryString $article81Query
#[MapQueryString] SymfonyMapQueryString $article81Query,
) {
}

#[Route('/article_map_query_string_nullable', methods: ['GET'])]
#[OA\Response(response: '200', description: '')]
public function fetchArticleFromMapQueryStringNullable(
#[MapQueryString] ?SymfonyMapQueryString $article81Query
#[MapQueryString] ?SymfonyMapQueryString $article81Query,
) {
}

Expand Down Expand Up @@ -74,7 +74,7 @@ public function fetchArticleFromMapQueryStringHandlesValidationGroups(
)]
#[OA\Response(response: '200', description: '')]
public function fetchArticleFromMapQueryStringOverwriteParameters(
#[MapQueryString] SymfonyMapQueryString $article81Query
#[MapQueryString] SymfonyMapQueryString $article81Query,
) {
}

Expand Down
24 changes: 12 additions & 12 deletions tests/Functional/JMSFunctionalTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -328,7 +328,7 @@ public function testNamingStrategyWithConstraints(): void
'type' => 'string',
'maxLength' => 10,
'minLength' => 3,
'default' => 'default'
'default' => 'default',
],
],
'schema' => 'JMSNamingStrategyConstraints',
Expand Down Expand Up @@ -376,8 +376,8 @@ public function testEnumSupport(): void
'type' => 'string',
'enum' => [
'draft',
'final'
]
'final',
],
], json_decode($this->getModel('ArticleType81')->toJson(), true));

if (TestKernel::isAnnotationsAvailable()) {
Expand All @@ -390,33 +390,33 @@ public function testEnumSupport(): void
'type' => 'string',
'enum' => [
'DRAFT',
'FINAL'
]
'FINAL',
],
], json_decode($this->getModel('ArticleType812')->toJson(), true));

self::assertEquals([
'schema' => 'JMSEnum',
'type' => 'object',
'properties' => [
'enum_value' => [
'$ref' => '#/components/schemas/ArticleType81'
'$ref' => '#/components/schemas/ArticleType81',
],
'enum_values' => [
'type' => 'array',
'items' => [
'$ref' => '#/components/schemas/ArticleType81'
]
'$ref' => '#/components/schemas/ArticleType81',
],
],
'enum_name' => [
'$ref' => '#/components/schemas/ArticleType812'
'$ref' => '#/components/schemas/ArticleType812',
],
'enum_names' => [
'type' => 'array',
'items' => [
'$ref' => '#/components/schemas/ArticleType812'
]
'$ref' => '#/components/schemas/ArticleType812',
],
],
]
],
], json_decode($this->getModel('JMSEnum')->toJson(), true));
}

Expand Down
2 changes: 1 addition & 1 deletion tests/Routing/FilteredRouteCollectionBuilderTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -244,7 +244,7 @@ public function testRoutesWithDisabledDefaultRoutes(
Route $route,
\ReflectionMethod $reflectionMethod,
array $options,
int $expectedRoutesCount
int $expectedRoutesCount,
): void {
$routes = new RouteCollection();
$routes->add($name, $route);
Expand Down

0 comments on commit 6217051

Please sign in to comment.