TracksExecutionTime::chronometer()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 10
Code Lines 6

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 7
CRAP Score 1

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 6
c 1
b 0
f 0
nc 1
nop 2
dl 0
loc 10
ccs 7
cts 7
cp 1
cc 1
crap 1
rs 10
1
<?php
2
3
namespace Krenor\Prometheus\Metrics\Concerns;
4
5
use Closure;
6
7
trait TracksExecutionTime
8
{
9
    /**
10
     * @param array $labels
11
     * @param int $precision
12
     *
13
     * @return Closure
14
     */
15 3
    public function chronometer(array $labels = [], int $precision = 4): Closure
16
    {
17 3
        $start = microtime(true);
18
19 3
        return function ($labelz = []) use ($labels, $precision, $start) {
20 3
            $delta = microtime(true) - $start;
21
22 3
            $this->track(
23 3
                round($delta, $precision),
24 3
                array_merge($labels, $labelz)
25
            );
26 3
        };
27
    }
28
29
    /**
30
     * @param float $value
31
     * @param array $labels
32
     *
33
     * @return void
34
     */
35
    abstract protected function track(float $value, array $labels = []): void;
36
}
37