• Home
  • Features
  • Pricing
  • Docs
  • Announcements
  • Sign In

api-platform / core / 14532461818

18 Apr 2025 08:42AM UTC coverage: 8.488% (-13.8%) from 22.324%
14532461818

push

github

soyuka
ci: minimum stability

13402 of 157890 relevant lines covered (8.49%)

22.86 hits per line

Source File
Press 'n' to go to next uncovered line, 'b' for previous

88.89
/src/JsonLd/Serializer/ErrorNormalizer.php
1
<?php
2

3
/*
4
 * This file is part of the API Platform project.
5
 *
6
 * (c) Kévin Dunglas <dunglas@gmail.com>
7
 *
8
 * For the full copyright and license information, please view the LICENSE
9
 * file that was distributed with this source code.
10
 */
11

12
declare(strict_types=1);
13

14
namespace ApiPlatform\JsonLd\Serializer;
15

16
use ApiPlatform\State\ApiResource\Error;
17
use ApiPlatform\Validator\Exception\ValidationException;
18
use Symfony\Component\Serializer\Normalizer\NormalizerInterface;
19

20
final class ErrorNormalizer implements NormalizerInterface
21
{
22
    use HydraPrefixTrait;
23

24
    public function __construct(private readonly NormalizerInterface $inner, private readonly array $defaultContext = [])
25
    {
26
    }
2,018✔
27

28
    public function normalize(mixed $object, ?string $format = null, array $context = []): array|string|int|float|bool|\ArrayObject|null
29
    {
30
        $context += $this->defaultContext;
154✔
31
        $normalized = $this->inner->normalize($object, $format, $context);
154✔
32
        $hydraPrefix = $this->getHydraPrefix($context);
154✔
33
        if (!$hydraPrefix) {
154✔
34
            return $normalized;
×
35
        }
36

37
        if ('Error' === $normalized['@type']) {
154✔
38
            $normalized['@type'] = 'hydra:Error';
114✔
39
        }
40

41
        if (isset($normalized['description'])) {
154✔
42
            $normalized['hydra:description'] = $normalized['description'];
154✔
43
        }
44

45
        if (isset($normalized['title'])) {
154✔
46
            $normalized['hydra:title'] = $normalized['title'];
154✔
47
        }
48

49
        return $normalized;
154✔
50
    }
51

52
    public function supportsNormalization(mixed $data, ?string $format = null, array $context = []): bool
53
    {
54
        return $this->inner->supportsNormalization($data, $format, $context)
1,210✔
55
            && (is_a($data, Error::class) || is_a($data, ValidationException::class));
1,210✔
56
    }
57

58
    public function getSupportedTypes(?string $format): array
59
    {
60
        if (method_exists($this->inner, 'getSupportedTypes')) {
1,825✔
61
            return $this->inner->getSupportedTypes($format);
1,825✔
62
        }
63

64
        return [];
×
65
    }
66
}
STATUS · Troubleshooting · Open an Issue · Sales · Support · CAREERS · ENTERPRISE · START FREE · SCHEDULE DEMO
ANNOUNCEMENTS · TWITTER · TOS & SLA · Supported CI Services · What's a CI service? · Automated Testing

© 2025 Coveralls, Inc