aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMorris Jobke <hey@morrisjobke.de>2015-01-30 14:08:44 +0100
committerMorris Jobke <hey@morrisjobke.de>2015-01-30 14:08:44 +0100
commite7900ba255df677fbea718e73e52931f8950c811 (patch)
tree125465c3abe3787e6d253fd8ad45761abc347fa8
parentf4d20dc1f30d4ab4748166956fcacdaeb0773e75 (diff)
parentce0aa02aacee6b4e2641bdb1666f5650507ed28a (diff)
downloadnextcloud-server-e7900ba255df677fbea718e73e52931f8950c811.tar.gz
nextcloud-server-e7900ba255df677fbea718e73e52931f8950c811.zip
Merge pull request #13508 from owncloud/failed-delete-cache
Dont remove a file from cache if the delete operation failed
-rw-r--r--apps/files_trashbin/lib/storage.php6
-rw-r--r--apps/files_trashbin/lib/trashbin.php5
-rw-r--r--apps/files_trashbin/tests/storage.php39
-rw-r--r--lib/private/files/view.php6
-rw-r--r--tests/lib/files/view.php23
5 files changed, 72 insertions, 7 deletions
diff --git a/apps/files_trashbin/lib/storage.php b/apps/files_trashbin/lib/storage.php
index 21b4e56d0bb..175889ef95d 100644
--- a/apps/files_trashbin/lib/storage.php
+++ b/apps/files_trashbin/lib/storage.php
@@ -80,11 +80,15 @@ class Storage extends Wrapper {
$result = \OCA\Files_Trashbin\Trashbin::move2trash($filesPath);
// in cross-storage cases the file will be copied
// but not deleted, so we delete it here
- $this->storage->unlink($path);
+ if ($result) {
+ $this->storage->unlink($path);
+ }
} else {
$result = $this->storage->unlink($path);
}
unset($this->deletedFiles[$normalized]);
+ } else if ($this->storage->file_exists($path)) {
+ $result = $this->storage->unlink($path);
}
return $result;
diff --git a/apps/files_trashbin/lib/trashbin.php b/apps/files_trashbin/lib/trashbin.php
index 0576be66b4b..ead7f3e09ca 100644
--- a/apps/files_trashbin/lib/trashbin.php
+++ b/apps/files_trashbin/lib/trashbin.php
@@ -180,6 +180,11 @@ class Trashbin {
}
\OC_FileProxy::$enabled = $proxyStatus;
+ if ($view->file_exists('/files/' . $file_path)) { // failed to delete the original file, abort
+ $view->unlink($trashPath);
+ return false;
+ }
+
if ($sizeOfAddedFiles !== false) {
$size = $sizeOfAddedFiles;
$query = \OC_DB::prepare("INSERT INTO `*PREFIX*files_trash` (`id`,`timestamp`,`location`,`user`) VALUES (?,?,?,?)");
diff --git a/apps/files_trashbin/tests/storage.php b/apps/files_trashbin/tests/storage.php
index d9a18e5a15c..24a04e68b2a 100644
--- a/apps/files_trashbin/tests/storage.php
+++ b/apps/files_trashbin/tests/storage.php
@@ -71,7 +71,7 @@ class Storage extends \Test\TestCase {
public function testSingleStorageDelete() {
$this->assertTrue($this->userView->file_exists('test.txt'));
$this->userView->unlink('test.txt');
- list($storage, ) = $this->userView->resolvePath('test.txt');
+ list($storage,) = $this->userView->resolvePath('test.txt');
$storage->getScanner()->scan(''); // make sure we check the storage
$this->assertFalse($this->userView->getFileInfo('test.txt'));
@@ -123,7 +123,7 @@ class Storage extends \Test\TestCase {
$this->userView->unlink('test.txt');
// rescan trash storage
- list($rootStorage, ) = $this->rootView->resolvePath($this->user . '/files_trashbin');
+ list($rootStorage,) = $this->rootView->resolvePath($this->user . '/files_trashbin');
$rootStorage->getScanner()->scan('');
// check if versions are in trashbin
@@ -158,7 +158,7 @@ class Storage extends \Test\TestCase {
$this->userView->file_exists('substorage/test.txt');
// rescan trash storage
- list($rootStorage, ) = $this->rootView->resolvePath($this->user . '/files_trashbin');
+ list($rootStorage,) = $this->rootView->resolvePath($this->user . '/files_trashbin');
$rootStorage->getScanner()->scan('');
// versions were moved too
@@ -173,4 +173,37 @@ class Storage extends \Test\TestCase {
$results = $this->rootView->getDirectoryContent($this->user . '/files_trashbin/versions/');
$this->assertEquals(0, count($results));
}
+
+ /**
+ * Delete should fail is the source file cant be deleted
+ */
+ public function testSingleStorageDeleteFail() {
+ /**
+ * @var \OC\Files\Storage\Temporary | \PHPUnit_Framework_MockObject_MockObject $storage
+ */
+ $storage = $this->getMockBuilder('\OC\Files\Storage\Temporary')
+ ->setConstructorArgs([[]])
+ ->setMethods(['rename', 'unlink'])
+ ->getMock();
+
+ $storage->expects($this->any())
+ ->method('rename')
+ ->will($this->returnValue(false));
+ $storage->expects($this->any())
+ ->method('unlink')
+ ->will($this->returnValue(false));
+
+ $cache = $storage->getCache();
+
+ Filesystem::mount($storage, [], '/' . $this->user . '/files');
+ $this->userView->file_put_contents('test.txt', 'foo');
+ $this->assertTrue($storage->file_exists('test.txt'));
+ $this->assertFalse($this->userView->unlink('test.txt'));
+ $this->assertTrue($storage->file_exists('test.txt'));
+ $this->assertTrue($cache->inCache('test.txt'));
+
+ // file should not be in the trashbin
+ $results = $this->rootView->getDirectoryContent($this->user . '/files_trashbin/files/');
+ $this->assertEquals(0, count($results));
+ }
}
diff --git a/lib/private/files/view.php b/lib/private/files/view.php
index a2717ce4321..6c720a6f5c0 100644
--- a/lib/private/files/view.php
+++ b/lib/private/files/view.php
@@ -527,7 +527,7 @@ class View {
fclose($target);
if ($result !== false) {
- $storage1->unlink($internalPath1);
+ $result &= $storage1->unlink($internalPath1);
}
}
}
@@ -537,7 +537,7 @@ class View {
if ($this->shouldEmitHooks()) {
$this->emit_file_hooks_post($exists, $path2);
}
- } elseif ($result !== false) {
+ } elseif ($result) {
$this->updater->rename($path1, $path2);
if ($this->shouldEmitHooks($path1) and $this->shouldEmitHooks($path2)) {
\OC_Hook::emit(
@@ -803,7 +803,7 @@ class View {
$result = \OC_FileProxy::runPostProxies($operation, $this->getAbsolutePath($path), $result);
- if (in_array('delete', $hooks)) {
+ if (in_array('delete', $hooks) and $result) {
$this->updater->remove($path);
}
if (in_array('write', $hooks)) {
diff --git a/tests/lib/files/view.php b/tests/lib/files/view.php
index 5e42e5ffd0f..9ddc9c80475 100644
--- a/tests/lib/files/view.php
+++ b/tests/lib/files/view.php
@@ -849,4 +849,27 @@ class View extends \Test\TestCase {
$this->assertEquals($time, $view->filemtime('/test/sub/storage/foo/bar.txt'));
}
+
+ public function testDeleteFailKeepCache() {
+ /**
+ * @var \PHPUnit_Framework_MockObject_MockObject | \OC\Files\Storage\Temporary $storage
+ */
+ $storage = $this->getMockBuilder('\OC\Files\Storage\Temporary')
+ ->setConstructorArgs(array(array()))
+ ->setMethods(array('unlink'))
+ ->getMock();
+ $storage->expects($this->once())
+ ->method('unlink')
+ ->will($this->returnValue(false));
+ $scanner = $storage->getScanner();
+ $cache = $storage->getCache();
+ $storage->file_put_contents('foo.txt', 'asd');
+ $scanner->scan('');
+ \OC\Files\Filesystem::mount($storage, array(), '/test/');
+
+ $view = new \OC\Files\View('/test');
+
+ $this->assertFalse($view->unlink('foo.txt'));
+ $this->assertTrue($cache->inCache('foo.txt'));
+ }
}