mirror of
https://code.mensbeam.com/MensBeam/Arsse.git
synced 2025-01-05 15:32:40 +00:00
46 lines
1.5 KiB
PHP
46 lines
1.5 KiB
PHP
<?php
|
|
|
|
/** @license MIT
|
|
* Copyright 2017 J. King, Dustin Wilson et al.
|
|
* See LICENSE and AUTHORS files for details */
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace JKingWeb\Arsse\TestCase\Db\PostgreSQL;
|
|
|
|
use JKingWeb\Arsse\Database;
|
|
use PHPUnit\Framework\Attributes\CoversClass;
|
|
use PHPUnit\Framework\Attributes\Group;
|
|
|
|
#[Group('slow')]
|
|
#[Group('coverageOptional')]
|
|
#[CoversClass(Database::class)]
|
|
class TestDatabase extends \JKingWeb\Arsse\TestCase\Database\AbstractTest {
|
|
use \JKingWeb\Arsse\Test\DatabaseDrivers\PostgreSQL;
|
|
|
|
protected function nextID(string $table): int {
|
|
return (int) static::$drv->query("SELECT coalesce(last_value, (select max(id) from $table)) + 1 from pg_sequences where sequencename = '{$table}_id_seq'")->getValue();
|
|
}
|
|
|
|
public function setUp(): void {
|
|
parent::setUp();
|
|
$seqList =
|
|
"select
|
|
replace(substring(column_default, 10), right(column_default, 12), '') as seq,
|
|
table_name as table,
|
|
column_name as col
|
|
from information_schema.columns
|
|
where table_schema = current_schema()
|
|
and table_name like 'arsse_%'
|
|
and column_default like 'nextval(%'
|
|
";
|
|
foreach (static::$drv->query($seqList) as $r) {
|
|
$num = (int) static::$drv->query("SELECT max({$r['col']}) from {$r['table']}")->getValue();
|
|
if (!$num) {
|
|
continue;
|
|
}
|
|
$num++;
|
|
static::$drv->exec("ALTER SEQUENCE {$r['seq']} RESTART WITH $num");
|
|
}
|
|
}
|
|
}
|