Change param prefix from @ to :
This commit is contained in:
		
							parent
							
								
									7390ae0f61
								
							
						
					
					
						commit
						3d45bbcabc
					
				| @ -8,14 +8,14 @@ namespace BitBadger\PDODocument; | |||||||
| class Parameters | class Parameters | ||||||
| { | { | ||||||
|     /** |     /** | ||||||
|      * Create an ID parameter (name "@id", key will be treated as a string) |      * Create an ID parameter (name ":id", key will be treated as a string) | ||||||
|      * |      * | ||||||
|      * @param mixed $key The key representing the ID of the document |      * @param mixed $key The key representing the ID of the document | ||||||
|      * @return array|string[] An associative array with an "@id" parameter/value pair |      * @return array|string[] An associative array with an "@id" parameter/value pair | ||||||
|      */ |      */ | ||||||
|     public static function id(mixed $key): array |     public static function id(mixed $key): array | ||||||
|     { |     { | ||||||
|         return ['@id' => is_string($key) ? $key : "$key"]; |         return [':id' => is_string($key) ? $key : "$key"]; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
| @ -39,7 +39,7 @@ class Parameters | |||||||
|     public static function nameFields(array $fields): array |     public static function nameFields(array $fields): array | ||||||
|     { |     { | ||||||
|         for ($idx = 0; $idx < sizeof($fields); $idx++) { |         for ($idx = 0; $idx < sizeof($fields); $idx++) { | ||||||
|             if ($fields[$idx]->paramName == '') $fields[$idx]->paramName = "@field$idx"; |             if ($fields[$idx]->paramName == '') $fields[$idx]->paramName = ":field$idx"; | ||||||
|         } |         } | ||||||
|         return $fields; |         return $fields; | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -21,7 +21,7 @@ class Patch | |||||||
|     public static function byId(string $tableName, mixed $docId, array|object $patch, ?PDO $pdo = null): void |     public static function byId(string $tableName, mixed $docId, array|object $patch, ?PDO $pdo = null): void | ||||||
|     { |     { | ||||||
|         Custom::nonQuery(Query\Patch::byId($tableName), |         Custom::nonQuery(Query\Patch::byId($tableName), | ||||||
|             array_merge(Parameters::id($docId), Parameters::json('@data', $patch)), $pdo); |             array_merge(Parameters::id($docId), Parameters::json(':data', $patch)), $pdo); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
| @ -39,6 +39,6 @@ class Patch | |||||||
|     { |     { | ||||||
|         $namedFields = Parameters::nameFields($fields); |         $namedFields = Parameters::nameFields($fields); | ||||||
|         Custom::nonQuery(Query\Patch::byFields($tableName, $namedFields, $conjunction), |         Custom::nonQuery(Query\Patch::byFields($tableName, $namedFields, $conjunction), | ||||||
|             Parameters::addFields($namedFields, Parameters::json('@data', $patch)), $pdo); |             Parameters::addFields($namedFields, Parameters::json(':data', $patch)), $pdo); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -36,7 +36,7 @@ class Query | |||||||
|      * @param string $paramName The parameter name where the value of the ID will be provided (optional; default @id) |      * @param string $paramName The parameter name where the value of the ID will be provided (optional; default @id) | ||||||
|      * @return string The WHERE clause fragment to match by ID |      * @return string The WHERE clause fragment to match by ID | ||||||
|      */ |      */ | ||||||
|     public static function whereById(string $paramName = '@id'): string |     public static function whereById(string $paramName = ':id'): string | ||||||
|     { |     { | ||||||
|         return self::whereByFields([Field::EQ(Configuration::$idField, 0, $paramName)]); |         return self::whereByFields([Field::EQ(Configuration::$idField, 0, $paramName)]); | ||||||
|     } |     } | ||||||
| @ -49,7 +49,7 @@ class Query | |||||||
|      */ |      */ | ||||||
|     public static function insert(string $tableName): string |     public static function insert(string $tableName): string | ||||||
|     { |     { | ||||||
|         return "INSERT INTO $tableName VALUES (@data)"; |         return "INSERT INTO $tableName VALUES (:data)"; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
| @ -72,6 +72,6 @@ class Query | |||||||
|      */ |      */ | ||||||
|     public static function update(string $tableName): string |     public static function update(string $tableName): string | ||||||
|     { |     { | ||||||
|         return "UPDATE $tableName SET data = @data WHERE " . self::whereById(); |         return "UPDATE $tableName SET data = :data WHERE " . self::whereById(); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -24,8 +24,8 @@ class Patch | |||||||
|     public static function update(string $tableName, string $whereClause): string |     public static function update(string $tableName, string $whereClause): string | ||||||
|     { |     { | ||||||
|         $setValue = match (Configuration::$mode) { |         $setValue = match (Configuration::$mode) { | ||||||
|             Mode::PgSQL  => 'data || @data', |             Mode::PgSQL  => 'data || :data', | ||||||
|             Mode::SQLite => 'json_patch(data, json(@data))', |             Mode::SQLite => 'json_patch(data, json(:data))', | ||||||
|             default      => throw new DocumentException('Database mode not set; cannot make patch statement') |             default      => throw new DocumentException('Database mode not set; cannot make patch statement') | ||||||
|         }; |         }; | ||||||
|         return "UPDATE $tableName SET data = $setValue WHERE $whereClause"; |         return "UPDATE $tableName SET data = $setValue WHERE $whereClause"; | ||||||
|  | |||||||
| @ -20,7 +20,7 @@ class RemoveFields | |||||||
|      */ |      */ | ||||||
|     public static function byId(string $tableName, mixed $docId, array $fieldNames, ?PDO $pdo = null): void |     public static function byId(string $tableName, mixed $docId, array $fieldNames, ?PDO $pdo = null): void | ||||||
|     { |     { | ||||||
|         $nameParams = Parameters::fieldNames('@name', $fieldNames); |         $nameParams = Parameters::fieldNames(':name', $fieldNames); | ||||||
|         Custom::nonQuery(Query\RemoveFields::byId($tableName, $nameParams), |         Custom::nonQuery(Query\RemoveFields::byId($tableName, $nameParams), | ||||||
|             array_merge(Parameters::id($docId), $nameParams), $pdo); |             array_merge(Parameters::id($docId), $nameParams), $pdo); | ||||||
|     } |     } | ||||||
| @ -38,7 +38,7 @@ class RemoveFields | |||||||
|     public static function byFields(string $tableName, array $fields, array $fieldNames, ?PDO $pdo = null, |     public static function byFields(string $tableName, array $fields, array $fieldNames, ?PDO $pdo = null, | ||||||
|                                     string $conjunction = 'AND'): void |                                     string $conjunction = 'AND'): void | ||||||
|     { |     { | ||||||
|         $nameParams  = Parameters::fieldNames('@name', $fieldNames); |         $nameParams  = Parameters::fieldNames(':name', $fieldNames); | ||||||
|         $namedFields = Parameters::nameFields($fields); |         $namedFields = Parameters::nameFields($fields); | ||||||
|         Custom::nonQuery(Query\RemoveFields::byFields($tableName, $namedFields, $nameParams, $conjunction), |         Custom::nonQuery(Query\RemoveFields::byFields($tableName, $namedFields, $nameParams, $conjunction), | ||||||
|             Parameters::addFields($namedFields, $nameParams), $pdo); |             Parameters::addFields($namedFields, $nameParams), $pdo); | ||||||
|  | |||||||
| @ -18,35 +18,35 @@ class ParametersTest extends TestCase | |||||||
|     #[TestDox('ID succeeds with string')]
 |     #[TestDox('ID succeeds with string')]
 | ||||||
|     public function testIdSucceedsWithString(): void |     public function testIdSucceedsWithString(): void | ||||||
|     { |     { | ||||||
|         $this->assertEquals(['@id' => 'key'], Parameters::id('key'), 'ID parameter not constructed correctly'); |         $this->assertEquals([':id' => 'key'], Parameters::id('key'), 'ID parameter not constructed correctly'); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     #[TestDox('ID succeeds with non string')]
 |     #[TestDox('ID succeeds with non string')]
 | ||||||
|     public function testIdSucceedsWithNonString(): void |     public function testIdSucceedsWithNonString(): void | ||||||
|     { |     { | ||||||
|         $this->assertEquals(['@id' => '7'], Parameters::id(7), 'ID parameter not constructed correctly'); |         $this->assertEquals([':id' => '7'], Parameters::id(7), 'ID parameter not constructed correctly'); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public function testJsonSucceeds(): void |     public function testJsonSucceeds(): void | ||||||
|     { |     { | ||||||
|         $this->assertEquals(['@it' => '{"id":18,"url":"https://www.unittest.com"}'], |         $this->assertEquals([':it' => '{"id":18,"url":"https://www.unittest.com"}'], | ||||||
|             Parameters::json('@it', ['id' => 18, 'url' => 'https://www.unittest.com']), |             Parameters::json(':it', ['id' => 18, 'url' => 'https://www.unittest.com']), | ||||||
|             'JSON parameter not constructed correctly'); |             'JSON parameter not constructed correctly'); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public function testNameFieldsSucceeds(): void |     public function testNameFieldsSucceeds(): void | ||||||
|     { |     { | ||||||
|         $named = Parameters::nameFields([Field::EQ('it', 17), Field::EQ('also', 22, '@also'), Field::EQ('other', 24)]); |         $named = Parameters::nameFields([Field::EQ('it', 17), Field::EQ('also', 22, ':also'), Field::EQ('other', 24)]); | ||||||
|         $this->assertCount(3, $named, 'There should be 3 parameters in the array'); |         $this->assertCount(3, $named, 'There should be 3 parameters in the array'); | ||||||
|         $this->assertEquals('@field0', $named[0]->paramName, 'Parameter 1 not named correctly'); |         $this->assertEquals(':field0', $named[0]->paramName, 'Parameter 1 not named correctly'); | ||||||
|         $this->assertEquals('@also', $named[1]->paramName, 'Parameter 2 not named correctly'); |         $this->assertEquals(':also', $named[1]->paramName, 'Parameter 2 not named correctly'); | ||||||
|         $this->assertEquals('@field2', $named[2]->paramName, 'Parameter 3 not named correctly'); |         $this->assertEquals(':field2', $named[2]->paramName, 'Parameter 3 not named correctly'); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public function testAddFieldsSucceeds(): void |     public function testAddFieldsSucceeds(): void | ||||||
|     { |     { | ||||||
|         $this->assertEquals(['@a' => 1, '@b' => 'two', '@z' => 18], |         $this->assertEquals([':a' => 1, ':b' => 'two', ':z' => 18], | ||||||
|             Parameters::addFields([Field::EQ('b', 'two', '@b'), Field::EQ('z', 18, '@z')], ['@a' => 1]), |             Parameters::addFields([Field::EQ('b', 'two', ':b'), Field::EQ('z', 18, ':z')], [':a' => 1]), | ||||||
|             'Field parameters not added correctly'); |             'Field parameters not added correctly'); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @ -55,8 +55,8 @@ class ParametersTest extends TestCase | |||||||
|     { |     { | ||||||
|         try { |         try { | ||||||
|             Configuration::$mode = Mode::PgSQL; |             Configuration::$mode = Mode::PgSQL; | ||||||
|             $this->assertEquals(['@names' => "ARRAY['one','two','seven']"], |             $this->assertEquals([':names' => "ARRAY['one','two','seven']"], | ||||||
|                 Parameters::fieldNames('@names', ['one', 'two', 'seven']), 'Field name parameters not correct'); |                 Parameters::fieldNames(':names', ['one', 'two', 'seven']), 'Field name parameters not correct'); | ||||||
|         } finally { |         } finally { | ||||||
|             Configuration::$mode = null; |             Configuration::$mode = null; | ||||||
|         } |         } | ||||||
| @ -67,8 +67,8 @@ class ParametersTest extends TestCase | |||||||
|     { |     { | ||||||
|         try { |         try { | ||||||
|             Configuration::$mode = Mode::SQLite; |             Configuration::$mode = Mode::SQLite; | ||||||
|             $this->assertEquals(['@it0' => 'test', '@it1' => 'unit', '@it2' => 'wow'], |             $this->assertEquals([':it0' => 'test', ':it1' => 'unit', ':it2' => 'wow'], | ||||||
|                 Parameters::fieldNames('@it', ['test', 'unit', 'wow']), 'Field name parameters not correct'); |                 Parameters::fieldNames(':it', ['test', 'unit', 'wow']), 'Field name parameters not correct'); | ||||||
|         } finally { |         } finally { | ||||||
|             Configuration::$mode = null; |             Configuration::$mode = null; | ||||||
|         } |         } | ||||||
|  | |||||||
| @ -20,7 +20,7 @@ class CountTest extends TestCase | |||||||
| 
 | 
 | ||||||
|     public function testByFieldsSucceeds() |     public function testByFieldsSucceeds() | ||||||
|     { |     { | ||||||
|         $this->assertEquals("SELECT COUNT(*) FROM somewhere WHERE data->>'errors' > @errors", |         $this->assertEquals("SELECT COUNT(*) FROM somewhere WHERE data->>'errors' > :errors", | ||||||
|             Count::byFields('somewhere', [Field::GT('errors', 10, '@errors')])); |             Count::byFields('somewhere', [Field::GT('errors', 10, ':errors')])); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -15,14 +15,14 @@ class DeleteTest extends TestCase | |||||||
|     #[TestDox('By ID succeeds')]
 |     #[TestDox('By ID succeeds')]
 | ||||||
|     public function testByIdSucceeds(): void |     public function testByIdSucceeds(): void | ||||||
|     { |     { | ||||||
|         $this->assertEquals("DELETE FROM over_there WHERE data->>'id' = @id", Delete::byId('over_there'), |         $this->assertEquals("DELETE FROM over_there WHERE data->>'id' = :id", Delete::byId('over_there'), | ||||||
|             'DELETE statement not constructed correctly'); |             'DELETE statement not constructed correctly'); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public function testByFieldsSucceeds(): void |     public function testByFieldsSucceeds(): void | ||||||
|     { |     { | ||||||
|         $this->assertEquals("DELETE FROM my_table WHERE data->>'value' < @max AND data->>'value' >= @min", |         $this->assertEquals("DELETE FROM my_table WHERE data->>'value' < :max AND data->>'value' >= :min", | ||||||
|             Delete::byFields('my_table', [Field::LT('value', 99, '@max'), Field::GE('value', 18, '@min')]), |             Delete::byFields('my_table', [Field::LT('value', 99, ':max'), Field::GE('value', 18, ':min')]), | ||||||
|             'DELETE statement not constructed correctly'); |             'DELETE statement not constructed correctly'); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -21,14 +21,14 @@ class ExistsTest extends TestCase | |||||||
|     #[TestDox('By ID succeeds')]
 |     #[TestDox('By ID succeeds')]
 | ||||||
|     public function testByIdSucceeds(): void |     public function testByIdSucceeds(): void | ||||||
|     { |     { | ||||||
|         $this->assertEquals("SELECT EXISTS (SELECT 1 FROM dox WHERE data->>'id' = @id)", Exists::byId('dox'), |         $this->assertEquals("SELECT EXISTS (SELECT 1 FROM dox WHERE data->>'id' = :id)", Exists::byId('dox'), | ||||||
|             'Existence query not generated correctly'); |             'Existence query not generated correctly'); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public function testByFieldsSucceeds(): void |     public function testByFieldsSucceeds(): void | ||||||
|     { |     { | ||||||
|         $this->assertEquals("SELECT EXISTS (SELECT 1 FROM box WHERE data->>'status' <> @status)", |         $this->assertEquals("SELECT EXISTS (SELECT 1 FROM box WHERE data->>'status' <> :status)", | ||||||
|             Exists::byFields('box', [Field::NE('status', 'occupied', '@status')]), |             Exists::byFields('box', [Field::NE('status', 'occupied', ':status')]), | ||||||
|             'Existence query not generated correctly'); |             'Existence query not generated correctly'); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -15,14 +15,14 @@ class FindTest extends TestCase | |||||||
|     #[TestDox('By ID succeeds')]
 |     #[TestDox('By ID succeeds')]
 | ||||||
|     public function testByIdSucceeds(): void |     public function testByIdSucceeds(): void | ||||||
|     { |     { | ||||||
|         $this->assertEquals("SELECT data FROM here WHERE data->>'id' = @id", Find::byId('here'), |         $this->assertEquals("SELECT data FROM here WHERE data->>'id' = :id", Find::byId('here'), | ||||||
|             'SELECT query not generated correctly'); |             'SELECT query not generated correctly'); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public function testByFieldsSucceeds(): void |     public function testByFieldsSucceeds(): void | ||||||
|     { |     { | ||||||
|         $this->assertEquals("SELECT data FROM there WHERE data->>'active' = @act OR data->>'locked' = @lock", |         $this->assertEquals("SELECT data FROM there WHERE data->>'active' = :act OR data->>'locked' = :lock", | ||||||
|             Find::byFields('there', [Field::EQ('active', true, '@act'), Field::EQ('locked', true, '@lock')], 'OR'), |             Find::byFields('there', [Field::EQ('active', true, ':act'), Field::EQ('locked', true, ':lock')], 'OR'), | ||||||
|             'SELECT query not generated correctly'); |             'SELECT query not generated correctly'); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -20,7 +20,7 @@ class PatchTest extends TestCase | |||||||
|     { |     { | ||||||
|         try { |         try { | ||||||
|             Configuration::$mode = Mode::PgSQL; |             Configuration::$mode = Mode::PgSQL; | ||||||
|             $this->assertEquals("UPDATE doc_table SET data = data || @data WHERE data->>'id' = @id", |             $this->assertEquals("UPDATE doc_table SET data = data || :data WHERE data->>'id' = :id", | ||||||
|                 Patch::byId('doc_table'), 'Patch UPDATE statement is not correct'); |                 Patch::byId('doc_table'), 'Patch UPDATE statement is not correct'); | ||||||
|         } finally { |         } finally { | ||||||
|             Configuration::$mode = null; |             Configuration::$mode = null; | ||||||
| @ -32,7 +32,7 @@ class PatchTest extends TestCase | |||||||
|     { |     { | ||||||
|         try { |         try { | ||||||
|             Configuration::$mode = Mode::SQLite; |             Configuration::$mode = Mode::SQLite; | ||||||
|             $this->assertEquals("UPDATE my_table SET data = json_patch(data, json(@data)) WHERE data->>'id' = @id", |             $this->assertEquals("UPDATE my_table SET data = json_patch(data, json(:data)) WHERE data->>'id' = :id", | ||||||
|                 Patch::byId('my_table'), 'Patch UPDATE statement is not correct'); |                 Patch::byId('my_table'), 'Patch UPDATE statement is not correct'); | ||||||
|         } finally { |         } finally { | ||||||
|             Configuration::$mode = null; |             Configuration::$mode = null; | ||||||
| @ -52,8 +52,8 @@ class PatchTest extends TestCase | |||||||
|     { |     { | ||||||
|         try { |         try { | ||||||
|             Configuration::$mode = Mode::PgSQL; |             Configuration::$mode = Mode::PgSQL; | ||||||
|             $this->assertEquals("UPDATE that SET data = data || @data WHERE data->>'something' < @some", |             $this->assertEquals("UPDATE that SET data = data || :data WHERE data->>'something' < :some", | ||||||
|                 Patch::byFields('that', [Field::LT('something', 17, '@some')]), |                 Patch::byFields('that', [Field::LT('something', 17, ':some')]), | ||||||
|                 'Patch UPDATE statement is not correct'); |                 'Patch UPDATE statement is not correct'); | ||||||
|         } finally { |         } finally { | ||||||
|             Configuration::$mode = null; |             Configuration::$mode = null; | ||||||
| @ -66,8 +66,8 @@ class PatchTest extends TestCase | |||||||
|         try { |         try { | ||||||
|             Configuration::$mode = Mode::SQLite; |             Configuration::$mode = Mode::SQLite; | ||||||
|             $this->assertEquals( |             $this->assertEquals( | ||||||
|                 "UPDATE a_table SET data = json_patch(data, json(@data)) WHERE data->>'something' > @it", |                 "UPDATE a_table SET data = json_patch(data, json(:data)) WHERE data->>'something' > :it", | ||||||
|                 Patch::byFields('a_table', [Field::GT('something', 17, '@it')]), |                 Patch::byFields('a_table', [Field::GT('something', 17, ':it')]), | ||||||
|                 'Patch UPDATE statement is not correct'); |                 'Patch UPDATE statement is not correct'); | ||||||
|         } finally { |         } finally { | ||||||
|             Configuration::$mode = null; |             Configuration::$mode = null; | ||||||
|  | |||||||
							
								
								
									
										121
									
								
								tests/unit/Query/RemoveFieldsTest.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										121
									
								
								tests/unit/Query/RemoveFieldsTest.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,121 @@ | |||||||
|  | <?php declare(strict_types=1); | ||||||
|  | 
 | ||||||
|  | namespace Test\Unit\Query; | ||||||
|  | 
 | ||||||
|  | use BitBadger\PDODocument\Configuration; | ||||||
|  | use BitBadger\PDODocument\DocumentException; | ||||||
|  | use BitBadger\PDODocument\Field; | ||||||
|  | use BitBadger\PDODocument\Mode; | ||||||
|  | use BitBadger\PDODocument\Parameters; | ||||||
|  | use BitBadger\PDODocument\Query\RemoveFields; | ||||||
|  | use PHPUnit\Framework\Attributes\TestDox; | ||||||
|  | use PHPUnit\Framework\TestCase; | ||||||
|  | 
 | ||||||
|  | /** | ||||||
|  |  * Unit tests for the RemoveFields class | ||||||
|  |  */ | ||||||
|  | class RemoveFieldsTest extends TestCase | ||||||
|  | { | ||||||
|  |     #[TestDox('Update succeeds for PostgreSQL')]
 | ||||||
|  |     public function testUpdateSucceedsForPostgreSQL(): void | ||||||
|  |     { | ||||||
|  |         try { | ||||||
|  |             Configuration::$mode = Mode::PgSQL; | ||||||
|  |             $this->assertEquals('UPDATE taco SET data = data - :names WHERE it = true', | ||||||
|  |                 RemoveFields::update('taco', [':names' => "ARRAY['one','two']"], 'it = true'), | ||||||
|  |                 'UPDATE statement not correct'); | ||||||
|  |         } finally { | ||||||
|  |             Configuration::$mode = null; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     #[TestDox('Update succeeds for SQLite')]
 | ||||||
|  |     public function testUpdateSucceedsForSQLite(): void | ||||||
|  |     { | ||||||
|  |         try { | ||||||
|  |             Configuration::$mode = Mode::SQLite; | ||||||
|  |             $this->assertEquals('UPDATE burrito SET data = json_remove(data, :name0, :name1, :name2) WHERE a = b', | ||||||
|  |                 RemoveFields::update('burrito', Parameters::fieldNames(':name', ['one', 'two', 'ten']), 'a = b'), | ||||||
|  |                 'UPDATE statement not correct'); | ||||||
|  |         } finally { | ||||||
|  |             Configuration::$mode = null; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public function testUpdateFailsWhenModeNotSet(): void | ||||||
|  |     { | ||||||
|  |         $this->expectException(DocumentException::class); | ||||||
|  |         Configuration::$mode = null; | ||||||
|  |         RemoveFields::update('wow', [], ''); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     #[TestDox('By ID succeeds for PostgreSQL')]
 | ||||||
|  |     public function testByIdSucceedsForPostgreSQL() | ||||||
|  |     { | ||||||
|  |         try { | ||||||
|  |             Configuration::$mode = Mode::PgSQL; | ||||||
|  |             $this->assertEquals("UPDATE churro SET data = data - :bite WHERE data->>'id' = :id", | ||||||
|  |                 RemoveFields::byId('churro', Parameters::fieldNames(':bite', ['byte'])), | ||||||
|  |                 'UPDATE statement not correct'); | ||||||
|  |         } finally { | ||||||
|  |             Configuration::$mode = null; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     #[TestDox('By ID succeeds for SQLite')]
 | ||||||
|  |     public function testByIdSucceedsForSQLite() | ||||||
|  |     { | ||||||
|  |         try { | ||||||
|  |             Configuration::$mode = Mode::SQLite; | ||||||
|  |             $this->assertEquals("UPDATE quesadilla SET data = json_remove(data, :bite0) WHERE data->>'id' = :id", | ||||||
|  |                 RemoveFields::byId('quesadilla', Parameters::fieldNames(':bite', ['byte'])), | ||||||
|  |                 'UPDATE statement not correct'); | ||||||
|  |         } finally { | ||||||
|  |             Configuration::$mode = null; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     #[TestDox('By ID fails when mode not set')]
 | ||||||
|  |     public function testByIdFailsWhenModeNotSet(): void | ||||||
|  |     { | ||||||
|  |         $this->expectException(DocumentException::class); | ||||||
|  |         Configuration::$mode = null; | ||||||
|  |         RemoveFields::byId('oof', []); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     #[TestDox('By fields succeeds for PostgreSQL')]
 | ||||||
|  |     public function testByFieldsSucceedsForPostgreSQL() | ||||||
|  |     { | ||||||
|  |         try { | ||||||
|  |             Configuration::$mode = Mode::PgSQL; | ||||||
|  |             $this->assertEquals("UPDATE enchilada SET data = data - :sauce WHERE data->>'cheese' = :queso", | ||||||
|  |                 RemoveFields::byFields('enchilada', [Field::EQ('cheese', 'jack', ':queso')], | ||||||
|  |                     Parameters::fieldNames(':sauce', ['white'])), | ||||||
|  |                 'UPDATE statement not correct'); | ||||||
|  |         } finally { | ||||||
|  |             Configuration::$mode = null; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     #[TestDox('By fields succeeds for SQLite')]
 | ||||||
|  |     public function testByFieldsSucceedsForSQLite() | ||||||
|  |     { | ||||||
|  |         try { | ||||||
|  |             Configuration::$mode = Mode::SQLite; | ||||||
|  |             $this->assertEquals( | ||||||
|  |                 "UPDATE chimichanga SET data = json_remove(data, :filling0) WHERE data->>'side' = :rice", | ||||||
|  |                 RemoveFields::byFields('chimichanga', [Field::EQ('side', 'beans', ':rice')], | ||||||
|  |                     Parameters::fieldNames(':filling', ['beef'])), | ||||||
|  |                 'UPDATE statement not correct'); | ||||||
|  |         } finally { | ||||||
|  |             Configuration::$mode = null; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public function testByFieldsFailsWhenModeNotSet(): void | ||||||
|  |     { | ||||||
|  |         $this->expectException(DocumentException::class); | ||||||
|  |         Configuration::$mode = null; | ||||||
|  |         RemoveFields::byFields('boing', [], []); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -20,52 +20,52 @@ class QueryTest extends TestCase | |||||||
| 
 | 
 | ||||||
|     public function testWhereByFieldsSucceedsForSingleField(): void |     public function testWhereByFieldsSucceedsForSingleField(): void | ||||||
|     { |     { | ||||||
|         $this->assertEquals("data->>'test_field' <= @it", |         $this->assertEquals("data->>'test_field' <= :it", | ||||||
|             Query::whereByFields([Field::LE('test_field', '', '@it')]), 'WHERE fragment not constructed correctly'); |             Query::whereByFields([Field::LE('test_field', '', ':it')]), 'WHERE fragment not constructed correctly'); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public function testWhereByFieldsSucceedsForMultipleFields(): void |     public function testWhereByFieldsSucceedsForMultipleFields(): void | ||||||
|     { |     { | ||||||
|         $this->assertEquals("data->>'test_field' <= @it AND data->>'other_field' = @other", |         $this->assertEquals("data->>'test_field' <= :it AND data->>'other_field' = :other", | ||||||
|             Query::whereByFields([Field::LE('test_field', '', '@it'), Field::EQ('other_field', '', '@other')]), |             Query::whereByFields([Field::LE('test_field', '', ':it'), Field::EQ('other_field', '', ':other')]), | ||||||
|             'WHERE fragment not constructed correctly'); |             'WHERE fragment not constructed correctly'); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public function testWhereByFieldsSucceedsForMultipleFieldsWithOr(): void |     public function testWhereByFieldsSucceedsForMultipleFieldsWithOr(): void | ||||||
|     { |     { | ||||||
|         $this->assertEquals("data->>'test_field' <= @it OR data->>'other_field' = @other", |         $this->assertEquals("data->>'test_field' <= :it OR data->>'other_field' = :other", | ||||||
|             Query::whereByFields([Field::LE('test_field', '', '@it'), Field::EQ('other_field', '', '@other')], 'OR'), |             Query::whereByFields([Field::LE('test_field', '', ':it'), Field::EQ('other_field', '', ':other')], 'OR'), | ||||||
|             'WHERE fragment not constructed correctly'); |             'WHERE fragment not constructed correctly'); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     #[TestDox('Where by ID succeeds with default parameter')]
 |     #[TestDox('Where by ID succeeds with default parameter')]
 | ||||||
|     public function testWhereByIdSucceedsWithDefaultParameter(): void |     public function testWhereByIdSucceedsWithDefaultParameter(): void | ||||||
|     { |     { | ||||||
|         $this->assertEquals("data->>'id' = @id", Query::whereById(), 'WHERE fragment not constructed correctly'); |         $this->assertEquals("data->>'id' = :id", Query::whereById(), 'WHERE fragment not constructed correctly'); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     #[TestDox('Where by ID succeeds with specific parameter')]
 |     #[TestDox('Where by ID succeeds with specific parameter')]
 | ||||||
|     public function testWhereByIdSucceedsWithSpecificParameter(): void |     public function testWhereByIdSucceedsWithSpecificParameter(): void | ||||||
|     { |     { | ||||||
|         $this->assertEquals("data->>'id' = @di", Query::whereById('@di'), 'WHERE fragment not constructed correctly'); |         $this->assertEquals("data->>'id' = :di", Query::whereById(':di'), 'WHERE fragment not constructed correctly'); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public function testInsertSucceeds(): void |     public function testInsertSucceeds(): void | ||||||
|     { |     { | ||||||
|         $this->assertEquals('INSERT INTO my_table VALUES (@data)', Query::insert('my_table'), |         $this->assertEquals('INSERT INTO my_table VALUES (:data)', Query::insert('my_table'), | ||||||
|             'INSERT statement not constructed correctly'); |             'INSERT statement not constructed correctly'); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public function testSaveSucceeds(): void |     public function testSaveSucceeds(): void | ||||||
|     { |     { | ||||||
|         $this->assertEquals( |         $this->assertEquals( | ||||||
|             "INSERT INTO test_tbl VALUES (@data) ON CONFLICT ((data->>'id')) DO UPDATE SET data = EXCLUDED.data", |             "INSERT INTO test_tbl VALUES (:data) ON CONFLICT ((data->>'id')) DO UPDATE SET data = EXCLUDED.data", | ||||||
|             Query::save('test_tbl'), 'INSERT ON CONFLICT statement not constructed correctly'); |             Query::save('test_tbl'), 'INSERT ON CONFLICT statement not constructed correctly'); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public function testUpdateSucceeds() |     public function testUpdateSucceeds() | ||||||
|     { |     { | ||||||
|         $this->assertEquals("UPDATE testing SET data = @data WHERE data->>'id' = @id", Query::update('testing'), |         $this->assertEquals("UPDATE testing SET data = :data WHERE data->>'id' = :id", Query::update('testing'), | ||||||
|             'UPDATE statement not constructed correctly'); |             'UPDATE statement not constructed correctly'); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user