summaryrefslogtreecommitdiffstats
path: root/tests/lib
diff options
context:
space:
mode:
authorMorris Jobke <hey@morrisjobke.de>2017-07-13 23:27:01 +0200
committerGitHub <noreply@github.com>2017-07-13 23:27:01 +0200
commit1f1504e071d38dffd274cd9b4123d2093a6beb3e (patch)
treeeb276d206866df66cf50183108b2a78a535bc039 /tests/lib
parent01466ab8403c9f1fb1f2a92490bbf1be82db0a43 (diff)
parent03f27b4c2c2c3a6d3187a877cf5feb93830b7a9f (diff)
downloadnextcloud-server-1f1504e071d38dffd274cd9b4123d2093a6beb3e.tar.gz
nextcloud-server-1f1504e071d38dffd274cd9b4123d2093a6beb3e.zip
Merge pull request #5708 from nextcloud/nested-permissions-mask
Fix scan permissions with nested permissions masks
Diffstat (limited to 'tests/lib')
-rw-r--r--tests/lib/Files/Storage/Wrapper/PermissionsMaskTest.php15
1 files changed, 15 insertions, 0 deletions
diff --git a/tests/lib/Files/Storage/Wrapper/PermissionsMaskTest.php b/tests/lib/Files/Storage/Wrapper/PermissionsMaskTest.php
index 354db9d069d..388272b4107 100644
--- a/tests/lib/Files/Storage/Wrapper/PermissionsMaskTest.php
+++ b/tests/lib/Files/Storage/Wrapper/PermissionsMaskTest.php
@@ -127,6 +127,21 @@ class PermissionsMaskTest extends \Test\Files\Storage\Storage {
$this->assertEquals(Constants::PERMISSION_READ, $storage->getCache()->get('foo')->getPermissions());
}
+ public function testScanNewFilesNested() {
+ $storage = $this->getMaskedStorage(Constants::PERMISSION_READ + Constants::PERMISSION_CREATE + Constants::PERMISSION_UPDATE);
+ $nestedStorage = new \OC\Files\Storage\Wrapper\PermissionsMask(array(
+ 'storage' => $storage,
+ 'mask' => Constants::PERMISSION_READ + Constants::PERMISSION_CREATE
+ ));
+ $wrappedStorage = new Wrapper(['storage' => $nestedStorage]);
+ $wrappedStorage->file_put_contents('foo', 'bar');
+ $wrappedStorage->getScanner()->scan('');
+
+ $this->assertEquals(Constants::PERMISSION_ALL - Constants::PERMISSION_CREATE, $this->sourceStorage->getCache()->get('foo')->getPermissions());
+ $this->assertEquals(Constants::PERMISSION_READ + Constants::PERMISSION_UPDATE, $storage->getCache()->get('foo')->getPermissions());
+ $this->assertEquals(Constants::PERMISSION_READ, $wrappedStorage->getCache()->get('foo')->getPermissions());
+ }
+
public function testScanUnchanged() {
$this->sourceStorage->mkdir('foo');
$this->sourceStorage->file_put_contents('foo/bar.txt', 'bar');