Merge pull request #11709 from owncloud/temp-handling
Cleanup handling of temporary files
This commit is contained in:
commit
9fa5483111
3
cron.php
3
cron.php
|
@ -71,8 +71,7 @@ try {
|
||||||
// Handle unexpected errors
|
// Handle unexpected errors
|
||||||
register_shutdown_function('handleUnexpectedShutdown');
|
register_shutdown_function('handleUnexpectedShutdown');
|
||||||
|
|
||||||
// Delete temp folder
|
\OC::$server->getTempManager()->cleanOld();
|
||||||
OC_Helper::cleanTmpNoClean();
|
|
||||||
|
|
||||||
// Exit if background jobs are disabled!
|
// Exit if background jobs are disabled!
|
||||||
$appmode = OC_BackgroundJob::getExecutionType();
|
$appmode = OC_BackgroundJob::getExecutionType();
|
||||||
|
|
|
@ -577,7 +577,8 @@ class OC {
|
||||||
self::registerLocalAddressBook();
|
self::registerLocalAddressBook();
|
||||||
|
|
||||||
//make sure temporary files are cleaned up
|
//make sure temporary files are cleaned up
|
||||||
register_shutdown_function(array('OC_Helper', 'cleanTmp'));
|
$tmpManager = \OC::$server->getTempManager();
|
||||||
|
register_shutdown_function(array($tmpManager, 'clean'));
|
||||||
|
|
||||||
if (OC_Config::getValue('installed', false) && !self::checkUpgrade(false)) {
|
if (OC_Config::getValue('installed', false) && !self::checkUpgrade(false)) {
|
||||||
if (\OC::$server->getAppConfig()->getValue('core', 'backgroundjobs_mode', 'ajax') == 'ajax') {
|
if (\OC::$server->getAppConfig()->getValue('core', 'backgroundjobs_mode', 'ajax') == 'ajax') {
|
||||||
|
|
|
@ -25,7 +25,6 @@
|
||||||
* Collection of useful functions
|
* Collection of useful functions
|
||||||
*/
|
*/
|
||||||
class OC_Helper {
|
class OC_Helper {
|
||||||
private static $tmpFiles = array();
|
|
||||||
private static $mimetypeIcons = array();
|
private static $mimetypeIcons = array();
|
||||||
private static $mimetypeDetector;
|
private static $mimetypeDetector;
|
||||||
private static $templateManager;
|
private static $templateManager;
|
||||||
|
@ -593,136 +592,24 @@ class OC_Helper {
|
||||||
*
|
*
|
||||||
* @param string $postfix
|
* @param string $postfix
|
||||||
* @return string
|
* @return string
|
||||||
|
* @deprecated Use the TempManager instead
|
||||||
*
|
*
|
||||||
* temporary files are automatically cleaned up after the script is finished
|
* temporary files are automatically cleaned up after the script is finished
|
||||||
*/
|
*/
|
||||||
public static function tmpFile($postfix = '') {
|
public static function tmpFile($postfix = '') {
|
||||||
$file = get_temp_dir() . '/' . md5(time() . rand()) . $postfix;
|
return \OC::$server->getTempManager()->getTemporaryFile($postfix);
|
||||||
$fh = fopen($file, 'w');
|
|
||||||
if ($fh!==false){
|
|
||||||
fclose($fh);
|
|
||||||
self::$tmpFiles[] = $file;
|
|
||||||
} else {
|
|
||||||
OC_Log::write(
|
|
||||||
'OC_Helper',
|
|
||||||
sprintf(
|
|
||||||
'Can not create a temporary file in directory %s. Check it exists and has correct permissions',
|
|
||||||
get_temp_dir()
|
|
||||||
),
|
|
||||||
OC_Log::WARN
|
|
||||||
);
|
|
||||||
$file = false;
|
|
||||||
}
|
|
||||||
return $file;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* move a file to oc-noclean temp dir
|
|
||||||
*
|
|
||||||
* @param string $filename
|
|
||||||
* @return mixed
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
public static function moveToNoClean($filename = '') {
|
|
||||||
if ($filename == '') {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
$tmpDirNoClean = get_temp_dir() . '/oc-noclean/';
|
|
||||||
if (!file_exists($tmpDirNoClean) || !is_dir($tmpDirNoClean)) {
|
|
||||||
if (file_exists($tmpDirNoClean)) {
|
|
||||||
unlink($tmpDirNoClean);
|
|
||||||
}
|
|
||||||
mkdir($tmpDirNoClean);
|
|
||||||
}
|
|
||||||
$newname = $tmpDirNoClean . basename($filename);
|
|
||||||
if (rename($filename, $newname)) {
|
|
||||||
return $newname;
|
|
||||||
} else {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* create a temporary folder with an unique filename
|
* create a temporary folder with an unique filename
|
||||||
*
|
*
|
||||||
* @return string
|
* @return string
|
||||||
|
* @deprecated Use the TempManager instead
|
||||||
*
|
*
|
||||||
* temporary files are automatically cleaned up after the script is finished
|
* temporary files are automatically cleaned up after the script is finished
|
||||||
*/
|
*/
|
||||||
public static function tmpFolder() {
|
public static function tmpFolder() {
|
||||||
$path = get_temp_dir() . DIRECTORY_SEPARATOR . md5(time() . rand());
|
return \OC::$server->getTempManager()->getTemporaryFolder();
|
||||||
mkdir($path);
|
|
||||||
self::$tmpFiles[] = $path;
|
|
||||||
return $path . DIRECTORY_SEPARATOR;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* remove all files created by self::tmpFile
|
|
||||||
*/
|
|
||||||
public static function cleanTmp() {
|
|
||||||
$leftoversFile = get_temp_dir() . '/oc-not-deleted';
|
|
||||||
if (file_exists($leftoversFile)) {
|
|
||||||
$leftovers = file($leftoversFile);
|
|
||||||
foreach ($leftovers as $file) {
|
|
||||||
try {
|
|
||||||
self::rmdirr($file);
|
|
||||||
} catch (UnexpectedValueException $ex) {
|
|
||||||
// not really much we can do here anymore
|
|
||||||
if (!is_null(\OC::$server)) {
|
|
||||||
$message = $ex->getMessage();
|
|
||||||
\OC::$server->getLogger()->error("Error deleting file/folder: $file - Reason: $message",
|
|
||||||
array('app' => 'core'));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
unlink($leftoversFile);
|
|
||||||
}
|
|
||||||
|
|
||||||
foreach (self::$tmpFiles as $file) {
|
|
||||||
if (file_exists($file)) {
|
|
||||||
try {
|
|
||||||
if (!self::rmdirr($file)) {
|
|
||||||
file_put_contents($leftoversFile, $file . "\n", FILE_APPEND);
|
|
||||||
}
|
|
||||||
} catch (UnexpectedValueException $ex) {
|
|
||||||
// not really much we can do here anymore
|
|
||||||
if (!is_null(\OC::$server)) {
|
|
||||||
$message = $ex->getMessage();
|
|
||||||
\OC::$server->getLogger()->error("Error deleting file/folder: $file - Reason: $message",
|
|
||||||
array('app' => 'core'));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* remove all files in PHP /oc-noclean temp dir
|
|
||||||
*/
|
|
||||||
public static function cleanTmpNoClean() {
|
|
||||||
$tmpDirNoCleanName=get_temp_dir() . '/oc-noclean/';
|
|
||||||
if(file_exists($tmpDirNoCleanName) && is_dir($tmpDirNoCleanName)) {
|
|
||||||
$files=scandir($tmpDirNoCleanName);
|
|
||||||
foreach($files as $file) {
|
|
||||||
$fileName = $tmpDirNoCleanName . $file;
|
|
||||||
if (!\OC\Files\Filesystem::isIgnoredDir($file) && filemtime($fileName) + 600 < time()) {
|
|
||||||
unlink($fileName);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// if oc-noclean is empty delete it
|
|
||||||
$isTmpDirNoCleanEmpty = true;
|
|
||||||
$tmpDirNoClean = opendir($tmpDirNoCleanName);
|
|
||||||
if(is_resource($tmpDirNoClean)) {
|
|
||||||
while (false !== ($file = readdir($tmpDirNoClean))) {
|
|
||||||
if (!\OC\Files\Filesystem::isIgnoredDir($file)) {
|
|
||||||
$isTmpDirNoCleanEmpty = false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if ($isTmpDirNoCleanEmpty) {
|
|
||||||
rmdir($tmpDirNoCleanName);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -256,6 +256,10 @@ class Server extends SimpleContainer implements IServerContainer {
|
||||||
return new NullQueryLogger();
|
return new NullQueryLogger();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
$this->registerService('TempManager', function ($c) {
|
||||||
|
/** @var Server $c */
|
||||||
|
return new TempManager(get_temp_dir(), $c->getLogger());
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -617,4 +621,13 @@ class Server extends SimpleContainer implements IServerContainer {
|
||||||
function getQueryLogger() {
|
function getQueryLogger() {
|
||||||
return $this->query('QueryLogger');
|
return $this->query('QueryLogger');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the manager for temporary files and folders
|
||||||
|
*
|
||||||
|
* @return \OCP\ITempManager
|
||||||
|
*/
|
||||||
|
function getTempManager() {
|
||||||
|
return $this->query('TempManager');
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,146 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Copyright (c) 2014 Robin Appelman <icewind@owncloud.com>
|
||||||
|
* This file is licensed under the Affero General Public License version 3 or
|
||||||
|
* later.
|
||||||
|
* See the COPYING-README file.
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace OC;
|
||||||
|
|
||||||
|
use OCP\ILogger;
|
||||||
|
use OCP\ITempManager;
|
||||||
|
|
||||||
|
class TempManager implements ITempManager {
|
||||||
|
/**
|
||||||
|
* Current temporary files and folders
|
||||||
|
*
|
||||||
|
* @var string[]
|
||||||
|
*/
|
||||||
|
protected $current = array();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* i.e. /tmp on linux systems
|
||||||
|
*
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
protected $tmpBaseDir;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var \OCP\ILogger
|
||||||
|
*/
|
||||||
|
protected $log;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $baseDir
|
||||||
|
* @param \OCP\ILogger $logger
|
||||||
|
*/
|
||||||
|
public function __construct($baseDir, ILogger $logger) {
|
||||||
|
$this->tmpBaseDir = $baseDir;
|
||||||
|
$this->log = $logger;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function generatePath($postFix) {
|
||||||
|
return $this->tmpBaseDir . '/oc_tmp_' . md5(time() . rand()) . $postFix;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a temporary file and return the path
|
||||||
|
*
|
||||||
|
* @param string $postFix
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function getTemporaryFile($postFix = '') {
|
||||||
|
$file = $this->generatePath($postFix);
|
||||||
|
if (is_writable($this->tmpBaseDir)) {
|
||||||
|
touch($file);
|
||||||
|
$this->current[] = $file;
|
||||||
|
return $file;
|
||||||
|
} else {
|
||||||
|
$this->log->warning(
|
||||||
|
'Can not create a temporary file in directory {dir}. Check it exists and has correct permissions',
|
||||||
|
array(
|
||||||
|
'dir' => $this->tmpBaseDir
|
||||||
|
)
|
||||||
|
);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a temporary folder and return the path
|
||||||
|
*
|
||||||
|
* @param string $postFix
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function getTemporaryFolder($postFix = '') {
|
||||||
|
$path = $this->generatePath($postFix);
|
||||||
|
if (is_writable($this->tmpBaseDir)) {
|
||||||
|
mkdir($path);
|
||||||
|
$this->current[] = $path;
|
||||||
|
return $path . '/';
|
||||||
|
} else {
|
||||||
|
$this->log->warning(
|
||||||
|
'Can not create a temporary folder in directory {dir}. Check it exists and has correct permissions',
|
||||||
|
array(
|
||||||
|
'dir' => $this->tmpBaseDir
|
||||||
|
)
|
||||||
|
);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Remove the temporary files and folders generated during this request
|
||||||
|
*/
|
||||||
|
public function clean() {
|
||||||
|
$this->cleanFiles($this->current);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function cleanFiles($files) {
|
||||||
|
foreach ($files as $file) {
|
||||||
|
if (file_exists($file)) {
|
||||||
|
try {
|
||||||
|
\OC_Helper::rmdirr($file);
|
||||||
|
} catch (\UnexpectedValueException $ex) {
|
||||||
|
$this->log->warning(
|
||||||
|
"Error deleting temporary file/folder: {file} - Reason: {error}",
|
||||||
|
array(
|
||||||
|
'file' => $file,
|
||||||
|
'error' => $ex->getMessage()
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Remove old temporary files and folders that were failed to be cleaned
|
||||||
|
*/
|
||||||
|
public function cleanOld() {
|
||||||
|
$this->cleanFiles($this->getOldFiles());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get all temporary files and folders generated by oc older than an hour
|
||||||
|
*
|
||||||
|
* @return string[]
|
||||||
|
*/
|
||||||
|
protected function getOldFiles() {
|
||||||
|
$cutOfTime = time() - 3600;
|
||||||
|
$files = array();
|
||||||
|
$dh = opendir($this->tmpBaseDir);
|
||||||
|
while (($file = readdir($dh)) !== false) {
|
||||||
|
if (substr($file, 0, 7) === 'oc_tmp_') {
|
||||||
|
$path = $this->tmpBaseDir . '/' . $file;
|
||||||
|
$mtime = filemtime($path);
|
||||||
|
if ($mtime < $cutOfTime) {
|
||||||
|
$files[] = $path;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return $files;
|
||||||
|
}
|
||||||
|
}
|
|
@ -264,4 +264,11 @@ interface IServerContainer {
|
||||||
* @return \OCP\Diagnostics\IQueryLogger
|
* @return \OCP\Diagnostics\IQueryLogger
|
||||||
*/
|
*/
|
||||||
function getQueryLogger();
|
function getQueryLogger();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the manager for temporary files and folders
|
||||||
|
*
|
||||||
|
* @return \OCP\ITempManager
|
||||||
|
*/
|
||||||
|
function getTempManager();
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,38 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Copyright (c) 2014 Robin Appelman <icewind@owncloud.com>
|
||||||
|
* This file is licensed under the Affero General Public License version 3 or
|
||||||
|
* later.
|
||||||
|
* See the COPYING-README file.
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace OCP;
|
||||||
|
|
||||||
|
interface ITempManager {
|
||||||
|
/**
|
||||||
|
* Create a temporary file and return the path
|
||||||
|
*
|
||||||
|
* @param string $postFix
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function getTemporaryFile($postFix = '');
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a temporary folder and return the path
|
||||||
|
*
|
||||||
|
* @param string $postFix
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function getTemporaryFolder($postFix = '');
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Remove the temporary files and folders generated during this request
|
||||||
|
*/
|
||||||
|
public function clean();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Remove old temporary files and folders that were failed to be cleaned
|
||||||
|
*/
|
||||||
|
public function cleanOld();
|
||||||
|
}
|
|
@ -0,0 +1,143 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Copyright (c) 2014 Robin Appelman <icewind@owncloud.com>
|
||||||
|
* This file is licensed under the Affero General Public License version 3 or
|
||||||
|
* later.
|
||||||
|
* See the COPYING-README file.
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace Test;
|
||||||
|
|
||||||
|
use OC\Log;
|
||||||
|
|
||||||
|
class NullLogger extends Log {
|
||||||
|
public function __construct($logger = null) {
|
||||||
|
//disable original constructor
|
||||||
|
}
|
||||||
|
|
||||||
|
public function log($level, $message, array $context = array()) {
|
||||||
|
//noop
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class TempManager extends \PHPUnit_Framework_TestCase {
|
||||||
|
protected $baseDir;
|
||||||
|
|
||||||
|
public function setUp() {
|
||||||
|
$this->baseDir = get_temp_dir() . '/oc_tmp_test';
|
||||||
|
if (!is_dir($this->baseDir)) {
|
||||||
|
mkdir($this->baseDir);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function tearDown() {
|
||||||
|
\OC_Helper::rmdirr($this->baseDir);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param \Psr\Log\LoggerInterface $logger
|
||||||
|
* @return \OC\TempManager
|
||||||
|
*/
|
||||||
|
protected function getManager($logger = null) {
|
||||||
|
if (!$logger) {
|
||||||
|
$logger = new NullLogger();
|
||||||
|
}
|
||||||
|
return new \OC\TempManager($this->baseDir, $logger);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGetFile() {
|
||||||
|
$manager = $this->getManager();
|
||||||
|
$file = $manager->getTemporaryFile('.txt');
|
||||||
|
$this->assertStringEndsWith('.txt', $file);
|
||||||
|
$this->assertTrue(is_file($file));
|
||||||
|
$this->assertTrue(is_writable($file));
|
||||||
|
|
||||||
|
file_put_contents($file, 'bar');
|
||||||
|
$this->assertEquals('bar', file_get_contents($file));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGetFolder() {
|
||||||
|
$manager = $this->getManager();
|
||||||
|
$folder = $manager->getTemporaryFolder();
|
||||||
|
$this->assertStringEndsWith('/', $folder);
|
||||||
|
$this->assertTrue(is_dir($folder));
|
||||||
|
$this->assertTrue(is_writable($folder));
|
||||||
|
|
||||||
|
file_put_contents($folder . 'foo.txt', 'bar');
|
||||||
|
$this->assertEquals('bar', file_get_contents($folder . 'foo.txt'));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testCleanFiles() {
|
||||||
|
$manager = $this->getManager();
|
||||||
|
$file1 = $manager->getTemporaryFile('.txt');
|
||||||
|
$file2 = $manager->getTemporaryFile('.txt');
|
||||||
|
$this->assertTrue(file_exists($file1));
|
||||||
|
$this->assertTrue(file_exists($file2));
|
||||||
|
|
||||||
|
$manager->clean();
|
||||||
|
|
||||||
|
$this->assertFalse(file_exists($file1));
|
||||||
|
$this->assertFalse(file_exists($file2));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testCleanFolder() {
|
||||||
|
$manager = $this->getManager();
|
||||||
|
$folder1 = $manager->getTemporaryFolder();
|
||||||
|
$folder2 = $manager->getTemporaryFolder();
|
||||||
|
touch($folder1 . 'foo.txt');
|
||||||
|
touch($folder1 . 'bar.txt');
|
||||||
|
$this->assertTrue(file_exists($folder1));
|
||||||
|
$this->assertTrue(file_exists($folder2));
|
||||||
|
$this->assertTrue(file_exists($folder1 . 'foo.txt'));
|
||||||
|
$this->assertTrue(file_exists($folder1 . 'bar.txt'));
|
||||||
|
|
||||||
|
$manager->clean();
|
||||||
|
|
||||||
|
$this->assertFalse(file_exists($folder1));
|
||||||
|
$this->assertFalse(file_exists($folder2));
|
||||||
|
$this->assertFalse(file_exists($folder1 . 'foo.txt'));
|
||||||
|
$this->assertFalse(file_exists($folder1 . 'bar.txt'));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testCleanOld() {
|
||||||
|
$manager = $this->getManager();
|
||||||
|
$oldFile = $manager->getTemporaryFile('.txt');
|
||||||
|
$newFile = $manager->getTemporaryFile('.txt');
|
||||||
|
$folder = $manager->getTemporaryFolder();
|
||||||
|
$nonOcFile = $this->baseDir . '/foo.txt';
|
||||||
|
file_put_contents($nonOcFile, 'bar');
|
||||||
|
|
||||||
|
$past = time() - 2 * 3600;
|
||||||
|
touch($oldFile, $past);
|
||||||
|
touch($folder, $past);
|
||||||
|
touch($nonOcFile, $past);
|
||||||
|
|
||||||
|
$manager2 = $this->getManager();
|
||||||
|
$manager2->cleanOld();
|
||||||
|
$this->assertFalse(file_exists($oldFile));
|
||||||
|
$this->assertFalse(file_exists($folder));
|
||||||
|
$this->assertTrue(file_exists($nonOcFile));
|
||||||
|
$this->assertTrue(file_exists($newFile));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testLogCantCreateFile() {
|
||||||
|
$logger = $this->getMock('\Test\NullLogger');
|
||||||
|
$manager = $this->getManager($logger);
|
||||||
|
chmod($this->baseDir, 0500);
|
||||||
|
$logger->expects($this->once())
|
||||||
|
->method('warning')
|
||||||
|
->with($this->stringContains('Can not create a temporary file in directory'));
|
||||||
|
$this->assertFalse($manager->getTemporaryFile('.txt'));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testLogCantCreateFolder() {
|
||||||
|
$logger = $this->getMock('\Test\NullLogger');
|
||||||
|
$manager = $this->getManager($logger);
|
||||||
|
chmod($this->baseDir, 0500);
|
||||||
|
$logger->expects($this->once())
|
||||||
|
->method('warning')
|
||||||
|
->with($this->stringContains('Can not create a temporary folder in directory'));
|
||||||
|
$this->assertFalse($manager->getTemporaryFolder());
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue