From f21778002d0334f0e168252dfa0dea0d59b6fc5b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pawe=C5=82=20Niedzielski?= Date: Wed, 5 May 2021 14:10:46 +0200 Subject: [PATCH 1/2] Added information to Symfony's profiler "performance" tab for component rendering --- .../EzPlatformAdminUiExtension.php | 12 +++++ .../Resources/config/services.debug.yaml | 7 +++ .../Resources/config/services/components.yaml | 2 + .../Templating/Twig/ComponentExtension.php | 5 -- .../Component/Renderer/DefaultRenderer.php | 12 ++++- .../Component/Renderer/TraceableRenderer.php | 52 +++++++++++++++++++ 6 files changed, 84 insertions(+), 6 deletions(-) create mode 100644 src/bundle/Resources/config/services.debug.yaml create mode 100644 src/lib/Component/Renderer/TraceableRenderer.php diff --git a/src/bundle/DependencyInjection/EzPlatformAdminUiExtension.php b/src/bundle/DependencyInjection/EzPlatformAdminUiExtension.php index cd3c2e4d2a..aedb200669 100644 --- a/src/bundle/DependencyInjection/EzPlatformAdminUiExtension.php +++ b/src/bundle/DependencyInjection/EzPlatformAdminUiExtension.php @@ -12,6 +12,7 @@ use Symfony\Component\DependencyInjection\Extension\PrependExtensionInterface; use Symfony\Component\DependencyInjection\Loader\YamlFileLoader; use Symfony\Component\HttpKernel\DependencyInjection\Extension; +use Symfony\Component\Stopwatch\Stopwatch; use Symfony\Component\Yaml\Yaml; class EzPlatformAdminUiExtension extends Extension implements PrependExtensionInterface @@ -39,6 +40,8 @@ public function load(array $configs, ContainerBuilder $container) if ($environment === 'behat') { $loader->load('services/feature_contexts.yaml'); } + + $this->registerDebugConfiguration($container, $loader); } /** @@ -143,4 +146,13 @@ private function prependJMSTranslation(ContainerBuilder $container): void ], ]); } + + private function registerDebugConfiguration(ContainerBuilder $container, YamlFileLoader $loader): void + { + $debug = $container->getParameter('kernel.debug'); + + if ($debug && class_exists(Stopwatch::class)) { + $loader->load('services.debug.yaml'); + } + } } diff --git a/src/bundle/Resources/config/services.debug.yaml b/src/bundle/Resources/config/services.debug.yaml new file mode 100644 index 0000000000..235665a900 --- /dev/null +++ b/src/bundle/Resources/config/services.debug.yaml @@ -0,0 +1,7 @@ +services: + EzSystems\EzPlatformAdminUi\Component\Renderer\TraceableRenderer: + decorates: EzSystems\EzPlatformAdminUi\Component\Renderer\RendererInterface + public: false + arguments: + - '@.inner' + - '@debug.stopwatch' \ No newline at end of file diff --git a/src/bundle/Resources/config/services/components.yaml b/src/bundle/Resources/config/services/components.yaml index 66672f21ea..97819f5eb9 100644 --- a/src/bundle/Resources/config/services/components.yaml +++ b/src/bundle/Resources/config/services/components.yaml @@ -36,5 +36,7 @@ services: EzSystems\EzPlatformAdminUi\Component\Renderer\DefaultRenderer: public: false + calls: + - setRenderer: ['@EzSystems\EzPlatformAdminUi\Component\Renderer\RendererInterface'] EzSystems\EzPlatformAdminUi\Component\Renderer\RendererInterface: '@EzSystems\EzPlatformAdminUi\Component\Renderer\DefaultRenderer' diff --git a/src/bundle/Templating/Twig/ComponentExtension.php b/src/bundle/Templating/Twig/ComponentExtension.php index 0020543404..14b1669568 100644 --- a/src/bundle/Templating/Twig/ComponentExtension.php +++ b/src/bundle/Templating/Twig/ComponentExtension.php @@ -8,22 +8,17 @@ namespace EzSystems\EzPlatformAdminUiBundle\Templating\Twig; -use EzSystems\EzPlatformAdminUi\Component\Registry as ComponentRegistry; use EzSystems\EzPlatformAdminUi\Component\Renderer\RendererInterface; use Twig\Extension\AbstractExtension; use Twig\TwigFunction; class ComponentExtension extends AbstractExtension { - protected $registry; - protected $renderer; public function __construct( - ComponentRegistry $registry, RendererInterface $renderer ) { - $this->registry = $registry; $this->renderer = $renderer; } diff --git a/src/lib/Component/Renderer/DefaultRenderer.php b/src/lib/Component/Renderer/DefaultRenderer.php index 7177d0bd8a..d8a3c595ed 100644 --- a/src/lib/Component/Renderer/DefaultRenderer.php +++ b/src/lib/Component/Renderer/DefaultRenderer.php @@ -16,16 +16,26 @@ class DefaultRenderer implements RendererInterface { + /** @var \EzSystems\EzPlatformAdminUi\Component\Registry */ protected $registry; + /** @var \Symfony\Component\EventDispatcher\EventDispatcherInterface */ protected $eventDispatcher; + /** @var \EzSystems\EzPlatformAdminUi\Component\Renderer\RendererInterface */ + protected $renderer; + public function __construct(Registry $registry, EventDispatcherInterface $eventDispatcher) { $this->registry = $registry; $this->eventDispatcher = $eventDispatcher; } + public function setRenderer(RendererInterface $renderer): void + { + $this->renderer = $renderer; + } + public function renderGroup(string $groupName, array $parameters = []): array { $this->eventDispatcher->dispatch(new RenderGroupEvent( @@ -38,7 +48,7 @@ public function renderGroup(string $groupName, array $parameters = []): array $rendered = []; foreach ($components as $id => $component) { - $rendered[] = $this->renderSingle($id, $groupName, $parameters); + $rendered[] = $this->renderer->renderSingle($id, $groupName, $parameters); } return $rendered; diff --git a/src/lib/Component/Renderer/TraceableRenderer.php b/src/lib/Component/Renderer/TraceableRenderer.php new file mode 100644 index 0000000000..481696566a --- /dev/null +++ b/src/lib/Component/Renderer/TraceableRenderer.php @@ -0,0 +1,52 @@ +decorated = $decorated; + $this->stopwatch = $stopwatch; + } + + public function renderGroup(string $groupName, array $parameters = []): array + { + $event = $this->stopwatch->start(sprintf('%s', $groupName), 'admin-ui'); + + try { + $rendered = $this->decorated->renderGroup($groupName, $parameters); + } finally { + if ($event->isStarted()) { + $event->stop(); + } + } + + return $rendered; + } + + public function renderSingle(string $name, $groupName, array $parameters = []): string + { + $event = $this->stopwatch->start(sprintf('%s - %s', $groupName, $name), 'admin-ui'); + + try { + $rendered = $this->decorated->renderSingle($name, $groupName, $parameters); + } finally { + if ($event->isStarted()) { + $event->stop(); + } + } + + return $rendered; + } +} \ No newline at end of file From b7a3d740395193fb54083edaad384e4b138fb885 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pawe=C5=82=20Niedzielski?= Date: Fri, 7 May 2021 12:20:29 +0200 Subject: [PATCH 2/2] Fixed code style --- src/bundle/Resources/config/services.debug.yaml | 2 +- src/lib/Component/Renderer/TraceableRenderer.php | 8 ++++++-- 2 files changed, 7 insertions(+), 3 deletions(-) diff --git a/src/bundle/Resources/config/services.debug.yaml b/src/bundle/Resources/config/services.debug.yaml index 235665a900..bb4a1d64c7 100644 --- a/src/bundle/Resources/config/services.debug.yaml +++ b/src/bundle/Resources/config/services.debug.yaml @@ -4,4 +4,4 @@ services: public: false arguments: - '@.inner' - - '@debug.stopwatch' \ No newline at end of file + - '@debug.stopwatch' diff --git a/src/lib/Component/Renderer/TraceableRenderer.php b/src/lib/Component/Renderer/TraceableRenderer.php index 481696566a..32ca04d6ee 100644 --- a/src/lib/Component/Renderer/TraceableRenderer.php +++ b/src/lib/Component/Renderer/TraceableRenderer.php @@ -1,4 +1,9 @@