Passed
Pull Request — master (#451)
by Sergei
04:56
created

Timer   A

Complexity

Total Complexity 3

Size/Duplication

Total Lines 16
Duplicated Lines 0 %

Test Coverage

Coverage 83.33%

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 6
c 1
b 0
f 0
dl 0
loc 16
ccs 5
cts 6
cp 0.8333
rs 10
wmc 3

2 Methods

Rating   Name   Duplication   Size   Complexity  
A get() 0 7 2
A start() 0 3 1
1
<?php
2
3
declare(strict_types=1);
4
5
namespace App;
6
7
final class Timer
8
{
9
    private array $timers = [];
10
11 20
    public function start(string $name): void
12
    {
13 20
        $this->timers[$name] = microtime(true);
14
    }
15
16 20
    public function get(string $name): float
17
    {
18 20
        if (!array_key_exists($name, $this->timers)) {
19
            throw new \InvalidArgumentException("There is no \"$name\" timer started");
20
        }
21
22 20
        return microtime(true) - $this->timers[$name];
23
    }
24
}
25