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

fractalzombie / frzb-metrics-power / 8464240914

28 Mar 2024 08:06AM UTC coverage: 85.185% (-4.5%) from 89.706%
8464240914

push

github

fractalzombie
[MetricsPower] Added ContextExtractor for logger

79 of 98 new or added lines in 16 files covered. (80.61%)

1 existing line in 1 file now uncovered.

184 of 216 relevant lines covered (85.19%)

8.44 hits per line

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

0.0
/Handler/MetricsHandler.php
1
<?php
2

3
declare(strict_types=1);
4

5
/**
6
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
7
 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
8
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
9
 *
10
 * Copyright (c) 2024 Mykhailo Shtanko fractalzombie@gmail.com
11
 *
12
 * For the full copyright and license information, please view the LICENSE.MD
13
 * file that was distributed with this source code.
14
 */
15

16
namespace FRZB\Component\MetricsPower\Handler;
17

18
use FRZB\Component\DependencyInjection\Attribute\AsService;
19
use FRZB\Component\MetricsPower\Helper\MetricalHelper;
20
use FRZB\Component\MetricsPower\Logger\MetricsPowerLoggerInterface;
21
use FRZB\Component\MetricsPower\OptionsResolver\OptionsResolverLocatorInterface;
22
use Symfony\Component\Messenger\Event\AbstractWorkerMessageEvent;
23
use Symfony\Component\Messenger\Event\SendMessageToTransportsEvent;
24

25
#[AsService]
26
class MetricsHandler implements MetricsHandlerInterface
27
{
28
    public function __construct(
29
        private readonly OptionsResolverLocatorInterface $locator,
30
        private readonly MetricsPowerLoggerInterface $logger,
31
    ) {}
×
32

33
    public function handle(AbstractWorkerMessageEvent|SendMessageToTransportsEvent $event): void
34
    {
35
        foreach (MetricalHelper::getOptions($event->getEnvelope()->getMessage()) as $option) {
×
36
            try {
37
                $this->locator->get($option)($event, $option);
×
NEW
38
                $this->logger->info($event, $option);
×
39
            } catch (\Throwable $e) {
×
NEW
40
                $this->logger->error($event, $option, $e);
×
41
            }
42
        }
43
    }
44
}
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

© 2026 Coveralls, Inc