fix(db): Prevent two connections for single node databases
Signed-off-by: Christoph Wurst <christoph@winzerhof-wurst.at>pull/45013/head
parent
f0ec5489a4
commit
3bfba2042c
@ -0,0 +1,101 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
declare(strict_types=1);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* SPDX-FileCopyrightText: 2024 Nextcloud GmbH and Nextcloud contributors
|
||||||
|
* SPDX-License-Identifier: AGPL-3.0-or-later
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace Test\DB;
|
||||||
|
|
||||||
|
use Doctrine\DBAL\Configuration;
|
||||||
|
use Doctrine\DBAL\Driver;
|
||||||
|
use Doctrine\DBAL\Driver\Connection as DriverConnection;
|
||||||
|
use Doctrine\DBAL\Platforms\MySQLPlatform;
|
||||||
|
use OC\DB\Adapter;
|
||||||
|
use OC\DB\Connection;
|
||||||
|
use Test\TestCase;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @group DB
|
||||||
|
*/
|
||||||
|
class ConnectionTest extends TestCase {
|
||||||
|
|
||||||
|
public function testSingleNodeConnectsToPrimaryOnly(): void {
|
||||||
|
$connectionParams = [
|
||||||
|
'user' => 'test',
|
||||||
|
'password' => 'topsecret',
|
||||||
|
'host' => 'test',
|
||||||
|
];
|
||||||
|
$adapter = $this->createMock(Adapter::class);
|
||||||
|
$driver = $this->createMock(Driver::class);
|
||||||
|
$configuration = $this->createMock(Configuration::class);
|
||||||
|
$connection = $this->getMockBuilder(Connection::class)
|
||||||
|
->onlyMethods(['connectTo'])
|
||||||
|
->setConstructorArgs([
|
||||||
|
[
|
||||||
|
'adapter' => $adapter,
|
||||||
|
'platform' => new MySQLPlatform(),
|
||||||
|
'tablePrefix' => 'nctest',
|
||||||
|
'primary' => $connectionParams,
|
||||||
|
'replica' => [
|
||||||
|
$connectionParams,
|
||||||
|
],
|
||||||
|
],
|
||||||
|
$driver,
|
||||||
|
$configuration,
|
||||||
|
])
|
||||||
|
->getMock();
|
||||||
|
$driverConnection = $this->createMock(DriverConnection::class);
|
||||||
|
$connection->expects(self::once())
|
||||||
|
->method('connectTo')
|
||||||
|
->with('primary')
|
||||||
|
->willReturn($driverConnection);
|
||||||
|
|
||||||
|
$connection->ensureConnectedToReplica();
|
||||||
|
$connection->ensureConnectedToPrimary();
|
||||||
|
$connection->ensureConnectedToReplica();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testClusterConnectsToPrimaryAndReplica(): void {
|
||||||
|
$connectionParamsPrimary = [
|
||||||
|
'user' => 'test',
|
||||||
|
'password' => 'topsecret',
|
||||||
|
'host' => 'testprimary',
|
||||||
|
];
|
||||||
|
$connectionParamsReplica = [
|
||||||
|
'user' => 'test',
|
||||||
|
'password' => 'topsecret',
|
||||||
|
'host' => 'testreplica',
|
||||||
|
];
|
||||||
|
$adapter = $this->createMock(Adapter::class);
|
||||||
|
$driver = $this->createMock(Driver::class);
|
||||||
|
$configuration = $this->createMock(Configuration::class);
|
||||||
|
$connection = $this->getMockBuilder(Connection::class)
|
||||||
|
->onlyMethods(['connectTo'])
|
||||||
|
->setConstructorArgs([
|
||||||
|
[
|
||||||
|
'adapter' => $adapter,
|
||||||
|
'platform' => new MySQLPlatform(),
|
||||||
|
'tablePrefix' => 'nctest',
|
||||||
|
'primary' => $connectionParamsPrimary,
|
||||||
|
'replica' => [
|
||||||
|
$connectionParamsReplica,
|
||||||
|
],
|
||||||
|
],
|
||||||
|
$driver,
|
||||||
|
$configuration,
|
||||||
|
])
|
||||||
|
->getMock();
|
||||||
|
$driverConnection = $this->createMock(DriverConnection::class);
|
||||||
|
$connection->expects(self::exactly(2))
|
||||||
|
->method('connectTo')
|
||||||
|
->willReturn($driverConnection);
|
||||||
|
|
||||||
|
$connection->ensureConnectedToReplica();
|
||||||
|
$connection->ensureConnectedToPrimary();
|
||||||
|
$connection->ensureConnectedToReplica();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
Loading…
Reference in New Issue