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
|
|
|
|