2018-11-22 23:18:20 -05:00
|
|
|
<?php
|
|
|
|
/** @license MIT
|
|
|
|
* Copyright 2017 J. King, Dustin Wilson et al.
|
|
|
|
* See LICENSE and AUTHORS files for details */
|
|
|
|
|
|
|
|
declare(strict_types=1);
|
2021-04-14 11:17:01 -04:00
|
|
|
|
2018-12-12 12:42:40 -05:00
|
|
|
namespace JKingWeb\Arsse\TestCase\Db\PostgreSQLPDO;
|
2018-11-22 23:18:20 -05:00
|
|
|
|
|
|
|
/**
|
2018-12-10 12:39:09 -05:00
|
|
|
* @group slow
|
2018-11-29 13:56:15 -05:00
|
|
|
* @covers \JKingWeb\Arsse\Db\PostgreSQL\PDOStatement<extended>
|
2019-01-15 08:58:11 -05:00
|
|
|
* @covers \JKingWeb\Arsse\Db\PDOError
|
|
|
|
* @covers \JKingWeb\Arsse\Db\SQLState */
|
2018-11-22 23:18:20 -05:00
|
|
|
class TestStatement extends \JKingWeb\Arsse\TestCase\Db\BaseStatement {
|
2019-08-25 13:19:11 -04:00
|
|
|
use \JKingWeb\Arsse\Test\DatabaseDrivers\PostgreSQLPDO;
|
2018-11-22 23:18:20 -05:00
|
|
|
|
|
|
|
protected function makeStatement(string $q, array $types = []): array {
|
2018-11-29 13:45:37 -05:00
|
|
|
return [static::$interface, $q, $types];
|
2018-11-22 23:18:20 -05:00
|
|
|
}
|
|
|
|
|
2024-12-27 19:58:07 -05:00
|
|
|
protected static function decorateTypeSyntax(string $value, string $type): string {
|
2018-11-22 23:18:20 -05:00
|
|
|
switch ($type) {
|
|
|
|
case "float":
|
2019-01-11 10:38:06 -05:00
|
|
|
return (substr($value, -2) === ".0") ? "'".substr($value, 0, strlen($value) - 2)."'" : "'$value'";
|
2018-11-22 23:18:20 -05:00
|
|
|
case "string":
|
2021-06-24 11:58:50 -04:00
|
|
|
if (preg_match("<^char\((\d+)\)$>D", $value, $match)) {
|
2018-11-22 23:18:20 -05:00
|
|
|
return "U&'\\+".str_pad(dechex((int) $match[1]), 6, "0", \STR_PAD_LEFT)."'";
|
|
|
|
}
|
2018-12-05 17:28:11 -05:00
|
|
|
return $value;
|
2020-11-02 15:21:04 -05:00
|
|
|
case "binary":
|
|
|
|
if ($value[0] === "x") {
|
|
|
|
return "'\\x".substr($value, 2)."::bytea";
|
|
|
|
}
|
|
|
|
// no break;
|
2018-11-22 23:18:20 -05:00
|
|
|
default:
|
|
|
|
return $value;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|