diff options
author | Lukas Reschke <lukas@owncloud.com> | 2015-02-20 14:56:13 +0100 |
---|---|---|
committer | Lukas Reschke <lukas@owncloud.com> | 2015-02-20 14:56:13 +0100 |
commit | 6e9a2515eaa38eb949fd6d406e03e47c6360b66c (patch) | |
tree | e7ad395e11dd6d52e7cbafc97a0ca7ea037fae75 /apps/files/tests | |
parent | 50208308e38fb8c8e586c790b91c4cfa489b197b (diff) | |
parent | 3213b04aef30a66c7eebb750bfc4bbb6fe6cfa78 (diff) | |
download | nextcloud-server-6e9a2515eaa38eb949fd6d406e03e47c6360b66c.tar.gz nextcloud-server-6e9a2515eaa38eb949fd6d406e03e47c6360b66c.zip |
Merge pull request #14278 from owncloud/fix-index
Check if the offset exists before accessing
Diffstat (limited to 'apps/files/tests')
-rw-r--r-- | apps/files/tests/controller/apicontrollertest.php | 243 |
1 files changed, 243 insertions, 0 deletions
diff --git a/apps/files/tests/controller/apicontrollertest.php b/apps/files/tests/controller/apicontrollertest.php new file mode 100644 index 00000000000..1be7a749a1b --- /dev/null +++ b/apps/files/tests/controller/apicontrollertest.php @@ -0,0 +1,243 @@ +<?php +/** + * Copyright (c) 2015 Lukas Reschke <lukas@owncloud.com> + * This file is licensed under the Affero General Public License version 3 or + * later. + * See the COPYING-README file. + */ + +namespace OCA\Files\Controller; + +use OC\Files\FileInfo; +use OCP\AppFramework\Http; +use OC\Preview; +use OCP\Files\NotFoundException; +use OCP\Files\StorageNotAvailableException; +use Test\TestCase; +use OCP\IRequest; +use OCA\Files\Service\TagService; +use OCP\AppFramework\Http\DataResponse; + +/** + * Class ApiController + * + * @package OCA\Files\Controller + */ +class ApiControllerTest extends TestCase { + /** @var string */ + private $appName = 'files'; + /** @var IRequest */ + private $request; + /** @var TagService */ + private $tagService; + /** @var ApiController */ + private $apiController; + + public function setUp() { + $this->request = $this->getMockBuilder('\OCP\IRequest') + ->disableOriginalConstructor() + ->getMock(); + $this->tagService = $this->getMockBuilder('\OCA\Files\Service\TagService') + ->disableOriginalConstructor() + ->getMock(); + + $this->apiController = new ApiController( + $this->appName, + $this->request, + $this->tagService + ); + } + + public function testGetFilesByTagEmpty() { + $tagName = 'MyTagName'; + $this->tagService->expects($this->once()) + ->method('getFilesByTag') + ->with($this->equalTo([$tagName])) + ->will($this->returnValue([])); + + $expected = new DataResponse(['files' => []]); + $this->assertEquals($expected, $this->apiController->getFilesByTag([$tagName])); + } + + public function testGetFilesByTagSingle() { + $tagName = 'MyTagName'; + $fileInfo = new FileInfo( + '/root.txt', + $this->getMockBuilder('\OC\Files\Storage\Storage') + ->disableOriginalConstructor() + ->getMock(), + '/var/www/root.txt', + [ + 'mtime' => 55, + 'mimetype' => 'application/pdf', + 'size' => 1234, + 'etag' => 'MyEtag', + ], + $this->getMockBuilder('\OCP\Files\Mount\IMountPoint') + ->disableOriginalConstructor() + ->getMock() + ); + $this->tagService->expects($this->once()) + ->method('getFilesByTag') + ->with($this->equalTo([$tagName])) + ->will($this->returnValue([$fileInfo])); + + $expected = new DataResponse([ + 'files' => [ + [ + 'id' => null, + 'parentId' => null, + 'date' => 'January 1, 1970 at 12:00:55 AM GMT+0', + 'mtime' => 55000, + 'icon' => \OCA\Files\Helper::determineIcon($fileInfo), + 'name' => 'root.txt', + 'permissions' => null, + 'mimetype' => 'application/pdf', + 'size' => 1234, + 'type' => 'file', + 'etag' => 'MyEtag', + 'path' => '/', + 'tags' => [ + [ + 'MyTagName' + ] + ], + ], + ], + ]); + $this->assertEquals($expected, $this->apiController->getFilesByTag([$tagName])); + } + + public function testGetFilesByTagMultiple() { + $tagName = 'MyTagName'; + $fileInfo1 = new FileInfo( + '/root.txt', + $this->getMockBuilder('\OC\Files\Storage\Storage') + ->disableOriginalConstructor() + ->getMock(), + '/var/www/root.txt', + [ + 'mtime' => 55, + 'mimetype' => 'application/pdf', + 'size' => 1234, + 'etag' => 'MyEtag', + ], + $this->getMockBuilder('\OCP\Files\Mount\IMountPoint') + ->disableOriginalConstructor() + ->getMock() + ); + $fileInfo2 = new FileInfo( + '/root.txt', + $this->getMockBuilder('\OC\Files\Storage\Storage') + ->disableOriginalConstructor() + ->getMock(), + '/var/www/some/sub.txt', + [ + 'mtime' => 999, + 'mimetype' => 'application/binary', + 'size' => 9876, + 'etag' => 'SubEtag', + ], + $this->getMockBuilder('\OCP\Files\Mount\IMountPoint') + ->disableOriginalConstructor() + ->getMock() + ); + $this->tagService->expects($this->once()) + ->method('getFilesByTag') + ->with($this->equalTo([$tagName])) + ->will($this->returnValue([$fileInfo1, $fileInfo2])); + + $expected = new DataResponse([ + 'files' => [ + [ + 'id' => null, + 'parentId' => null, + 'date' => 'January 1, 1970 at 12:00:55 AM GMT+0', + 'mtime' => 55000, + 'icon' => \OCA\Files\Helper::determineIcon($fileInfo1), + 'name' => 'root.txt', + 'permissions' => null, + 'mimetype' => 'application/pdf', + 'size' => 1234, + 'type' => 'file', + 'etag' => 'MyEtag', + 'path' => '/', + 'tags' => [ + [ + 'MyTagName' + ] + ], + ], + [ + 'id' => null, + 'parentId' => null, + 'date' => 'January 1, 1970 at 12:16:39 AM GMT+0', + 'mtime' => 999000, + 'icon' => \OCA\Files\Helper::determineIcon($fileInfo2), + 'name' => 'root.txt', + 'permissions' => null, + 'mimetype' => 'application/binary', + 'size' => 9876, + 'type' => 'file', + 'etag' => 'SubEtag', + 'path' => '/', + 'tags' => [ + [ + 'MyTagName' + ] + ], + ] + ], + ]); + $this->assertEquals($expected, $this->apiController->getFilesByTag([$tagName])); + } + + public function testUpdateFileTagsEmpty() { + $expected = new DataResponse([]); + $this->assertEquals($expected, $this->apiController->updateFileTags('/path.txt')); + } + + public function testUpdateFileTagsWorking() { + $this->tagService->expects($this->once()) + ->method('updateFileTags') + ->with('/path.txt', ['Tag1', 'Tag2']); + + $expected = new DataResponse([ + 'tags' => [ + 'Tag1', + 'Tag2' + ], + ]); + $this->assertEquals($expected, $this->apiController->updateFileTags('/path.txt', ['Tag1', 'Tag2'])); + } + + public function testUpdateFileTagsNotFoundException() { + $this->tagService->expects($this->once()) + ->method('updateFileTags') + ->with('/path.txt', ['Tag1', 'Tag2']) + ->will($this->throwException(new NotFoundException('My error message'))); + + $expected = new DataResponse(['message' => 'My error message'], Http::STATUS_NOT_FOUND); + $this->assertEquals($expected, $this->apiController->updateFileTags('/path.txt', ['Tag1', 'Tag2'])); + } + + public function testUpdateFileTagsStorageNotAvailableException() { + $this->tagService->expects($this->once()) + ->method('updateFileTags') + ->with('/path.txt', ['Tag1', 'Tag2']) + ->will($this->throwException(new StorageNotAvailableException('My error message'))); + + $expected = new DataResponse(['message' => 'My error message'], Http::STATUS_SERVICE_UNAVAILABLE); + $this->assertEquals($expected, $this->apiController->updateFileTags('/path.txt', ['Tag1', 'Tag2'])); + } + + public function testUpdateFileTagsStorageGenericException() { + $this->tagService->expects($this->once()) + ->method('updateFileTags') + ->with('/path.txt', ['Tag1', 'Tag2']) + ->will($this->throwException(new \Exception('My error message'))); + + $expected = new DataResponse(['message' => 'My error message'], Http::STATUS_NOT_FOUND); + $this->assertEquals($expected, $this->apiController->updateFileTags('/path.txt', ['Tag1', 'Tag2'])); + } +} |