|
14 | 14 | namespace ApiPlatform\Tests\State; |
15 | 15 |
|
16 | 16 | use ApiPlatform\Metadata\ApiResource; |
| 17 | +use ApiPlatform\Metadata\Delete; |
17 | 18 | use ApiPlatform\Metadata\Get; |
18 | 19 | use ApiPlatform\Metadata\IriConverterInterface; |
19 | 20 | use ApiPlatform\Metadata\Operation\Factory\OperationMetadataFactoryInterface; |
@@ -162,6 +163,65 @@ public function testAddsLinkedDataPlatformHeaders(): void |
162 | 163 | $this->assertSame('application/ld+json', $response->headers->get('Accept-Post')); |
163 | 164 | } |
164 | 165 |
|
| 166 | + public function testDoesNotSetContentTypeWhenOutputIsFalse(): void |
| 167 | + { |
| 168 | + $operation = new Post(class: Employee::class, output: ['class' => null], status: 204); |
| 169 | + |
| 170 | + $resourceClassResolver = $this->prophesize(ResourceClassResolverInterface::class); |
| 171 | + $resourceClassResolver->isResourceClass(Employee::class)->willReturn(true); |
| 172 | + |
| 173 | + $respondProcessor = new RespondProcessor(null, $resourceClassResolver->reveal()); |
| 174 | + |
| 175 | + $req = new Request(); |
| 176 | + $req->setMethod('POST'); |
| 177 | + $response = $respondProcessor->process(null, $operation, context: [ |
| 178 | + 'request' => $req, |
| 179 | + 'original_data' => new Employee(), |
| 180 | + ]); |
| 181 | + |
| 182 | + $this->assertSame(204, $response->getStatusCode()); |
| 183 | + $this->assertFalse($response->headers->has('Content-Type')); |
| 184 | + } |
| 185 | + |
| 186 | + public function testDoesNotSetContentTypeWhenOutputIsFalseWithCreatedStatus(): void |
| 187 | + { |
| 188 | + $operation = new Post(class: Employee::class, output: ['class' => null], status: 201); |
| 189 | + |
| 190 | + $resourceClassResolver = $this->prophesize(ResourceClassResolverInterface::class); |
| 191 | + $resourceClassResolver->isResourceClass(Employee::class)->willReturn(true); |
| 192 | + |
| 193 | + $respondProcessor = new RespondProcessor(null, $resourceClassResolver->reveal()); |
| 194 | + |
| 195 | + $req = new Request(); |
| 196 | + $req->setMethod('POST'); |
| 197 | + $response = $respondProcessor->process(null, $operation, context: [ |
| 198 | + 'request' => $req, |
| 199 | + 'original_data' => new Employee(), |
| 200 | + ]); |
| 201 | + |
| 202 | + $this->assertSame(201, $response->getStatusCode()); |
| 203 | + $this->assertFalse($response->headers->has('Content-Type')); |
| 204 | + } |
| 205 | + |
| 206 | + public function testDoesNotSetContentTypeOnBodylessStatusCodes(): void |
| 207 | + { |
| 208 | + $operation = new Delete(class: Employee::class); |
| 209 | + |
| 210 | + $resourceClassResolver = $this->prophesize(ResourceClassResolverInterface::class); |
| 211 | + $resourceClassResolver->isResourceClass(Employee::class)->willReturn(true); |
| 212 | + |
| 213 | + $respondProcessor = new RespondProcessor(null, $resourceClassResolver->reveal()); |
| 214 | + |
| 215 | + $req = new Request(); |
| 216 | + $req->setMethod('DELETE'); |
| 217 | + $response = $respondProcessor->process(null, $operation, context: [ |
| 218 | + 'request' => $req, |
| 219 | + ]); |
| 220 | + |
| 221 | + $this->assertSame(204, $response->getStatusCode()); |
| 222 | + $this->assertFalse($response->headers->has('Content-Type')); |
| 223 | + } |
| 224 | + |
165 | 225 | public function testDoesNotAddLinkedDataPlatformHeadersWithoutFactory(): void |
166 | 226 | { |
167 | 227 | $operation = new Get(uriTemplate: '/employees/{id}', class: Employee::class); |
|
0 commit comments