1
0
Fork 0

Merge pull request #2453 from mirkobeine/#2441-V2

Use 'cache-files-ttl' for cache gc, fixes #2441
pull/2295/merge
Jordi Boggiano 2013-11-25 02:56:58 -08:00
commit dea246186d
3 changed files with 45 additions and 7 deletions

View File

@ -23,6 +23,7 @@ use Symfony\Component\Finder\Finder;
*/
class Cache
{
private static $cacheCollected = false;
private $io;
private $root;
private $enabled = true;
@ -126,6 +127,11 @@ class Cache
return false;
}
public function gcIsNecessary()
{
return (!self::$cacheCollected && !mt_rand(0, 50));
}
public function remove($file)
{
$file = preg_replace('{[^'.$this->whitelist.']}i', '-', $file);
@ -157,6 +163,8 @@ class Cache
}
}
self::$cacheCollected = true;
return true;
}

View File

@ -34,7 +34,6 @@ use Composer\Util\RemoteFilesystem;
*/
class FileDownloader implements DownloaderInterface
{
private static $cacheCollected = false;
protected $io;
protected $config;
protected $rfs;
@ -61,10 +60,10 @@ class FileDownloader implements DownloaderInterface
$this->filesystem = $filesystem ?: new Filesystem();
$this->cache = $cache;
if ($this->cache && !self::$cacheCollected && !mt_rand(0, 50)) {
$this->cache->gc($config->get('cache-ttl'), $config->get('cache-files-maxsize'));
if ($this->cache && $this->cache->gcIsNecessary()) {
$this->cache->gc($config->get('cache-files-ttl'), $config->get('cache-files-maxsize'));
}
self::$cacheCollected = true;
}
/**

View File

@ -17,13 +17,13 @@ use Composer\Util\Filesystem;
class FileDownloaderTest extends \PHPUnit_Framework_TestCase
{
protected function getDownloader($io = null, $config = null, $rfs = null, $filesystem = null)
protected function getDownloader($io = null, $config = null, $eventDispatcher = null, $cache = null, $rfs = null, $filesystem = null)
{
$io = $io ?: $this->getMock('Composer\IO\IOInterface');
$config = $config ?: $this->getMock('Composer\Config');
$rfs = $rfs ?: $this->getMockBuilder('Composer\Util\RemoteFilesystem')->disableOriginalConstructor()->getMock();
return new FileDownloader($io, $config, null, null, $rfs, $filesystem);
return new FileDownloader($io, $config, $eventDispatcher, $cache, $rfs, $filesystem);
}
/**
@ -123,6 +123,37 @@ class FileDownloaderTest extends \PHPUnit_Framework_TestCase
}
}
public function testCacheGarbageCollectionIsCalled()
{
$expectedTtl = '99999999';
$configMock = $this->getMock('Composer\Config');
$configMock
->expects($this->at(0))
->method('get')
->with('cache-files-ttl')
->will($this->returnValue($expectedTtl));
$configMock
->expects($this->at(1))
->method('get')
->with('cache-files-maxsize')
->will($this->returnValue('500M'));
$cacheMock = $this->getMockBuilder('Composer\Cache')
->disableOriginalConstructor()
->getMock();
$cacheMock
->expects($this->any())
->method('gcIsNecessary')
->will($this->returnValue(true));
$cacheMock
->expects($this->once())
->method('gc')
->with($expectedTtl, $this->anything());
$downloader = $this->getDownloader(null, $configMock, null, $cacheMock, null, null);
}
public function testDownloadFileWithInvalidChecksum()
{
$packageMock = $this->getMock('Composer\Package\PackageInterface');
@ -140,7 +171,7 @@ class FileDownloaderTest extends \PHPUnit_Framework_TestCase
$path = sys_get_temp_dir().'/'.md5(time().mt_rand());
} while (file_exists($path));
$downloader = $this->getDownloader(null, null, null, $filesystem);
$downloader = $this->getDownloader(null, null, null, null, null, $filesystem);
// make sure the file expected to be downloaded is on disk already
mkdir($path, 0777, true);