From 4b48dd424f37446dd78f4589d2474fbe47097b1f Mon Sep 17 00:00:00 2001 From: Robin Appelman Date: Mon, 1 Jun 2015 14:08:14 +0200 Subject: emit hooks from a view as long as the path is inside the default root --- tests/lib/files/view.php | 29 +++++++++++++++++++++++++++++ 1 file changed, 29 insertions(+) (limited to 'tests/lib/files/view.php') diff --git a/tests/lib/files/view.php b/tests/lib/files/view.php index 06a42d63431..9e4da40a292 100644 --- a/tests/lib/files/view.php +++ b/tests/lib/files/view.php @@ -1107,4 +1107,33 @@ class View extends \Test\TestCase { $view->lockFile('/foo/bar', ILockingProvider::LOCK_SHARED); $view->lockFile('/foo/bar', ILockingProvider::LOCK_EXCLUSIVE); } + + public function hookPathProvider() { + return [ + ['/foo/files', '/foo', true], + ['/foo/files/bar', '/foo', true], + ['/foo', '/foo', false], + ['/foo', '/files/foo', true], + ['/foo', 'filesfoo', false] + ]; + } + + /** + * @dataProvider hookPathProvider + * @param $root + * @param $path + * @param $shouldEmit + */ + public function testHookPaths($root, $path, $shouldEmit) { + $filesystemReflection = new \ReflectionClass('\OC\Files\Filesystem'); + $defaultRootValue = $filesystemReflection->getProperty('defaultInstance'); + $defaultRootValue->setAccessible(true); + $oldRoot = $defaultRootValue->getValue(); + $defaultView = new \OC\Files\View('/foo/files'); + $defaultRootValue->setValue($defaultView); + $view = new \OC\Files\View($root); + $result = \Test_Helper::invokePrivate($view, 'shouldEmitHooks', [$path]); + $defaultRootValue->setValue($oldRoot); + $this->assertEquals($shouldEmit, $result); + } } -- cgit v1.2.3