summaryrefslogtreecommitdiffstats
path: root/tests
diff options
context:
space:
mode:
authorThomas Müller <thomas.mueller@tmit.eu>2015-03-27 15:18:44 +0100
committerThomas Müller <thomas.mueller@tmit.eu>2015-03-27 15:18:44 +0100
commit722e50a112579d851b958a21cf26c2e85a4ce5c2 (patch)
tree4920288942a5c4e512acb573417f1fb939ad255a /tests
parent5db932d1e4242fc4830784d63e83d8a20b202efa (diff)
parentcb9ead7dde1403959959ce2dad2a646d850955e4 (diff)
downloadnextcloud-server-722e50a112579d851b958a21cf26c2e85a4ce5c2.tar.gz
nextcloud-server-722e50a112579d851b958a21cf26c2e85a4ce5c2.zip
Merge pull request #15240 from owncloud/storage-wrapper-priority
add priority to storage wrappers
Diffstat (limited to 'tests')
-rw-r--r--tests/lib/files/storage/storagefactory.php27
1 files changed, 27 insertions, 0 deletions
diff --git a/tests/lib/files/storage/storagefactory.php b/tests/lib/files/storage/storagefactory.php
index 15519ef83fb..fcdff577dd5 100644
--- a/tests/lib/files/storage/storagefactory.php
+++ b/tests/lib/files/storage/storagefactory.php
@@ -15,7 +15,14 @@ use Test\TestCase;
use OC\Files\Storage\Wrapper\Wrapper;
class DummyWrapper extends Wrapper {
+ public $data;
+ public function __construct($arguments) {
+ parent::__construct($arguments);
+ if (isset($arguments['data'])) {
+ $this->data = $arguments['data'];
+ }
+ }
}
class StorageFactory extends TestCase {
@@ -42,4 +49,24 @@ class StorageFactory extends TestCase {
$wrapped = $mount->getStorage();
$this->assertInstanceOf('\OC\Files\Storage\Temporary', $wrapped);
}
+
+ public function testWrapperPriority() {
+ $instance = new \OC\Files\Storage\StorageFactory();
+ $mount = new MountPoint('\OC\Files\Storage\Temporary', '/foo', [[]], $instance);
+ $instance->addStorageWrapper('dummy1', function ($mountPoint, IStorage $storage) {
+ return new DummyWrapper(['storage' => $storage, 'data' => 1]);
+ }, 1);
+ $instance->addStorageWrapper('dummy2', function ($mountPoint, IStorage $storage) {
+ return new DummyWrapper(['storage' => $storage, 'data' => 100]);
+ }, 100);
+ $instance->addStorageWrapper('dummy3', function ($mountPoint, IStorage $storage) {
+ return new DummyWrapper(['storage' => $storage, 'data' => 50]);
+ }, 50);
+ /** @var \Test\Files\Storage\DummyWrapper $wrapped */
+ $wrapped = $mount->getStorage();
+ $this->assertInstanceOf('\Test\Files\Storage\DummyWrapper', $wrapped);
+ $this->assertEquals(1, $wrapped->data);// lowest priority is applied last, called first
+ $this->assertEquals(50, $wrapped->getWrapperStorage()->data);
+ $this->assertEquals(100, $wrapped->getWrapperStorage()->getWrapperStorage()->data);
+ }
}