From ba1fcc48ff8fba80b6d7d290b106886aa71337fa Mon Sep 17 00:00:00 2001 From: raviks789 Date: Mon, 24 Jun 2024 14:55:54 +0200 Subject: [PATCH] FilterProcessorTest: Add test cases to assemble predicates for EXISTS and NOT EXISTS operators --- tests/FilterProcessorTest.php | 22 ++++++++++++++++++++-- 1 file changed, 20 insertions(+), 2 deletions(-) diff --git a/tests/FilterProcessorTest.php b/tests/FilterProcessorTest.php index 315bedc..ccd9e45 100644 --- a/tests/FilterProcessorTest.php +++ b/tests/FilterProcessorTest.php @@ -3,7 +3,9 @@ namespace ipl\Tests\Sql; use ipl\Sql\Compat\FilterProcessor; +use ipl\Sql\Filter\Exists; use ipl\Sql\Filter\In; +use ipl\Sql\Filter\NotExists; use ipl\Sql\Filter\NotIn; use ipl\Sql\Select; use ipl\Stdlib\Filter; @@ -88,9 +90,25 @@ public function testNotInToSql() ['(foo NOT IN (?) OR foo IS NULL)' => $select], FilterProcessor::assemblePredicate(new NotIn(['foo'], $select)) ); + } + + public function testExistsToSql() + { + $select = (new Select())->from('oof')->columns('*')->where(['foo = ?' => 'bar']); + + $this->assertSame( + [' EXISTS ?' => $select], + FilterProcessor::assemblePredicate(new Exists($select)) + ); + } + + public function testNotExistsToSql() + { + $select = (new Select())->from('oof')->columns('*')->where(['foo = ?' => 'bar']); + $this->assertSame( - ['( foo, bar ) NOT IN (?)' => $select], - FilterProcessor::assemblePredicate(new NotIn(['foo', 'bar'], $select)) + [' NOT EXISTS ?' => $select], + FilterProcessor::assemblePredicate(new NotExists(($select))) ); } }