|
17 | 17 | use ApiPlatform\Doctrine\Common\Filter\LoggerAwareTrait; |
18 | 18 | use ApiPlatform\Doctrine\Common\Filter\ManagerRegistryAwareInterface; |
19 | 19 | use ApiPlatform\Doctrine\Common\Filter\ManagerRegistryAwareTrait; |
| 20 | +use ApiPlatform\Doctrine\Common\Filter\NameConverterAwareInterface; |
20 | 21 | use ApiPlatform\Doctrine\Odm\Extension\ParameterExtension; |
21 | 22 | use ApiPlatform\Doctrine\Odm\Filter\FilterInterface; |
22 | 23 | use ApiPlatform\Metadata\BackwardCompatibleFilterDescriptionTrait; |
|
30 | 31 | use PHPUnit\Framework\TestCase; |
31 | 32 | use Psr\Container\ContainerInterface; |
32 | 33 | use Psr\Log\LoggerInterface; |
| 34 | +use Symfony\Component\Serializer\NameConverter\NameConverterInterface; |
33 | 35 |
|
34 | 36 | class ParameterExtensionTest extends TestCase |
35 | 37 | { |
@@ -123,6 +125,62 @@ public function apply(Builder $aggregationBuilder, string $resourceClass, ?Opera |
123 | 125 | $this->assertNotNull($filter->getManagerRegistry()); |
124 | 126 | } |
125 | 127 |
|
| 128 | + public function testApplyToCollectionWithNameConverter(): void |
| 129 | + { |
| 130 | + $aggregationBuilder = $this->createMock(Builder::class); |
| 131 | + $nameConverter = $this->createMock(NameConverterInterface::class); |
| 132 | + |
| 133 | + $filter = new class($nameConverter) implements FilterInterface, NameConverterAwareInterface { |
| 134 | + use BackwardCompatibleFilterDescriptionTrait; |
| 135 | + |
| 136 | + private ?NameConverterInterface $nameConverter = null; |
| 137 | + |
| 138 | + public function __construct(private readonly NameConverterInterface $expectedNameConverter) |
| 139 | + { |
| 140 | + } |
| 141 | + |
| 142 | + public function hasNameConverter(): bool |
| 143 | + { |
| 144 | + return $this->nameConverter instanceof NameConverterInterface; |
| 145 | + } |
| 146 | + |
| 147 | + public function getNameConverter(): ?NameConverterInterface |
| 148 | + { |
| 149 | + return $this->nameConverter; |
| 150 | + } |
| 151 | + |
| 152 | + public function setNameConverter(NameConverterInterface $nameConverter): void |
| 153 | + { |
| 154 | + $this->nameConverter = $nameConverter; |
| 155 | + } |
| 156 | + |
| 157 | + public function apply(Builder $aggregationBuilder, string $resourceClass, ?Operation $operation = null, array &$context = []): void |
| 158 | + { |
| 159 | + Assert::assertTrue($this->hasNameConverter()); |
| 160 | + Assert::assertSame($this->expectedNameConverter, $this->getNameConverter()); |
| 161 | + Assert::assertSame('SomeClass', $resourceClass); |
| 162 | + } |
| 163 | + }; |
| 164 | + |
| 165 | + $operation = (new GetCollection()) |
| 166 | + ->withParameters([ |
| 167 | + (new QueryParameter( |
| 168 | + key: 'param1', |
| 169 | + filter: $filter, |
| 170 | + ))->setValue(1), |
| 171 | + ]); |
| 172 | + |
| 173 | + $extension = new ParameterExtension( |
| 174 | + $this->createNonCalledFilterLocator(), |
| 175 | + nameConverter: $nameConverter, |
| 176 | + ); |
| 177 | + $context = []; |
| 178 | + $extension->applyToCollection($aggregationBuilder, 'SomeClass', $operation, $context); |
| 179 | + |
| 180 | + $this->assertSame([], $context); |
| 181 | + $this->assertSame($nameConverter, $filter->getNameConverter()); |
| 182 | + } |
| 183 | + |
126 | 184 | public function testApplyToCollectionPassesContext(): void |
127 | 185 | { |
128 | 186 | $aggregationBuilder = $this->createMock(Builder::class); |
|
0 commit comments