2018-12-14 00:47:51 +00: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 15:17:01 +00:00
|
|
|
|
2018-12-14 00:47:51 +00:00
|
|
|
namespace JKingWeb\Arsse\TestCase\Db\PostgreSQL;
|
|
|
|
|
|
|
|
use JKingWeb\Arsse\Arsse;
|
|
|
|
use JKingWeb\Arsse\Db\PostgreSQL\Driver;
|
2024-12-28 04:39:44 +00:00
|
|
|
use PHPUnit\Framework\Attributes\CoversClass;
|
|
|
|
use PHPUnit\Framework\Attributes\DataProvider;
|
|
|
|
use PHPUnit\Framework\Attributes\Group;
|
2018-12-14 00:47:51 +00:00
|
|
|
|
2024-12-28 04:39:44 +00:00
|
|
|
#[Group("slow")]
|
|
|
|
#[CoversClass(\JKingWeb\Arsse\Db\PostgreSQL\Driver::class)]
|
2018-12-14 00:47:51 +00:00
|
|
|
class TestCreation extends \JKingWeb\Arsse\Test\AbstractTest {
|
2019-10-16 18:42:43 +00:00
|
|
|
public function setUp(): void {
|
2018-12-14 00:47:51 +00:00
|
|
|
if (!Driver::requirementsMet()) {
|
|
|
|
$this->markTestSkipped("PostgreSQL extension not loaded");
|
|
|
|
}
|
|
|
|
}
|
2020-03-01 20:16:50 +00:00
|
|
|
|
2024-12-28 04:39:44 +00:00
|
|
|
#[DataProvider("provideConnectionStrings")]
|
2020-01-20 18:52:48 +00:00
|
|
|
public function testGenerateConnectionString(bool $pdo, string $user, string $pass, string $db, string $host, int $port, string $service, string $exp): void {
|
2018-12-14 00:47:51 +00:00
|
|
|
self::setConf();
|
|
|
|
$timeout = (string) ceil(Arsse::$conf->dbTimeoutConnect ?? 0);
|
|
|
|
$postfix = "application_name='arsse' client_encoding='UTF8' connect_timeout='$timeout'";
|
|
|
|
$act = Driver::makeConnectionString($pdo, $user, $pass, $db, $host, $port, $service);
|
2019-01-11 15:38:06 +00:00
|
|
|
if ($act === $postfix) {
|
2018-12-14 00:47:51 +00:00
|
|
|
$this->assertSame($exp, "");
|
|
|
|
} else {
|
|
|
|
$test = substr($act, 0, strlen($act) - (strlen($postfix) + 1));
|
|
|
|
$check = substr($act, strlen($test) + 1);
|
|
|
|
$this->assertSame($postfix, $check);
|
|
|
|
$this->assertSame($exp, $test);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-12-28 00:58:07 +00:00
|
|
|
public static function provideConnectionStrings(): iterable {
|
2018-12-14 00:47:51 +00:00
|
|
|
return [
|
|
|
|
[false, "arsse", "secret", "arsse", "", 5432, "", "dbname='arsse' password='secret' user='arsse'"],
|
|
|
|
[false, "arsse", "p word", "arsse", "", 5432, "", "dbname='arsse' password='p word' user='arsse'"],
|
|
|
|
[false, "arsse", "p'word", "arsse", "", 5432, "", "dbname='arsse' password='p\\'word' user='arsse'"],
|
|
|
|
[false, "arsse user", "secret", "arsse db", "", 5432, "", "dbname='arsse db' password='secret' user='arsse user'"],
|
|
|
|
[false, "arsse", "secret", "", "", 5432, "", "password='secret' user='arsse'"],
|
|
|
|
[false, "arsse", "secret", "arsse", "localhost", 5432, "", "dbname='arsse' host='localhost' password='secret' user='arsse'"],
|
|
|
|
[false, "arsse", "secret", "arsse", "", 9999, "", "dbname='arsse' password='secret' port='9999' user='arsse'"],
|
|
|
|
[false, "arsse", "secret", "arsse", "localhost", 9999, "", "dbname='arsse' host='localhost' password='secret' port='9999' user='arsse'"],
|
|
|
|
[false, "arsse", "secret", "arsse", "/socket", 9999, "", "dbname='arsse' host='/socket' password='secret' user='arsse'"],
|
|
|
|
[false, "T'Pau of Vulcan", "", "", "", 5432, "", "user='T\\'Pau of Vulcan'"],
|
|
|
|
[false, "T'Pau of Vulcan", "superman", "datumbase", "somehost", 2112, "arsse", "service='arsse'"],
|
|
|
|
[true, "arsse", "secret", "arsse", "", 5432, "", "dbname='arsse'"],
|
|
|
|
[true, "arsse", "p word", "arsse", "", 5432, "", "dbname='arsse'"],
|
|
|
|
[true, "arsse", "p'word", "arsse", "", 5432, "", "dbname='arsse'"],
|
|
|
|
[true, "arsse user", "secret", "arsse db", "", 5432, "", "dbname='arsse db'"],
|
|
|
|
[true, "arsse", "secret", "", "", 5432, "", ""],
|
|
|
|
[true, "arsse", "secret", "arsse", "localhost", 5432, "", "dbname='arsse' host='localhost'"],
|
|
|
|
[true, "arsse", "secret", "arsse", "", 9999, "", "dbname='arsse' port='9999'"],
|
|
|
|
[true, "arsse", "secret", "arsse", "localhost", 9999, "", "dbname='arsse' host='localhost' port='9999'"],
|
|
|
|
[true, "arsse", "secret", "arsse", "/socket", 9999, "", "dbname='arsse' host='/socket'"],
|
|
|
|
[true, "T'Pau of Vulcan", "", "", "", 5432, "", ""],
|
|
|
|
[true, "T'Pau of Vulcan", "superman", "datumbase", "somehost", 2112, "arsse", "service='arsse'"],
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
2020-01-20 18:52:48 +00:00
|
|
|
public function testFailToConnect(): void {
|
2018-12-14 00:47:51 +00:00
|
|
|
// we cannnot distinguish between different connection failure modes
|
|
|
|
self::setConf([
|
2019-10-11 17:04:15 +00:00
|
|
|
'dbPostgreSQLHost' => "example.invalid",
|
2018-12-14 00:47:51 +00:00
|
|
|
]);
|
|
|
|
$this->assertException("connectionFailure", "Db");
|
|
|
|
new Driver;
|
|
|
|
}
|
|
|
|
}
|