aboutsummaryrefslogtreecommitdiffstats
path: root/apps/files_trashbin/tests
diff options
context:
space:
mode:
authorRobin Appelman <icewind@owncloud.com>2015-01-28 15:35:49 +0100
committerRobin Appelman <icewind@owncloud.com>2015-01-29 15:39:58 +0100
commitd4c4e2a3221bdba82c60e5428a5b151b4f21ad10 (patch)
tree22b6ea78bed401d97879af4cbb0e1d9e4ef396e5 /apps/files_trashbin/tests
parent2124540d1d9f500423e5149b1490ed489788ff1d (diff)
downloadnextcloud-server-d4c4e2a3221bdba82c60e5428a5b151b4f21ad10.tar.gz
nextcloud-server-d4c4e2a3221bdba82c60e5428a5b151b4f21ad10.zip
Detect failed deletes in the trashbin
Diffstat (limited to 'apps/files_trashbin/tests')
-rw-r--r--apps/files_trashbin/tests/storage.php39
1 files changed, 36 insertions, 3 deletions
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));
+ }
}