aboutsummaryrefslogtreecommitdiffstats
path: root/apps/files_trashbin/tests/StorageTest.php
diff options
context:
space:
mode:
authorRobin Appelman <robin@icewind.nl>2021-02-10 16:43:24 +0100
committerRobin Appelman <robin@icewind.nl>2021-02-17 16:08:57 +0100
commitb5db4502d02dda5becbe3e10b469c65fad969a7b (patch)
tree0588530b82a5a611fd7d13086b40c9c2700e2d65 /apps/files_trashbin/tests/StorageTest.php
parentd4b99c81f32453f57cb2c132fa46c6b5219b9e99 (diff)
downloadnextcloud-server-b5db4502d02dda5becbe3e10b469c65fad969a7b.tar.gz
nextcloud-server-b5db4502d02dda5becbe3e10b469c65fad969a7b.zip
disable trasbin during the moveFromStorage fallback
Signed-off-by: Robin Appelman <robin@icewind.nl>
Diffstat (limited to 'apps/files_trashbin/tests/StorageTest.php')
-rw-r--r--apps/files_trashbin/tests/StorageTest.php29
1 files changed, 29 insertions, 0 deletions
diff --git a/apps/files_trashbin/tests/StorageTest.php b/apps/files_trashbin/tests/StorageTest.php
index f86e0d12a95..53c1a09cc39 100644
--- a/apps/files_trashbin/tests/StorageTest.php
+++ b/apps/files_trashbin/tests/StorageTest.php
@@ -33,6 +33,7 @@
namespace OCA\Files_Trashbin\Tests;
use OC\Files\Filesystem;
+use OC\Files\Storage\Common;
use OC\Files\Storage\Temporary;
use OCA\Files_Trashbin\AppInfo\Application;
use OCA\Files_Trashbin\Events\MoveToTrashEvent;
@@ -44,11 +45,23 @@ use OCP\Files\Cache\ICache;
use OCP\Files\Folder;
use OCP\Files\IRootFolder;
use OCP\Files\Node;
+use OCP\Files\Storage\IStorage;
use OCP\ILogger;
use OCP\IUserManager;
use OCP\Lock\ILockingProvider;
use OCP\Share\IShare;
use Symfony\Component\EventDispatcher\EventDispatcherInterface;
+use Test\Traits\MountProviderTrait;
+
+class TemporaryNoCross extends Temporary {
+ public function copyFromStorage(IStorage $sourceStorage, $sourceInternalPath, $targetInternalPath, $preserveMtime = null) {
+ return Common::copyFromStorage($sourceStorage, $sourceInternalPath, $targetInternalPath, $preserveMtime);
+ }
+
+ public function moveFromStorage(IStorage $sourceStorage, $sourceInternalPath, $targetInternalPath) {
+ return Common::moveFromStorage($sourceStorage, $sourceInternalPath, $targetInternalPath);
+ }
+}
/**
* Class Storage
@@ -58,6 +71,8 @@ use Symfony\Component\EventDispatcher\EventDispatcherInterface;
* @package OCA\Files_Trashbin\Tests
*/
class StorageTest extends \Test\TestCase {
+ use MountProviderTrait;
+
/**
* @var string
*/
@@ -645,4 +660,18 @@ class StorageTest extends \Test\TestCase {
$this->assertEquals('foo', $this->rootView->file_get_contents($this->user . '/files_trashbin/files/test.txt.d1000'));
$this->assertEquals('bar', $this->rootView->file_get_contents($this->user . '/files_trashbin/files/test.txt.d1001'));
}
+
+ public function testMoveFromStoragePreserveFileId() {
+ $this->userView->file_put_contents('test.txt', 'foo');
+ $fileId = $this->userView->getFileInfo('test.txt')->getId();
+
+ $externalStorage = new TemporaryNoCross([]);
+ $externalStorage->getScanner()->scan('');
+ Filesystem::mount($externalStorage, [], "/" . $this->user . "/files/storage");
+
+ $this->assertTrue($this->userView->rename('test.txt', 'storage/test.txt'));
+ $this->assertTrue($externalStorage->file_exists('test.txt'));
+
+ $this->assertEquals($fileId, $this->userView->getFileInfo('storage/test.txt')->getId());
+ }
}