123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303 |
- <?php
- /**
- * SPDX-FileCopyrightText: 2016-2024 Nextcloud GmbH and Nextcloud contributors
- * SPDX-FileCopyrightText: 2016 ownCloud, Inc.
- * SPDX-License-Identifier: AGPL-3.0-or-later
- */
- namespace Test\Files\Node;
- /**
- * Class FileTest
- *
- * @group DB
- *
- * @package Test\Files\Node
- */
- class FileTest extends NodeTest {
- protected function createTestNode($root, $view, $path, array $data = [], $internalPath = '', $storage = null) {
- if ($data || $internalPath || $storage) {
- return new \OC\Files\Node\File($root, $view, $path, $this->getFileInfo($data, $internalPath, $storage));
- } else {
- return new \OC\Files\Node\File($root, $view, $path);
- }
- }
- protected function getNodeClass() {
- return '\OC\Files\Node\File';
- }
- protected function getNonExistingNodeClass() {
- return '\OC\Files\Node\NonExistingFile';
- }
- protected function getViewDeleteMethod() {
- return 'unlink';
- }
- public function testGetContent(): void {
- /** @var \OC\Files\Node\Root|\PHPUnit\Framework\MockObject\MockObject $root */
- $root = $this->getMockBuilder('\OC\Files\Node\Root')
- ->setConstructorArgs([$this->manager, $this->view, $this->user, $this->userMountCache, $this->logger, $this->userManager, $this->eventDispatcher, $this->cacheFactory])
- ->getMock();
- $hook = function ($file) {
- throw new \Exception('Hooks are not supposed to be called');
- };
- $root->listen('\OC\Files', 'preWrite', $hook);
- $root->listen('\OC\Files', 'postWrite', $hook);
- $this->view->expects($this->once())
- ->method('file_get_contents')
- ->with('/bar/foo')
- ->willReturn('bar');
- $this->view->expects($this->once())
- ->method('getFileInfo')
- ->with('/bar/foo')
- ->willReturn($this->getFileInfo(['permissions' => \OCP\Constants::PERMISSION_READ]));
- $node = new \OC\Files\Node\File($root, $this->view, '/bar/foo');
- $this->assertEquals('bar', $node->getContent());
- }
- public function testGetContentNotPermitted(): void {
- $this->expectException(\OCP\Files\NotPermittedException::class);
- /** @var \OC\Files\Node\Root|\PHPUnit\Framework\MockObject\MockObject $root */
- $root = $this->getMockBuilder('\OC\Files\Node\Root')
- ->setConstructorArgs([$this->manager, $this->view, $this->user, $this->userMountCache, $this->logger, $this->userManager, $this->eventDispatcher, $this->cacheFactory])
- ->getMock();
- $root->expects($this->any())
- ->method('getUser')
- ->willReturn($this->user);
- $this->view->expects($this->once())
- ->method('getFileInfo')
- ->with('/bar/foo')
- ->willReturn($this->getFileInfo(['permissions' => 0]));
- $node = new \OC\Files\Node\File($root, $this->view, '/bar/foo');
- $node->getContent();
- }
- public function testPutContent(): void {
- /** @var \OC\Files\Node\Root|\PHPUnit\Framework\MockObject\MockObject $root */
- $root = $this->getMockBuilder('\OC\Files\Node\Root')
- ->setConstructorArgs([$this->manager, $this->view, $this->user, $this->userMountCache, $this->logger, $this->userManager, $this->eventDispatcher, $this->cacheFactory])
- ->getMock();
- $root->expects($this->any())
- ->method('getUser')
- ->willReturn($this->user);
- $this->view->expects($this->once())
- ->method('getFileInfo')
- ->with('/bar/foo')
- ->willReturn($this->getFileInfo(['permissions' => \OCP\Constants::PERMISSION_ALL]));
- $this->view->expects($this->once())
- ->method('file_put_contents')
- ->with('/bar/foo', 'bar')
- ->willReturn(true);
- $node = new \OC\Files\Node\File($root, $this->view, '/bar/foo');
- $node->putContent('bar');
- }
- public function testPutContentNotPermitted(): void {
- $this->expectException(\OCP\Files\NotPermittedException::class);
- /** @var \OC\Files\Node\Root|\PHPUnit\Framework\MockObject\MockObject $root */
- $root = $this->getMockBuilder('\OC\Files\Node\Root')
- ->setConstructorArgs([$this->manager, $this->view, $this->user, $this->userMountCache, $this->logger, $this->userManager, $this->eventDispatcher, $this->cacheFactory])
- ->getMock();
- $this->view->expects($this->once())
- ->method('getFileInfo')
- ->with('/bar/foo')
- ->willReturn($this->getFileInfo(['permissions' => \OCP\Constants::PERMISSION_READ]));
- $node = new \OC\Files\Node\File($root, $this->view, '/bar/foo');
- $node->putContent('bar');
- }
- public function testGetMimeType(): void {
- /** @var \OC\Files\Node\Root|\PHPUnit\Framework\MockObject\MockObject $root */
- $root = $this->getMockBuilder('\OC\Files\Node\Root')
- ->setConstructorArgs([$this->manager, $this->view, $this->user, $this->userMountCache, $this->logger, $this->userManager, $this->eventDispatcher, $this->cacheFactory])
- ->getMock();
- $this->view->expects($this->once())
- ->method('getFileInfo')
- ->with('/bar/foo')
- ->willReturn($this->getFileInfo(['mimetype' => 'text/plain']));
- $node = new \OC\Files\Node\File($root, $this->view, '/bar/foo');
- $this->assertEquals('text/plain', $node->getMimeType());
- }
- public function testFOpenRead(): void {
- $stream = fopen('php://memory', 'w+');
- fwrite($stream, 'bar');
- rewind($stream);
- $root = new \OC\Files\Node\Root(
- $this->manager,
- $this->view,
- $this->user,
- $this->userMountCache,
- $this->logger,
- $this->userManager,
- $this->eventDispatcher,
- $this->cacheFactory,
- );
- $hook = function ($file) {
- throw new \Exception('Hooks are not supposed to be called');
- };
- $root->listen('\OC\Files', 'preWrite', $hook);
- $root->listen('\OC\Files', 'postWrite', $hook);
- $this->view->expects($this->once())
- ->method('fopen')
- ->with('/bar/foo', 'r')
- ->willReturn($stream);
- $this->view->expects($this->once())
- ->method('getFileInfo')
- ->with('/bar/foo')
- ->willReturn($this->getFileInfo(['permissions' => \OCP\Constants::PERMISSION_ALL]));
- $node = new \OC\Files\Node\File($root, $this->view, '/bar/foo');
- $fh = $node->fopen('r');
- $this->assertEquals($stream, $fh);
- $this->assertEquals('bar', fread($fh, 3));
- }
- public function testFOpenWrite(): void {
- $stream = fopen('php://memory', 'w+');
- $root = new \OC\Files\Node\Root(
- $this->manager,
- $this->view,
- $this->user,
- $this->userMountCache,
- $this->logger,
- $this->userManager,
- $this->eventDispatcher,
- $this->cacheFactory,
- );
- $hooksCalled = 0;
- $hook = function ($file) use (&$hooksCalled) {
- $hooksCalled++;
- };
- $root->listen('\OC\Files', 'preWrite', $hook);
- $root->listen('\OC\Files', 'postWrite', $hook);
- $this->view->expects($this->once())
- ->method('fopen')
- ->with('/bar/foo', 'w')
- ->willReturn($stream);
- $this->view->expects($this->once())
- ->method('getFileInfo')
- ->with('/bar/foo')
- ->willReturn($this->getFileInfo(['permissions' => \OCP\Constants::PERMISSION_ALL]));
- $node = new \OC\Files\Node\File($root, $this->view, '/bar/foo');
- $fh = $node->fopen('w');
- $this->assertEquals($stream, $fh);
- fwrite($fh, 'bar');
- rewind($fh);
- $this->assertEquals('bar', fread($stream, 3));
- $this->assertEquals(2, $hooksCalled);
- }
- public function testFOpenReadNotPermitted(): void {
- $this->expectException(\OCP\Files\NotPermittedException::class);
- $root = new \OC\Files\Node\Root(
- $this->manager,
- $this->view,
- $this->user,
- $this->userMountCache,
- $this->logger,
- $this->userManager,
- $this->eventDispatcher,
- $this->cacheFactory,
- );
- $hook = function ($file) {
- throw new \Exception('Hooks are not supposed to be called');
- };
- $this->view->expects($this->once())
- ->method('getFileInfo')
- ->with('/bar/foo')
- ->willReturn($this->getFileInfo(['permissions' => 0]));
- $node = new \OC\Files\Node\File($root, $this->view, '/bar/foo');
- $node->fopen('r');
- }
- public function testFOpenReadWriteNoReadPermissions(): void {
- $this->expectException(\OCP\Files\NotPermittedException::class);
- $root = new \OC\Files\Node\Root(
- $this->manager,
- $this->view,
- $this->user,
- $this->userMountCache,
- $this->logger,
- $this->userManager,
- $this->eventDispatcher,
- $this->cacheFactory,
- );
- $hook = function () {
- throw new \Exception('Hooks are not supposed to be called');
- };
- $this->view->expects($this->once())
- ->method('getFileInfo')
- ->with('/bar/foo')
- ->willReturn($this->getFileInfo(['permissions' => \OCP\Constants::PERMISSION_UPDATE]));
- $node = new \OC\Files\Node\File($root, $this->view, '/bar/foo');
- $node->fopen('w');
- }
- public function testFOpenReadWriteNoWritePermissions(): void {
- $this->expectException(\OCP\Files\NotPermittedException::class);
- $root = new \OC\Files\Node\Root(
- $this->manager,
- $this->view,
- $this->user,
- $this->userMountCache,
- $this->logger,
- $this->userManager,
- $this->eventDispatcher,
- $this->cacheFactory,
- );
- $hook = function () {
- throw new \Exception('Hooks are not supposed to be called');
- };
- $this->view->expects($this->once())
- ->method('getFileInfo')
- ->with('/bar/foo')
- ->willReturn($this->getFileInfo(['permissions' => \OCP\Constants::PERMISSION_READ]));
- $node = new \OC\Files\Node\File($root, $this->view, '/bar/foo');
- $node->fopen('w');
- }
- }
|