95 lines
5.7 KiB
PHP
95 lines
5.7 KiB
PHP
|
<?php
|
||
|
|
||
|
namespace Tests\Unit\Utopia\Database\Validator\Queries;
|
||
|
|
||
|
use Appwrite\Utopia\Database\Validator\Queries;
|
||
|
use Appwrite\Utopia\Database\Validator\Queries\LimitOffsetCursorFilterOrderQuery;
|
||
|
use Utopia\Database\Database;
|
||
|
use Utopia\Database\Document;
|
||
|
use Utopia\Database\Query;
|
||
|
use Utopia\Validator;
|
||
|
use PHPUnit\Framework\TestCase;
|
||
|
|
||
|
class LimitOffsetCursorFilterOrderQueryTest extends TestCase
|
||
|
{
|
||
|
/**
|
||
|
* @var Validator
|
||
|
*/
|
||
|
protected $validator = null;
|
||
|
|
||
|
public function setUp(): void
|
||
|
{
|
||
|
$this->validator = new LimitOffsetCursorFilterOrderQuery(
|
||
|
attributes: [
|
||
|
new Document([
|
||
|
'key' => 'attr',
|
||
|
'type' => Database::VAR_STRING,
|
||
|
'array' => false,
|
||
|
]),
|
||
|
],
|
||
|
);
|
||
|
}
|
||
|
|
||
|
public function tearDown(): void
|
||
|
{
|
||
|
}
|
||
|
|
||
|
public function testValue(): void
|
||
|
{
|
||
|
// Test for Success
|
||
|
$this->assertEquals($this->validator->isValid(Query::limit(1)), true, $this->validator->getDescription());
|
||
|
$this->assertEquals($this->validator->isValid(Query::limit(0)), true, $this->validator->getDescription());
|
||
|
$this->assertEquals($this->validator->isValid(Query::limit(100)), true, $this->validator->getDescription());
|
||
|
$this->assertEquals($this->validator->isValid(Query::offset(1)), true, $this->validator->getDescription());
|
||
|
$this->assertEquals($this->validator->isValid(Query::offset(0)), true, $this->validator->getDescription());
|
||
|
$this->assertEquals($this->validator->isValid(Query::offset(5000)), true, $this->validator->getDescription());
|
||
|
$this->assertEquals($this->validator->isValid(new Query(Query::TYPE_CURSORAFTER, values: ['asdf'])), true, $this->validator->getDescription());
|
||
|
$this->assertEquals($this->validator->isValid(new Query(Query::TYPE_CURSORBEFORE, values: ['asdf'])), true, $this->validator->getDescription());
|
||
|
$this->assertEquals($this->validator->isValid(Query::equal('attr', ['v'])), true, $this->validator->getDescription());
|
||
|
$this->assertEquals($this->validator->isValid(Query::orderAsc('attr')), true, $this->validator->getDescription());
|
||
|
$this->assertEquals($this->validator->isValid(Query::orderAsc('')), true, $this->validator->getDescription());
|
||
|
$this->assertEquals($this->validator->isValid(Query::orderDesc('attr')), true, $this->validator->getDescription());
|
||
|
$this->assertEquals($this->validator->isValid(Query::orderDesc('')), true, $this->validator->getDescription());
|
||
|
|
||
|
// Test for Failure
|
||
|
$this->assertEquals($this->validator->isValid(Query::limit(-1)), false, $this->validator->getDescription());
|
||
|
$this->assertEquals($this->validator->isValid(Query::limit(101)), false, $this->validator->getDescription());
|
||
|
$this->assertEquals($this->validator->isValid(Query::offset(-1)), false, $this->validator->getDescription());
|
||
|
$this->assertEquals($this->validator->isValid(Query::offset(5001)), false, $this->validator->getDescription());
|
||
|
$this->assertEquals($this->validator->isValid(Query::equal('dne', ['v'])), false, $this->validator->getDescription());
|
||
|
$this->assertEquals($this->validator->isValid(Query::equal('', ['v'])), false, $this->validator->getDescription());
|
||
|
$this->assertEquals($this->validator->isValid(Query::orderDesc('dne')), false, $this->validator->getDescription());
|
||
|
}
|
||
|
|
||
|
public function testValues(): void
|
||
|
{
|
||
|
|
||
|
$validator = new Queries($this->validator);
|
||
|
|
||
|
// Test for Success
|
||
|
$this->assertEquals($validator->isValid(['limit(1)']), true, $validator->getDescription());
|
||
|
$this->assertEquals($validator->isValid(['limit(0)']), true, $validator->getDescription());
|
||
|
$this->assertEquals($validator->isValid(['limit(100)']), true, $validator->getDescription());
|
||
|
$this->assertEquals($validator->isValid(['offset(1)']), true, $validator->getDescription());
|
||
|
$this->assertEquals($validator->isValid(['offset(0)']), true, $validator->getDescription());
|
||
|
$this->assertEquals($validator->isValid(['offset(5000)']), true, $validator->getDescription());
|
||
|
$this->assertEquals($validator->isValid(['limit(25)', 'offset(25)']), true, $validator->getDescription());
|
||
|
$this->assertEquals($validator->isValid(['cursorAfter("asdf")']), true, $validator->getDescription());
|
||
|
$this->assertEquals($validator->isValid(['cursorBefore("asdf")']), true, $validator->getDescription());
|
||
|
$this->assertEquals($validator->isValid(['equal("attr", "v")']), true, $validator->getDescription());
|
||
|
$this->assertEquals($validator->isValid(['orderAsc("attr")']), true, $validator->getDescription());
|
||
|
$this->assertEquals($validator->isValid(['orderAsc("")']), true, $validator->getDescription());
|
||
|
$this->assertEquals($validator->isValid(['orderDesc("attr")']), true, $validator->getDescription());
|
||
|
$this->assertEquals($validator->isValid(['orderDesc("")']), true, $validator->getDescription());
|
||
|
|
||
|
// Test for Failure
|
||
|
$this->assertEquals($validator->isValid(['limit(-1)']), false, $validator->getDescription());
|
||
|
$this->assertEquals($validator->isValid(['limit(101)']), false, $validator->getDescription());
|
||
|
$this->assertEquals($validator->isValid(['offset(-1)']), false, $validator->getDescription());
|
||
|
$this->assertEquals($validator->isValid(['offset(5001)']), false, $validator->getDescription());
|
||
|
$this->assertEquals($validator->isValid(['equal("dne", "v")']), false, $validator->getDescription());
|
||
|
$this->assertEquals($validator->isValid(['equal("", "v")']), false, $validator->getDescription());
|
||
|
$this->assertEquals($validator->isValid(['orderDesc("dne")']), false, $validator->getDescription());
|
||
|
}
|
||
|
}
|