2019-01-13 23:17:19 -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
|
|
|
|
2019-01-13 23:17:19 -05:00
|
|
|
namespace JKingWeb\Arsse\TestCase\Db\MySQL;
|
|
|
|
|
2024-12-27 23:39:44 -05:00
|
|
|
use PHPUnit\Framework\Attributes\CoversClass;
|
|
|
|
use PHPUnit\Framework\Attributes\Group;
|
|
|
|
|
|
|
|
#[Group("slow")]
|
|
|
|
#[CoversClass(\JKingWeb\Arsse\Db\MySQL\Driver::class)]
|
|
|
|
#[CoversClass(\JKingWeb\Arsse\Db\MySQL\ExceptionBuilder::class)]
|
|
|
|
#[CoversClass(\JKingWeb\Arsse\Db\SQLState::class)]
|
2019-01-13 23:17:19 -05:00
|
|
|
class TestDriver extends \JKingWeb\Arsse\TestCase\Db\BaseDriver {
|
2019-08-25 13:19:11 -04:00
|
|
|
use \JKingWeb\Arsse\Test\DatabaseDrivers\MySQL;
|
2019-01-13 23:17:19 -05:00
|
|
|
|
|
|
|
protected $create = "CREATE TABLE arsse_test(id bigint auto_increment primary key)";
|
|
|
|
protected $lock = ["SET lock_wait_timeout = 1", "LOCK TABLES arsse_meta WRITE"];
|
|
|
|
protected $setVersion = "UPDATE arsse_meta set value = '#' where `key` = 'schema_version'";
|
|
|
|
protected static $insertDefaultValues = "INSERT INTO arsse_test(id) values(default)";
|
|
|
|
|
|
|
|
protected function exec($q): bool {
|
2019-01-14 09:51:00 -05:00
|
|
|
if (!is_array($q)) {
|
|
|
|
$q = [$q];
|
2019-01-13 23:17:19 -05:00
|
|
|
}
|
2019-01-14 09:51:00 -05:00
|
|
|
foreach ($q as $query) {
|
|
|
|
static::$interface->query($query);
|
|
|
|
if (static::$interface->sqlstate !== "00000") {
|
|
|
|
throw new \Exception(static::$interface->error);
|
2019-01-13 23:17:19 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
protected function query(string $q) {
|
|
|
|
$r = static::$interface->query($q);
|
|
|
|
if ($r) {
|
|
|
|
$row = $r->fetch_row();
|
|
|
|
$r->free();
|
|
|
|
if ($row) {
|
|
|
|
return $row[0];
|
|
|
|
} else {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
}
|