Passed
Push — feature/change-cache-to-profil... ( 160b60 )
by Chema
04:07
created

FileProfilerBench::removeFiles()   A

Complexity

Conditions 2
Paths 1

Size

Total Lines 9
Code Lines 5

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
eloc 5
c 0
b 0
f 0
dl 0
loc 9
rs 10
cc 2
nc 1
nop 0
1
<?php
2
3
declare(strict_types=1);
4
5
namespace GacelaTest\Benchmark\Framework\ClassResolver\FileProfiler;
6
7
use Gacela\Framework\Bootstrap\GacelaConfig;
8
use Gacela\Framework\ClassResolver\ClassNameProfiler;
9
use Gacela\Framework\ClassResolver\DocBlockService\CustomServicesProfiler;
10
use Gacela\Framework\Gacela;
11
use GacelaTest\Fixtures\StringValue;
12
use GacelaTest\Fixtures\StringValueInterface;
13
14
/**
15
 * @Revs(50)
16
 * @Iterations(2)
17
 * @BeforeClassMethods("removeFiles")
18
 */
19
final class FileProfilerBench
20
{
21
    private const TOTAL_LOADING_MODULES = 100;
22
23
    public static function removeFiles(): void
24
    {
25
        $removeFile = static function (string $filename): void {
26
            if (file_exists($filename)) {
27
                unlink($filename);
28
            }
29
        };
30
        $removeFile(__DIR__ . '/.gacela/' . ClassNameProfiler::CACHE_FILENAME);
31
        $removeFile(__DIR__ . '/.gacela/.' . CustomServicesProfiler::CACHE_FILENAME);
32
    }
33
34
    public function bench_with_profiler(): void
35
    {
36
        $this->gacelaBootstrapWithProfiler(true);
37
        $this->loadAllModules();
38
    }
39
40
    public function bench_without_profiler(): void
41
    {
42
        $this->gacelaBootstrapWithProfiler(false);
43
        $this->loadAllModules();
44
    }
45
46
    private function gacelaBootstrapWithProfiler(bool $withProfiler): void
47
    {
48
        Gacela::bootstrap(__DIR__, static function (GacelaConfig $config) use ($withProfiler): void {
49
            $config->addAppConfig('config/*.php');
50
            $config->setProfilerEnabled($withProfiler);
51
            $config->setProfilerDirectory('.gacela');
52
53
            $config->addMappingInterface(StringValueInterface::class, new StringValue('testing-string'));
54
55
            $config->addSuffixTypeFactory('FactoryA');
56
            $config->addSuffixTypeFactory('FactoryB');
57
            $config->addSuffixTypeFactory('FactoryC');
58
            $config->addSuffixTypeFactory('FactoryD');
59
            $config->addSuffixTypeFactory('FactoryE');
60
61
            $config->addSuffixTypeConfig('ConfigA');
62
            $config->addSuffixTypeConfig('ConfigB');
63
            $config->addSuffixTypeConfig('ConfigC');
64
            $config->addSuffixTypeConfig('ConfigD');
65
            $config->addSuffixTypeConfig('ConfigE');
66
67
            $config->addSuffixTypeDependencyProvider('DepProvA');
68
            $config->addSuffixTypeDependencyProvider('DepProvB');
69
            $config->addSuffixTypeDependencyProvider('DepProvC');
70
            $config->addSuffixTypeDependencyProvider('DepProvD');
71
            $config->addSuffixTypeDependencyProvider('DepProvE');
72
        });
73
    }
74
75
    private function loadAllModules(): void
76
    {
77
        for ($i = 0; $i < self::TOTAL_LOADING_MODULES; ++$i) {
78
            (new ModuleA\Facade())->loadGacelaCacheFile();
79
            (new ModuleB\Facade())->loadGacelaCacheFile();
80
            (new ModuleC\Facade())->loadGacelaCacheFile();
81
            (new ModuleD\Facade())->loadGacelaCacheFile();
82
            (new ModuleE\Facade())->loadGacelaCacheFile();
83
            (new ModuleF\Facade())->loadGacelaCacheFile();
84
            (new ModuleG\Facade())->loadGacelaCacheFile();
85
        }
86
    }
87
}
88