pdo-document/tests/unit/ParametersTest.php

80 lines
2.9 KiB
PHP
Raw Normal View History

2024-06-03 23:10:12 -04:00
<?php declare(strict_types=1);
namespace Test\Unit;
2024-06-03 23:10:12 -04:00
use BitBadger\PDODocument\{Configuration, DocumentException, Field, Mode, Parameters};
2024-06-03 23:10:12 -04:00
use PHPUnit\Framework\Attributes\TestDox;
use PHPUnit\Framework\TestCase;
/**
* Unit tests for the Parameters class
*/
class ParametersTest extends TestCase
{
#[TestDox('ID succeeds with string')]
public function testIdSucceedsWithString(): void
{
2024-06-04 20:59:24 -04:00
$this->assertEquals([':id' => 'key'], Parameters::id('key'), 'ID parameter not constructed correctly');
2024-06-03 23:10:12 -04:00
}
#[TestDox('ID succeeds with non string')]
public function testIdSucceedsWithNonString(): void
{
2024-06-04 20:59:24 -04:00
$this->assertEquals([':id' => '7'], Parameters::id(7), 'ID parameter not constructed correctly');
2024-06-03 23:10:12 -04:00
}
public function testJsonSucceeds(): void
{
2024-06-04 20:59:24 -04:00
$this->assertEquals([':it' => '{"id":18,"url":"https://www.unittest.com"}'],
Parameters::json(':it', ['id' => 18, 'url' => 'https://www.unittest.com']),
2024-06-03 23:10:12 -04:00
'JSON parameter not constructed correctly');
}
public function testNameFieldsSucceeds(): void
{
2024-06-04 20:59:24 -04:00
$named = Parameters::nameFields([Field::EQ('it', 17), Field::EQ('also', 22, ':also'), Field::EQ('other', 24)]);
2024-06-03 23:10:12 -04:00
$this->assertCount(3, $named, 'There should be 3 parameters in the array');
2024-06-04 20:59:24 -04:00
$this->assertEquals(':field0', $named[0]->paramName, 'Parameter 1 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');
2024-06-03 23:10:12 -04:00
}
public function testAddFieldsSucceeds(): void
{
2024-06-04 20:59:24 -04:00
$this->assertEquals([':a' => 1, ':b' => 'two', ':z' => 18],
Parameters::addFields([Field::EQ('b', 'two', ':b'), Field::EQ('z', 18, ':z')], [':a' => 1]),
2024-06-03 23:10:12 -04:00
'Field parameters not added correctly');
}
#[TestDox('Field names succeeds for PostgreSQL')]
public function testFieldNamesSucceedsForPostgreSQL(): void
{
try {
Configuration::$mode = Mode::PgSQL;
2024-06-04 20:59:24 -04:00
$this->assertEquals([':names' => "ARRAY['one','two','seven']"],
Parameters::fieldNames(':names', ['one', 'two', 'seven']), 'Field name parameters not correct');
2024-06-03 23:10:12 -04:00
} finally {
Configuration::$mode = null;
}
}
#[TestDox('Field names succeeds for SQLite')]
public function testFieldNamesSucceedsForSQLite(): void
{
try {
Configuration::$mode = Mode::SQLite;
2024-06-04 20:59:24 -04:00
$this->assertEquals([':it0' => 'test', ':it1' => 'unit', ':it2' => 'wow'],
Parameters::fieldNames(':it', ['test', 'unit', 'wow']), 'Field name parameters not correct');
2024-06-03 23:10:12 -04:00
} finally {
Configuration::$mode = null;
}
}
public function testFieldNamesFailsWhenModeNotSet(): void
{
$this->expectException(DocumentException::class);
Configuration::$mode = null;
Parameters::fieldNames('', []);
}
}