Passed
Push — main ( ecc027...46eee6 )
by mikhail
03:29
created

ResourceUtilization::start()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 2
CRAP Score 1

Importance

Changes 0
Metric Value
eloc 1
dl 0
loc 3
ccs 2
cts 2
cp 1
rs 10
c 0
b 0
f 0
cc 1
nc 1
nop 0
crap 1
1
<?php
2
3
declare(strict_types=1);
4
5
namespace SavinMikhail\CommentsDensity\Metrics;
6
7
use SavinMikhail\CommentsDensity\DTO\Output\PerformanceMetricsDTO;
0 ignored issues
show
Bug introduced by
The type SavinMikhail\CommentsDen...t\PerformanceMetricsDTO was not found. Maybe you did not declare it correctly or list all dependencies?

The issue could also be caused by a filter entry in the build configuration. If the path has been excluded in your configuration, e.g. excluded_paths: ["lib/*"], you can move it to the dependency path list as follows:

filter:
    dependency_paths: ["lib/*"]

For further information see https://scrutinizer-ci.com/docs/tools/php/php-scrutinizer/#list-dependency-paths

Loading history...
8
9
use function memory_get_peak_usage;
10
use function microtime;
11
use function round;
12
13
final class ResourceUtilization
14
{
15
    private float $startTime;
16
    private float $endTime;
17
    private float $peakMemoryUsage;
18
19 3
    public function start(): void
20
    {
21 3
        $this->startTime = microtime(true);
22
    }
23
24 2
    public function stop(): void
25
    {
26 2
        $this->endTime = microtime(true);
27 2
        $this->peakMemoryUsage = memory_get_peak_usage(true);
28
    }
29
30 1
    private function getExecutionTime(): float
31
    {
32 1
        return round(($this->endTime - $this->startTime) * 1000, 2);
33
    }
34
35 1
    private function getPeakMemoryUsage(): float
36
    {
37 1
        return round($this->peakMemoryUsage / 1024 / 1024, 2); // Convert to MB
38
    }
39
40 1
    public function getPerformanceMetrics(): PerformanceMetricsDTO
41
    {
42 1
        return new PerformanceMetricsDTO(
43 1
            $this->getExecutionTime(),
44 1
            $this->getPeakMemoryUsage()
45 1
        );
46
    }
47
}
48