aboutsummaryrefslogtreecommitdiffstats
path: root/apps
diff options
context:
space:
mode:
authorRobin Appelman <robin@icewind.nl>2022-09-08 12:43:50 +0200
committerRobin Appelman <robin@icewind.nl>2022-09-08 13:32:05 +0200
commit3236a8e2af9383edc258b7fe31cb9291fac4df26 (patch)
tree85d303ec3766c81ba101cc05d2c6990fdb02f843 /apps
parent3df872b9a17ddc3d9a3e25b1b4ebb5cf0f3d843f (diff)
downloadnextcloud-server-3236a8e2af9383edc258b7fe31cb9291fac4df26.tar.gz
nextcloud-server-3236a8e2af9383edc258b7fe31cb9291fac4df26.zip
add test for search operator limit
Signed-off-by: Robin Appelman <robin@icewind.nl>
Diffstat (limited to 'apps')
-rw-r--r--apps/dav/tests/unit/Files/FileSearchBackendTest.php101
1 files changed, 76 insertions, 25 deletions
diff --git a/apps/dav/tests/unit/Files/FileSearchBackendTest.php b/apps/dav/tests/unit/Files/FileSearchBackendTest.php
index da682a5fb21..b4245ac181b 100644
--- a/apps/dav/tests/unit/Files/FileSearchBackendTest.php
+++ b/apps/dav/tests/unit/Files/FileSearchBackendTest.php
@@ -24,6 +24,7 @@
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
*/
+
namespace OCA\DAV\Tests\Files;
use OC\Files\Search\SearchComparison;
@@ -44,6 +45,7 @@ use OCP\IUser;
use OCP\Share\IManager;
use SearchDAV\Backend\SearchPropertyDefinition;
use SearchDAV\Query\Limit;
+use SearchDAV\Query\Operator;
use SearchDAV\Query\Query;
use Test\TestCase;
@@ -132,10 +134,10 @@ class FileSearchBackendTest extends TestCase {
$this->user
))
->willReturn([
- new \OC\Files\Node\Folder($this->rootFolder, $this->view, '/test/path')
+ new \OC\Files\Node\Folder($this->rootFolder, $this->view, '/test/path'),
]);
- $query = $this->getBasicQuery(\SearchDAV\Query\Operator::OPERATION_EQUAL, '{DAV:}displayname', 'foo');
+ $query = $this->getBasicQuery(Operator::OPERATION_EQUAL, '{DAV:}displayname', 'foo');
$result = $this->search->search($query);
$this->assertCount(1, $result);
@@ -161,10 +163,10 @@ class FileSearchBackendTest extends TestCase {
$this->user
))
->willReturn([
- new \OC\Files\Node\Folder($this->rootFolder, $this->view, '/test/path')
+ new \OC\Files\Node\Folder($this->rootFolder, $this->view, '/test/path'),
]);
- $query = $this->getBasicQuery(\SearchDAV\Query\Operator::OPERATION_EQUAL, '{DAV:}getcontenttype', 'foo');
+ $query = $this->getBasicQuery(Operator::OPERATION_EQUAL, '{DAV:}getcontenttype', 'foo');
$result = $this->search->search($query);
$this->assertCount(1, $result);
@@ -190,10 +192,10 @@ class FileSearchBackendTest extends TestCase {
$this->user
))
->willReturn([
- new \OC\Files\Node\Folder($this->rootFolder, $this->view, '/test/path')
+ new \OC\Files\Node\Folder($this->rootFolder, $this->view, '/test/path'),
]);
- $query = $this->getBasicQuery(\SearchDAV\Query\Operator::OPERATION_GREATER_THAN, FilesPlugin::SIZE_PROPERTYNAME, 10);
+ $query = $this->getBasicQuery(Operator::OPERATION_GREATER_THAN, FilesPlugin::SIZE_PROPERTYNAME, 10);
$result = $this->search->search($query);
$this->assertCount(1, $result);
@@ -219,10 +221,10 @@ class FileSearchBackendTest extends TestCase {
$this->user
))
->willReturn([
- new \OC\Files\Node\Folder($this->rootFolder, $this->view, '/test/path')
+ new \OC\Files\Node\Folder($this->rootFolder, $this->view, '/test/path'),
]);
- $query = $this->getBasicQuery(\SearchDAV\Query\Operator::OPERATION_GREATER_THAN, '{DAV:}getlastmodified', 10);
+ $query = $this->getBasicQuery(Operator::OPERATION_GREATER_THAN, '{DAV:}getlastmodified', 10);
$result = $this->search->search($query);
$this->assertCount(1, $result);
@@ -248,10 +250,10 @@ class FileSearchBackendTest extends TestCase {
$this->user
))
->willReturn([
- new \OC\Files\Node\Folder($this->rootFolder, $this->view, '/test/path')
+ new \OC\Files\Node\Folder($this->rootFolder, $this->view, '/test/path'),
]);
- $query = $this->getBasicQuery(\SearchDAV\Query\Operator::OPERATION_IS_COLLECTION, 'yes');
+ $query = $this->getBasicQuery(Operator::OPERATION_IS_COLLECTION, 'yes');
$result = $this->search->search($query);
$this->assertCount(1, $result);
@@ -269,7 +271,7 @@ class FileSearchBackendTest extends TestCase {
$this->searchFolder->expects($this->never())
->method('search');
- $query = $this->getBasicQuery(\SearchDAV\Query\Operator::OPERATION_EQUAL, '{DAV:}getetag', 'foo');
+ $query = $this->getBasicQuery(Operator::OPERATION_EQUAL, '{DAV:}getetag', 'foo');
$this->search->search($query);
}
@@ -280,12 +282,12 @@ class FileSearchBackendTest extends TestCase {
$orderBy = [];
$select = [];
if (is_null($value)) {
- $where = new \SearchDAV\Query\Operator(
+ $where = new Operator(
$type,
[new \SearchDAV\Query\Literal($property)]
);
} else {
- $where = new \SearchDAV\Query\Operator(
+ $where = new Operator(
$type,
[new SearchPropertyDefinition($property, true, true, true), new \SearchDAV\Query\Literal($value)]
);
@@ -305,7 +307,7 @@ class FileSearchBackendTest extends TestCase {
->method('getNodeForPath')
->willReturn($davNode);
- $query = $this->getBasicQuery(\SearchDAV\Query\Operator::OPERATION_EQUAL, '{DAV:}displayname', 'foo');
+ $query = $this->getBasicQuery(Operator::OPERATION_EQUAL, '{DAV:}displayname', 'foo');
$this->search->search($query);
}
@@ -321,11 +323,11 @@ class FileSearchBackendTest extends TestCase {
->willReturnCallback(function ($query) use (&$receivedQuery) {
$receivedQuery = $query;
return [
- new \OC\Files\Node\Folder($this->rootFolder, $this->view, '/test/path')
+ new \OC\Files\Node\Folder($this->rootFolder, $this->view, '/test/path'),
];
});
- $query = $this->getBasicQuery(\SearchDAV\Query\Operator::OPERATION_EQUAL, FilesPlugin::OWNER_ID_PROPERTYNAME, $this->user->getUID());
+ $query = $this->getBasicQuery(Operator::OPERATION_EQUAL, FilesPlugin::OWNER_ID_PROPERTYNAME, $this->user->getUID());
$this->search->search($query);
$this->assertNotNull($receivedQuery);
@@ -350,22 +352,22 @@ class FileSearchBackendTest extends TestCase {
->willReturnCallback(function ($query) use (&$receivedQuery) {
$receivedQuery = $query;
return [
- new \OC\Files\Node\Folder($this->rootFolder, $this->view, '/test/path')
+ new \OC\Files\Node\Folder($this->rootFolder, $this->view, '/test/path'),
];
});
- $query = $this->getBasicQuery(\SearchDAV\Query\Operator::OPERATION_EQUAL, FilesPlugin::OWNER_ID_PROPERTYNAME, $this->user->getUID());
- $query->where = new \SearchDAV\Query\Operator(
- \SearchDAV\Query\Operator::OPERATION_AND,
+ $query = $this->getBasicQuery(Operator::OPERATION_EQUAL, FilesPlugin::OWNER_ID_PROPERTYNAME, $this->user->getUID());
+ $query->where = new Operator(
+ Operator::OPERATION_AND,
[
- new \SearchDAV\Query\Operator(
- \SearchDAV\Query\Operator::OPERATION_EQUAL,
+ new Operator(
+ Operator::OPERATION_EQUAL,
[new SearchPropertyDefinition('{DAV:}getcontenttype', true, true, true), new \SearchDAV\Query\Literal('image/png')]
),
- new \SearchDAV\Query\Operator(
- \SearchDAV\Query\Operator::OPERATION_EQUAL,
+ new Operator(
+ Operator::OPERATION_EQUAL,
[new SearchPropertyDefinition(FilesPlugin::OWNER_ID_PROPERTYNAME, true, true, true), new \SearchDAV\Query\Literal($this->user->getUID())]
- )
+ ),
]
);
$this->search->search($query);
@@ -385,4 +387,53 @@ class FileSearchBackendTest extends TestCase {
$this->assertEquals(ISearchBinaryOperator::OPERATOR_AND, $operator->getType());
$this->assertEmpty($operator->getArguments());
}
+
+ public function testSearchOperatorLimit() {
+ $this->tree->expects($this->any())
+ ->method('getNodeForPath')
+ ->willReturn($this->davFolder);
+
+ $innerOperator = new Operator(
+ Operator::OPERATION_EQUAL,
+ [new SearchPropertyDefinition('{DAV:}getcontenttype', true, true, true), new \SearchDAV\Query\Literal('image/png')]
+ );
+ // 5 child operators
+ $level1Operator = new Operator(
+ Operator::OPERATION_AND,
+ [
+ $innerOperator,
+ $innerOperator,
+ $innerOperator,
+ $innerOperator,
+ $innerOperator,
+ ]
+ );
+ // 5^2 = 25 child operators
+ $level2Operator = new Operator(
+ Operator::OPERATION_AND,
+ [
+ $level1Operator,
+ $level1Operator,
+ $level1Operator,
+ $level1Operator,
+ $level1Operator,
+ ]
+ );
+ // 5^3 = 125 child operators
+ $level3Operator = new Operator(
+ Operator::OPERATION_AND,
+ [
+ $level2Operator,
+ $level2Operator,
+ $level2Operator,
+ $level2Operator,
+ $level2Operator,
+ ]
+ );
+
+ $query = $this->getBasicQuery(Operator::OPERATION_EQUAL, FilesPlugin::OWNER_ID_PROPERTYNAME, $this->user->getUID());
+ $query->where = $level3Operator;
+ $this->expectException(\InvalidArgumentException::class);
+ $this->search->search($query);
+ }
}