diff options
author | Thomas Müller <thomas.mueller@tmit.eu> | 2015-03-27 15:18:44 +0100 |
---|---|---|
committer | Thomas Müller <thomas.mueller@tmit.eu> | 2015-03-27 15:18:44 +0100 |
commit | 722e50a112579d851b958a21cf26c2e85a4ce5c2 (patch) | |
tree | 4920288942a5c4e512acb573417f1fb939ad255a /tests | |
parent | 5db932d1e4242fc4830784d63e83d8a20b202efa (diff) | |
parent | cb9ead7dde1403959959ce2dad2a646d850955e4 (diff) | |
download | nextcloud-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.php | 27 |
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); + } } |