]> source.dussan.org Git - nextcloud-server.git/commitdiff
add tests for filesearchbackend
authorRobin Appelman <robin@icewind.nl>
Tue, 21 Feb 2017 17:18:41 +0000 (18:18 +0100)
committerRobin Appelman <robin@icewind.nl>
Wed, 1 Mar 2017 13:06:40 +0000 (14:06 +0100)
Signed-off-by: Robin Appelman <robin@icewind.nl>
apps/dav/lib/Files/FileSearchBackend.php
apps/dav/tests/unit/Files/FileSearchBackendTest.php [new file with mode: 0644]
tests/lib/Files/Cache/QuerySearchHelperTest.php

index 3d87612aad74648d1595f5181fd3ed0455e008c8..c429a1727f8c6c75d6fc1cdcb7a3efc8fcb49879 100644 (file)
@@ -130,6 +130,10 @@ class FileSearchBackend implements ISearchBackend {
                ];
        }
 
+       /**
+        * @param BasicSearch $search
+        * @return SearchResult[]
+        */
        public function search(BasicSearch $search) {
                if (count($search->from) !== 1) {
                        throw new \InvalidArgumentException('Searching more than one folder is not supported');
@@ -225,13 +229,6 @@ class FileSearchBackend implements ISearchBackend {
         * @return string
         */
        private function mapPropertyNameToCollumn($propertyName) {
-               /**
-                * new SearchPropertyDefinition('{DAV:}displayname', true, false, true),
-                * new SearchPropertyDefinition('{DAV:}getcontenttype', true, true, true),
-                * new SearchPropertyDefinition('{DAV:}getlastmodifed', true, true, true, SearchPropertyDefinition::DATATYPE_DATETIME),
-                * new SearchPropertyDefinition(FilesPlugin::SIZE_PROPERTYNAME, true, true, true, SearchPropertyDefinition::DATATYPE_NONNEGATIVE_INTEGER),
-                */
-
                switch ($propertyName) {
                        case '{DAV:}displayname':
                                return 'name';
diff --git a/apps/dav/tests/unit/Files/FileSearchBackendTest.php b/apps/dav/tests/unit/Files/FileSearchBackendTest.php
new file mode 100644 (file)
index 0000000..24b9a9c
--- /dev/null
@@ -0,0 +1,299 @@
+<?php
+/**
+ * @copyright Copyright (c) 2017 Robin Appelman <robin@icewind.nl>
+ *
+ * @license GNU AGPL version 3 or any later version
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program.  If not, see <http://www.gnu.org/licenses/>.
+ *
+ */
+
+namespace OCA\DAV\Tests\Files;
+
+use OC\Files\Search\SearchComparison;
+use OC\Files\Search\SearchQuery;
+use OC\Files\View;
+use OCA\DAV\Connector\Sabre\Directory;
+use OCA\DAV\Connector\Sabre\File;
+use OCA\DAV\Connector\Sabre\FilesPlugin;
+use OCA\DAV\Files\FileSearchBackend;
+use OCP\Files\FileInfo;
+use OCP\Files\Folder;
+use OCP\Files\IRootFolder;
+use OCP\Files\Search\ISearchComparison;
+use OCP\IUser;
+use OCP\Share\IManager;
+use Sabre\DAV\Tree;
+use SearchDAV\XML\BasicSearch;
+use SearchDAV\XML\Literal;
+use SearchDAV\XML\Operator;
+use SearchDAV\XML\Scope;
+use Test\TestCase;
+
+class FileSearchBackendTest extends TestCase {
+       /** @var Tree|\PHPUnit_Framework_MockObject_MockObject */
+       private $tree;
+
+       /** @var IUser */
+       private $user;
+
+       /** @var IRootFolder|\PHPUnit_Framework_MockObject_MockObject */
+       private $rootFolder;
+
+       /** @var IManager|\PHPUnit_Framework_MockObject_MockObject */
+       private $shareManager;
+
+       /** @var View|\PHPUnit_Framework_MockObject_MockObject */
+       private $view;
+
+       /** @var Folder|\PHPUnit_Framework_MockObject_MockObject */
+       private $searchFolder;
+
+       /** @var FileSearchBackend */
+       private $search;
+
+       /** @var Directory|\PHPUnit_Framework_MockObject_MockObject */
+       private $davFolder;
+
+       protected function setUp() {
+               parent::setUp();
+
+               $this->user = $this->createMock(IUser::class);
+               $this->user->expects($this->any())
+                       ->method('getUID')
+                       ->willReturn('test');
+
+               $this->tree = $this->getMockBuilder(Tree::class)
+                       ->disableOriginalConstructor()
+                       ->getMock();
+
+               $this->view = $this->getMockBuilder(View::class)
+                       ->disableOriginalConstructor()
+                       ->getMock();
+
+               $this->view->expects($this->any())
+                       ->method('getRelativePath')
+                       ->willReturnArgument(0);
+
+               $this->rootFolder = $this->createMock(IRootFolder::class);
+
+               $this->shareManager = $this->createMock(IManager::class);
+
+               $this->searchFolder = $this->createMock(Folder::class);
+
+               $fileInfo = $this->createMock(FileInfo::class);
+
+               $this->davFolder = $this->createMock(Directory::class);
+
+               $this->davFolder->expects($this->any())
+                       ->method('getFileInfo')
+                       ->willReturn($fileInfo);
+
+               $this->rootFolder->expects($this->any())
+                       ->method('get')
+                       ->willReturn($this->searchFolder);
+
+               $this->search = new FileSearchBackend($this->tree, $this->user, $this->rootFolder, $this->shareManager, $this->view);
+       }
+
+       public function testSearchFilename() {
+               $this->tree->expects($this->any())
+                       ->method('getNodeForPath')
+                       ->willReturn($this->davFolder);
+
+               $this->searchFolder->expects($this->once())
+                       ->method('search')
+                       ->with(new SearchQuery(
+                               new SearchComparison(
+                                       ISearchComparison::COMPARE_EQUAL,
+                                       'name',
+                                       'foo'
+                               ),
+                               0,
+                               0,
+                               []
+                       ))
+                       ->will($this->returnValue([
+                               new \OC\Files\Node\Folder($this->rootFolder, $this->view, '/test/path')
+                       ]));
+
+               $query = $this->getBasicQuery(Operator::OPERATION_EQUAL, '{DAV:}displayname', 'foo');
+               $result = $this->search->search($query);
+
+               $this->assertCount(1, $result);
+               $this->assertEquals('/files/test/test/path', $result[0]->href);
+       }
+
+       public function testSearchMimetype() {
+               $this->tree->expects($this->any())
+                       ->method('getNodeForPath')
+                       ->willReturn($this->davFolder);
+
+               $this->searchFolder->expects($this->once())
+                       ->method('search')
+                       ->with(new SearchQuery(
+                               new SearchComparison(
+                                       ISearchComparison::COMPARE_EQUAL,
+                                       'mimetype',
+                                       'foo'
+                               ),
+                               0,
+                               0,
+                               []
+                       ))
+                       ->will($this->returnValue([
+                               new \OC\Files\Node\Folder($this->rootFolder, $this->view, '/test/path')
+                       ]));
+
+               $query = $this->getBasicQuery(Operator::OPERATION_EQUAL, '{DAV:}getcontenttype', 'foo');
+               $result = $this->search->search($query);
+
+               $this->assertCount(1, $result);
+               $this->assertEquals('/files/test/test/path', $result[0]->href);
+       }
+
+       public function testSearchSize() {
+               $this->tree->expects($this->any())
+                       ->method('getNodeForPath')
+                       ->willReturn($this->davFolder);
+
+               $this->searchFolder->expects($this->once())
+                       ->method('search')
+                       ->with(new SearchQuery(
+                               new SearchComparison(
+                                       ISearchComparison::COMPARE_GREATER_THAN,
+                                       'size',
+                                       10
+                               ),
+                               0,
+                               0,
+                               []
+                       ))
+                       ->will($this->returnValue([
+                               new \OC\Files\Node\Folder($this->rootFolder, $this->view, '/test/path')
+                       ]));
+
+               $query = $this->getBasicQuery(Operator::OPERATION_GREATER_THAN, FilesPlugin::SIZE_PROPERTYNAME, 10);
+               $result = $this->search->search($query);
+
+               $this->assertCount(1, $result);
+               $this->assertEquals('/files/test/test/path', $result[0]->href);
+       }
+
+       public function testSearchMtime() {
+               $this->tree->expects($this->any())
+                       ->method('getNodeForPath')
+                       ->willReturn($this->davFolder);
+
+               $this->searchFolder->expects($this->once())
+                       ->method('search')
+                       ->with(new SearchQuery(
+                               new SearchComparison(
+                                       ISearchComparison::COMPARE_GREATER_THAN,
+                                       'mtime',
+                                       10
+                               ),
+                               0,
+                               0,
+                               []
+                       ))
+                       ->will($this->returnValue([
+                               new \OC\Files\Node\Folder($this->rootFolder, $this->view, '/test/path')
+                       ]));
+
+               $query = $this->getBasicQuery(Operator::OPERATION_GREATER_THAN, '{DAV:}getlastmodifed', 10);
+               $result = $this->search->search($query);
+
+               $this->assertCount(1, $result);
+               $this->assertEquals('/files/test/test/path', $result[0]->href);
+       }
+
+       public function testSearchIsCollection() {
+               $this->tree->expects($this->any())
+                       ->method('getNodeForPath')
+                       ->willReturn($this->davFolder);
+
+               $this->searchFolder->expects($this->once())
+                       ->method('search')
+                       ->with(new SearchQuery(
+                               new SearchComparison(
+                                       ISearchComparison::COMPARE_EQUAL,
+                                       'mimetype',
+                                       FileInfo::MIMETYPE_FOLDER
+                               ),
+                               0,
+                               0,
+                               []
+                       ))
+                       ->will($this->returnValue([
+                               new \OC\Files\Node\Folder($this->rootFolder, $this->view, '/test/path')
+                       ]));
+
+               $query = $this->getBasicQuery(Operator::OPERATION_IS_COLLECTION, 'yes');
+               $result = $this->search->search($query);
+
+               $this->assertCount(1, $result);
+               $this->assertEquals('/files/test/test/path', $result[0]->href);
+       }
+
+       /**
+        * @expectedException \InvalidArgumentException
+        */
+       public function testSearchInvalidProp() {
+               $this->tree->expects($this->any())
+                       ->method('getNodeForPath')
+                       ->willReturn($this->davFolder);
+
+               $this->searchFolder->expects($this->never())
+                       ->method('search');
+
+               $query = $this->getBasicQuery(Operator::OPERATION_EQUAL, '{DAV:}getetag', 'foo');
+               $this->search->search($query);
+       }
+
+       private function getBasicQuery($type, $property, $value = null) {
+               $query = new BasicSearch();
+               $scope = new Scope('/', 'infinite');
+               $scope->path = '/';
+               $query->from = [$scope];
+               $query->orderBy = [];
+               $query->select = [];
+               if (is_null($value)) {
+                       $query->where = new Operator(
+                               $type,
+                               [new Literal($property)]
+                       );
+               } else {
+                       $query->where = new Operator(
+                               $type,
+                               [$property, new Literal($value)]
+                       );
+               }
+               return $query;
+       }
+
+       /**
+        * @expectedException \InvalidArgumentException
+        */
+       public function testSearchNonFolder() {
+               $davNode = $this->createMock(File::class);
+
+               $this->tree->expects($this->any())
+                       ->method('getNodeForPath')
+                       ->willReturn($davNode);
+
+               $query = $this->getBasicQuery(Operator::OPERATION_EQUAL, '{DAV:}displayname', 'foo');
+               $this->search->search($query);
+       }
+}
index beb0981d2df24214014a4b656ff4c90e198c1d7f..f458ef039e16df9f18512ea9df6a1e8b8d31dd83 100644 (file)
@@ -196,6 +196,9 @@ class QuerySearchHelperTest extends TestCase {
 
                $results = $this->search($operator);
 
+               sort($fileIds);
+               sort($results);
+
                $this->assertEquals($fileIds, $results);
        }
 }