2022-08-05 18:51:35 +00:00
|
|
|
<?php
|
2022-08-15 20:28:25 +00:00
|
|
|
|
2022-08-05 18:51:35 +00:00
|
|
|
declare(strict_types=1);
|
|
|
|
|
|
2022-08-15 20:28:25 +00:00
|
|
|
namespace Tests\Expression;
|
|
|
|
|
|
2022-08-15 20:35:51 +00:00
|
|
|
use Exception;
|
2022-10-25 17:55:35 +00:00
|
|
|
use Arendsen\FluxQueryBuilder\Expression\KeyFilter;
|
2022-08-05 18:51:35 +00:00
|
|
|
use PHPUnit\Framework\TestCase;
|
|
|
|
|
|
2022-10-25 17:55:35 +00:00
|
|
|
final class KeyFilterExpressionTest extends TestCase
|
2022-08-15 20:28:25 +00:00
|
|
|
{
|
2022-08-05 18:51:35 +00:00
|
|
|
public function testSimpleKeyvalue()
|
|
|
|
|
{
|
2022-10-25 17:55:35 +00:00
|
|
|
$keyFilter = KeyFilter::setEqualTo('_measurement', 'test_measurement')
|
2022-08-10 13:30:16 +00:00
|
|
|
->andEqualTo('_field', 'user')
|
2022-08-09 15:41:38 +00:00
|
|
|
->or('count', '>=', '1')
|
2022-10-25 17:55:35 +00:00
|
|
|
->and('user', KeyFilter::EQUAL_TO, 'my_username')
|
2022-08-10 13:30:16 +00:00
|
|
|
->orNotEqualTo('test', 'world');
|
2022-08-05 18:51:35 +00:00
|
|
|
|
2022-08-15 20:28:25 +00:00
|
|
|
$query = 'r._measurement == "test_measurement" and r._field == "user" or ' .
|
2022-08-10 13:30:16 +00:00
|
|
|
'r.count >= "1" and r.user == "my_username" or r.test != "world"';
|
2022-08-05 18:51:35 +00:00
|
|
|
|
2022-10-25 17:55:35 +00:00
|
|
|
$this->assertEquals($keyFilter->__toString(), $query);
|
2022-08-05 18:51:35 +00:00
|
|
|
}
|
|
|
|
|
|
2022-08-09 15:41:38 +00:00
|
|
|
public function testInvalidOperator()
|
|
|
|
|
{
|
|
|
|
|
$this->expectException(Exception::class);
|
|
|
|
|
|
2022-10-25 17:55:35 +00:00
|
|
|
KeyFilter::set('_measurement', '9dkda9e', 'test_measurement')
|
2022-08-10 13:30:16 +00:00
|
|
|
->andEqualTo('_field', 'user')
|
2022-08-09 15:41:38 +00:00
|
|
|
->or('_field', '==', 'field2')
|
2022-08-10 13:30:16 +00:00
|
|
|
->andEqualTo('user', 'my_username');
|
2022-08-09 15:41:38 +00:00
|
|
|
}
|
2022-08-15 20:28:25 +00:00
|
|
|
}
|