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\ClassNameJsonProfiler; |
9
|
|
|
use Gacela\Framework\ClassResolver\DocBlockService\CustomServicesJsonProfiler; |
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
|
|
|
$filename = __DIR__ . '/.gacela/profiler/' . $filename; |
27
|
|
|
if (file_exists($filename)) { |
28
|
|
|
unlink($filename); |
29
|
|
|
} |
30
|
|
|
}; |
31
|
|
|
$removeFile(ClassNameJsonProfiler::FILENAME); |
32
|
|
|
$removeFile(CustomServicesJsonProfiler::FILENAME); |
33
|
|
|
} |
34
|
|
|
|
35
|
|
|
public function bench_with_profiler(): void |
36
|
|
|
{ |
37
|
|
|
$this->gacelaBootstrapWithProfiler(true); |
38
|
|
|
$this->loadAllModules(); |
39
|
|
|
} |
40
|
|
|
|
41
|
|
|
public function bench_without_profiler(): void |
42
|
|
|
{ |
43
|
|
|
$this->gacelaBootstrapWithProfiler(false); |
44
|
|
|
$this->loadAllModules(); |
45
|
|
|
} |
46
|
|
|
|
47
|
|
|
private function gacelaBootstrapWithProfiler(bool $withProfiler): void |
48
|
|
|
{ |
49
|
|
|
Gacela::bootstrap(__DIR__, static function (GacelaConfig $config) use ($withProfiler): void { |
50
|
|
|
$config->addAppConfig('config/*.php'); |
51
|
|
|
$config->setProfilerEnabled($withProfiler); |
52
|
|
|
$config->setProfilerDirectory('.gacela/profiler'); |
53
|
|
|
|
54
|
|
|
$config->addMappingInterface(StringValueInterface::class, new StringValue('testing-string')); |
55
|
|
|
|
56
|
|
|
$config->addSuffixTypeFactory('FactoryA'); |
57
|
|
|
$config->addSuffixTypeFactory('FactoryB'); |
58
|
|
|
$config->addSuffixTypeFactory('FactoryC'); |
59
|
|
|
$config->addSuffixTypeFactory('FactoryD'); |
60
|
|
|
$config->addSuffixTypeFactory('FactoryE'); |
61
|
|
|
|
62
|
|
|
$config->addSuffixTypeConfig('ConfigA'); |
63
|
|
|
$config->addSuffixTypeConfig('ConfigB'); |
64
|
|
|
$config->addSuffixTypeConfig('ConfigC'); |
65
|
|
|
$config->addSuffixTypeConfig('ConfigD'); |
66
|
|
|
$config->addSuffixTypeConfig('ConfigE'); |
67
|
|
|
|
68
|
|
|
$config->addSuffixTypeDependencyProvider('DepProvA'); |
69
|
|
|
$config->addSuffixTypeDependencyProvider('DepProvB'); |
70
|
|
|
$config->addSuffixTypeDependencyProvider('DepProvC'); |
71
|
|
|
$config->addSuffixTypeDependencyProvider('DepProvD'); |
72
|
|
|
$config->addSuffixTypeDependencyProvider('DepProvE'); |
73
|
|
|
}); |
74
|
|
|
} |
75
|
|
|
|
76
|
|
|
private function loadAllModules(): void |
77
|
|
|
{ |
78
|
|
|
for ($i = 0; $i < self::TOTAL_LOADING_MODULES; ++$i) { |
79
|
|
|
(new ModuleA\Facade())->loadGacelaCacheFile(); |
80
|
|
|
(new ModuleB\Facade())->loadGacelaCacheFile(); |
81
|
|
|
(new ModuleC\Facade())->loadGacelaCacheFile(); |
82
|
|
|
(new ModuleD\Facade())->loadGacelaCacheFile(); |
83
|
|
|
(new ModuleE\Facade())->loadGacelaCacheFile(); |
84
|
|
|
(new ModuleF\Facade())->loadGacelaCacheFile(); |
85
|
|
|
(new ModuleG\Facade())->loadGacelaCacheFile(); |
86
|
|
|
} |
87
|
|
|
} |
88
|
|
|
} |
89
|
|
|
|