BenchMark::process()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 14

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 8
CRAP Score 1

Importance

Changes 0
Metric Value
dl 0
loc 14
ccs 8
cts 8
cp 1
rs 9.7998
c 0
b 0
f 0
cc 1
nc 1
nop 2
crap 1
1
<?php
2
declare(strict_types=1);
3
4
namespace App\Middleware;
5
6
use Psr\Http\Server\MiddlewareInterface;
7
use Psr\Http\Server\RequestHandlerInterface;
8
use Psr\Http\Message\ResponseInterface;
9
use Psr\Http\Message\ServerRequestInterface;
10
use Psr\Log\LoggerInterface;
11
12
class BenchMark implements MiddlewareInterface
13
{
14
    /** @var LoggerInterface  */
15
    private $logger;
16
17 2
    public function __construct(LoggerInterface $logger)
18
    {
19 2
        $this->logger = $logger;
20 2
    }
21
22
    /**
23
     * @inheritDoc
24
     */
25 1
    public function process(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface
26
    {
27 1
        $start = microtime(true);
28
29 1
        $response = $handler->handle($request);
30
31 1
        $time = microtime(true) - $start;
32
33 1
        $ms = number_format($time * 1000, 1);
34 1
        $message = "{$request->getMethod()} {$request->getUri()->__toString()} ({$response->getStatusCode()}) : processed in {$ms} ms.";
35 1
        $this->logger->info($message);
36
37 1
        return $response;
38
    }
39
}
40