mirror of
https://github.com/shlinkio/shlink.git
synced 2024-11-28 00:38:46 +03:00
Small improvements on CreateDatabaseCommand
This commit is contained in:
parent
430e2ff0b5
commit
3a82691503
2 changed files with 12 additions and 8 deletions
|
@ -66,7 +66,7 @@ class CreateDatabaseCommand extends AbstractDatabaseCommand
|
||||||
|
|
||||||
private function checkDbExists(): void
|
private function checkDbExists(): void
|
||||||
{
|
{
|
||||||
if ($this->regularConn->getDatabasePlatform() instanceof SqlitePlatform) {
|
if ($this->regularConn->getDriver()->getDatabasePlatform() instanceof SqlitePlatform) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -74,7 +74,7 @@ class CreateDatabaseCommand extends AbstractDatabaseCommand
|
||||||
// Otherwise, it will fail to connect and will not be able to create the new database
|
// Otherwise, it will fail to connect and will not be able to create the new database
|
||||||
$schemaManager = $this->noDbNameConn->createSchemaManager();
|
$schemaManager = $this->noDbNameConn->createSchemaManager();
|
||||||
$databases = $schemaManager->listDatabases();
|
$databases = $schemaManager->listDatabases();
|
||||||
$shlinkDatabase = $this->regularConn->getDatabase();
|
$shlinkDatabase = $this->regularConn->getParams()['dbname'] ?? null;
|
||||||
|
|
||||||
if ($shlinkDatabase !== null && ! contains($databases, $shlinkDatabase)) {
|
if ($shlinkDatabase !== null && ! contains($databases, $shlinkDatabase)) {
|
||||||
$schemaManager->createDatabase($shlinkDatabase);
|
$schemaManager->createDatabase($shlinkDatabase);
|
||||||
|
|
|
@ -5,6 +5,7 @@ declare(strict_types=1);
|
||||||
namespace ShlinkioTest\Shlink\CLI\Command\Db;
|
namespace ShlinkioTest\Shlink\CLI\Command\Db;
|
||||||
|
|
||||||
use Doctrine\DBAL\Connection;
|
use Doctrine\DBAL\Connection;
|
||||||
|
use Doctrine\DBAL\Driver;
|
||||||
use Doctrine\DBAL\Platforms\AbstractPlatform;
|
use Doctrine\DBAL\Platforms\AbstractPlatform;
|
||||||
use Doctrine\DBAL\Platforms\SqlitePlatform;
|
use Doctrine\DBAL\Platforms\SqlitePlatform;
|
||||||
use Doctrine\DBAL\Schema\AbstractSchemaManager;
|
use Doctrine\DBAL\Schema\AbstractSchemaManager;
|
||||||
|
@ -30,6 +31,7 @@ class CreateDatabaseCommandTest extends TestCase
|
||||||
private ObjectProphecy $processHelper;
|
private ObjectProphecy $processHelper;
|
||||||
private ObjectProphecy $regularConn;
|
private ObjectProphecy $regularConn;
|
||||||
private ObjectProphecy $schemaManager;
|
private ObjectProphecy $schemaManager;
|
||||||
|
private ObjectProphecy $driver;
|
||||||
|
|
||||||
public function setUp(): void
|
public function setUp(): void
|
||||||
{
|
{
|
||||||
|
@ -48,7 +50,9 @@ class CreateDatabaseCommandTest extends TestCase
|
||||||
|
|
||||||
$this->regularConn = $this->prophesize(Connection::class);
|
$this->regularConn = $this->prophesize(Connection::class);
|
||||||
$this->regularConn->createSchemaManager()->willReturn($this->schemaManager->reveal());
|
$this->regularConn->createSchemaManager()->willReturn($this->schemaManager->reveal());
|
||||||
$this->regularConn->getDatabasePlatform()->willReturn($this->prophesize(AbstractPlatform::class)->reveal());
|
$this->driver = $this->prophesize(Driver::class);
|
||||||
|
$this->regularConn->getDriver()->willReturn($this->driver->reveal());
|
||||||
|
$this->driver->getDatabasePlatform()->willReturn($this->prophesize(AbstractPlatform::class)->reveal());
|
||||||
$noDbNameConn = $this->prophesize(Connection::class);
|
$noDbNameConn = $this->prophesize(Connection::class);
|
||||||
$noDbNameConn->createSchemaManager()->willReturn($this->schemaManager->reveal());
|
$noDbNameConn->createSchemaManager()->willReturn($this->schemaManager->reveal());
|
||||||
|
|
||||||
|
@ -67,7 +71,7 @@ class CreateDatabaseCommandTest extends TestCase
|
||||||
public function successMessageIsPrintedIfDatabaseAlreadyExists(): void
|
public function successMessageIsPrintedIfDatabaseAlreadyExists(): void
|
||||||
{
|
{
|
||||||
$shlinkDatabase = 'shlink_database';
|
$shlinkDatabase = 'shlink_database';
|
||||||
$getDatabase = $this->regularConn->getDatabase()->willReturn($shlinkDatabase);
|
$getDatabase = $this->regularConn->getParams()->willReturn(['dbname' => $shlinkDatabase]);
|
||||||
$listDatabases = $this->schemaManager->listDatabases()->willReturn(['foo', $shlinkDatabase, 'bar']);
|
$listDatabases = $this->schemaManager->listDatabases()->willReturn(['foo', $shlinkDatabase, 'bar']);
|
||||||
$createDatabase = $this->schemaManager->createDatabase($shlinkDatabase)->will(function (): void {
|
$createDatabase = $this->schemaManager->createDatabase($shlinkDatabase)->will(function (): void {
|
||||||
});
|
});
|
||||||
|
@ -87,7 +91,7 @@ class CreateDatabaseCommandTest extends TestCase
|
||||||
public function databaseIsCreatedIfItDoesNotExist(): void
|
public function databaseIsCreatedIfItDoesNotExist(): void
|
||||||
{
|
{
|
||||||
$shlinkDatabase = 'shlink_database';
|
$shlinkDatabase = 'shlink_database';
|
||||||
$getDatabase = $this->regularConn->getDatabase()->willReturn($shlinkDatabase);
|
$getDatabase = $this->regularConn->getParams()->willReturn(['dbname' => $shlinkDatabase]);
|
||||||
$listDatabases = $this->schemaManager->listDatabases()->willReturn(['foo', 'bar']);
|
$listDatabases = $this->schemaManager->listDatabases()->willReturn(['foo', 'bar']);
|
||||||
$createDatabase = $this->schemaManager->createDatabase($shlinkDatabase)->will(function (): void {
|
$createDatabase = $this->schemaManager->createDatabase($shlinkDatabase)->will(function (): void {
|
||||||
});
|
});
|
||||||
|
@ -108,7 +112,7 @@ class CreateDatabaseCommandTest extends TestCase
|
||||||
public function tablesAreCreatedIfDatabaseIsEmpty(array $tables): void
|
public function tablesAreCreatedIfDatabaseIsEmpty(array $tables): void
|
||||||
{
|
{
|
||||||
$shlinkDatabase = 'shlink_database';
|
$shlinkDatabase = 'shlink_database';
|
||||||
$getDatabase = $this->regularConn->getDatabase()->willReturn($shlinkDatabase);
|
$getDatabase = $this->regularConn->getParams()->willReturn(['dbname' => $shlinkDatabase]);
|
||||||
$listDatabases = $this->schemaManager->listDatabases()->willReturn(['foo', $shlinkDatabase, 'bar']);
|
$listDatabases = $this->schemaManager->listDatabases()->willReturn(['foo', $shlinkDatabase, 'bar']);
|
||||||
$createDatabase = $this->schemaManager->createDatabase($shlinkDatabase)->will(function (): void {
|
$createDatabase = $this->schemaManager->createDatabase($shlinkDatabase)->will(function (): void {
|
||||||
});
|
});
|
||||||
|
@ -141,10 +145,10 @@ class CreateDatabaseCommandTest extends TestCase
|
||||||
/** @test */
|
/** @test */
|
||||||
public function databaseCheckIsSkippedForSqlite(): void
|
public function databaseCheckIsSkippedForSqlite(): void
|
||||||
{
|
{
|
||||||
$this->regularConn->getDatabasePlatform()->willReturn($this->prophesize(SqlitePlatform::class)->reveal());
|
$this->driver->getDatabasePlatform()->willReturn($this->prophesize(SqlitePlatform::class)->reveal());
|
||||||
|
|
||||||
$shlinkDatabase = 'shlink_database';
|
$shlinkDatabase = 'shlink_database';
|
||||||
$getDatabase = $this->regularConn->getDatabase()->willReturn($shlinkDatabase);
|
$getDatabase = $this->regularConn->getParams()->willReturn(['dbname' => $shlinkDatabase]);
|
||||||
$listDatabases = $this->schemaManager->listDatabases()->willReturn(['foo', 'bar']);
|
$listDatabases = $this->schemaManager->listDatabases()->willReturn(['foo', 'bar']);
|
||||||
$createDatabase = $this->schemaManager->createDatabase($shlinkDatabase)->will(function (): void {
|
$createDatabase = $this->schemaManager->createDatabase($shlinkDatabase)->will(function (): void {
|
||||||
});
|
});
|
||||||
|
|
Loading…
Reference in a new issue