8000 [TwigBundle] Fix Twig cache is not properly warmed by tucksaun · Pull Request #16262 · symfony/symfony · GitHub
[go: up one dir, main page]

Skip to content

[TwigBundle] Fix Twig cache is not properly warmed #16262

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Merged
merged 1 commit into from
Oct 17, 2015
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
[TwigBundle] Fix Twig cache is not properly warmed
  • Loading branch information
tucksaun committed Oct 17, 2015
commit e704ee4d6c27ff1152cef585292724ac5572d92a
Original file line number Diff line number Diff line change
Expand Up @@ -31,15 +31,16 @@ class TemplateCacheCacheWarmer implements CacheWarmerInterface
/**
* Constructor.
*
* @param ContainerInterface $container The dependency injection container
* @param TemplateFinderInterface $finder The template paths cache warmer
* @param ContainerInterface $container The dependency injection container
* @param TemplateFinderInterface|null $finder The template paths cache warmer
*/
public function __construct(ContainerInterface $container, TemplateFinderInterface $finder)
public function __construct(ContainerInterface $container, TemplateFinderInterface $finder = null)
{
// We don't inject the Twig environment directly as it depends on the
// template locator (via the loader) which might be a cached one.
// The cached template locator is available once the TemplatePathsCacheWarmer
// has been warmed up
// has been warmed up.
// But it can also be null if templating has been disabled.
$this->container = $container;
$this->finder = $finder;
}
Expand All @@ -51,6 +52,10 @@ public function __construct(ContainerInterface $container, TemplateFinderInterfa
*/
public function warmUp($cacheDir)
{
if (null === $this->finder) {
return;
}

$twig = $this->container->get('twig');

foreach ($this->finder->findAllTemplates() as $template) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -68,9 +68,7 @@ public function process(ContainerBuilder $container)
$container->getDefinition('twig.extension.debug')->addTag('twig.extension');
}

if ($container->has('templating')) {
$container->getDefinition('twig.cache_warmer')->addTag('kernel.cache_warmer');
} else {
if (!$container->has('templating')) {
$loader = $container->getDefinition('twig.loader.native_filesystem');
$loader->addTag('twig.loader');
$loader->setMethodCalls($container->getDefinition('twig.loader.filesystem')->getMethodCalls());
Expand Down
3 changes: 2 additions & 1 deletion src/Symfony/Bundle/TwigBundle/Resources/config/twig.xml
Original file line number Diff line number Diff line change
Expand Up @@ -46,8 +46,9 @@
</service>

<service id="twig.cache_warmer" class="%twig.cache_warmer.class%" public="false">
<tag name="kernel.cache_warmer" />
<argument type="service" id="service_container" />
<argument type="service" id="templating.finder" />
<argument type="service" id="templating.finder" on-invalid="ignore" />
</service>

<service id="twig.loader.native_filesystem" class="Twig_Loader_Filesystem" public="false">
Expand Down
116 changes: 116 additions & 0 deletions src/Symfony/Bundle/TwigBundle/Tests/Functional/CacheWarmingTest.php
8000
Original file line number Diff line number Diff line change
@@ -0,0 +1,116 @@
<?php

/*
* This file is part of the Symfony package.
*
* (c) Fabien Potencier <fabien@symfony.com>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/

namespace Symfony\Bundle\TwigBundle\Tests;

use Symfony\Component\HttpKernel\Kernel;
use Symfony\Component\Config\Loader\LoaderInterface;
use Symfony\Component\Filesystem\Filesystem;
use Symfony\Bundle\FrameworkBundle\FrameworkBundle;
use Symfony\Bundle\TwigBundle\TwigBundle;

class NewCacheWamingTest extends \PHPUnit_Framework_TestCase
{
public function testCacheIsProperlyWarmedWhenTemplatingIsAvailable()
{
$kernel = new CacheWarmingKernel(true);
$kernel->boot();

$warmer = $kernel->getContainer()->get('cache_warmer');
$warmer->enableOptionalWarmers();
$warmer->warmUp($kernel->getCacheDir());

$this->assertTrue(file_exists($kernel->getCacheDir().'/twig'));
}

public function testCacheIsNotWarmedWhenTemplatingIsDisabled()
{
$kernel = new CacheWarmingKernel(false);
$kernel->boot();

$warmer = $kernel->getContainer()->get('cache_warmer');
$warmer->enableOptionalWarmers();
$warmer->warmUp($kernel->getCacheDir());

$this->assertFalse(file_exists($kernel->getCacheDir().'/twig'));
}

protected function setUp()
{
$this->deleteTempDir();
}

protected function tearDown()
{
$this->deleteTempDir();
}

private function deleteTempDir()
{
if (!file_exists($dir = sys_get_temp_dir().'/'.Kernel::VERSION.'/CacheWarmingKernel')) {
return;
}

$fs = new Filesystem();
$fs->remove($dir);
}
}

class CacheWarmingKernel extends Kernel
{
private $withTemplating;

public function __construct($withTemplating)
{
$this->withTemplating = $withTemplating;

parent::__construct('dev', true);
}

public function getName()
{
return 'CacheWarming';
}

public function registerBundles()
{
return array(new FrameworkBundle(), new TwigBundle());
}

public function registerContainerConfiguration(LoaderInterface $loader)
{
$loader->load(function ($container) {
$container->loadFromExtension('framework', array(
'secret' => '$ecret',
));
});

if ($this->withTemplating) {
$loader->load(function ($container) {
$container->loadFromExtension('framework', array(
'secret' => '$ecret',
'templating' => array('engines' => array('twig')),
'router' => array('resource' => '%kernel.root_dir%/Resources/config/empty_routing.yml'),
));
});
}
}

public function getCacheDir()
{
return sys_get_temp_dir().'/'.Kernel::VERSION.'/CacheWarmingKernel/cache';
}

public function getLogDir()
{
return sys_get_temp_dir().'/'.Kernel::VERSION.'/CacheWarmingKernel/logs';
}
}
1 change: 1 addition & 0 deletions src/Symfony/Bundle/TwigBundle/composer.json
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@
"symfony/dependency-injection": "~2.6,>=2.6.6",
"symfony/expression-language": "~2.4",
"symfony/config": "~2.2",
"symfony/finder": "~2.0,>=2.0.5",
"symfony/routing": "~2.1",
"symfony/templating": "~2.1",
"symfony/yaml": "~2.3",
Expand Down
0