Simplified injecting db connection for upgrades
This commit is contained in:
parent
2fc6a23e46
commit
df939e0343
5 changed files with 18 additions and 9 deletions
|
@ -22,12 +22,6 @@ abstract class AbstractDao implements ICrudDao
|
|||
});
|
||||
}
|
||||
|
||||
public function setDatabaseConnection(\Szurubooru\DatabaseConnection $databaseConnection)
|
||||
{
|
||||
$this->pdo = $databaseConnection->getPDO();
|
||||
$this->fpdo = new \FluentPDO($this->pdo);
|
||||
}
|
||||
|
||||
public function getTableName()
|
||||
{
|
||||
return $this->tableName;
|
||||
|
@ -189,6 +183,12 @@ abstract class AbstractDao implements ICrudDao
|
|||
return $entities;
|
||||
}
|
||||
|
||||
private function setDatabaseConnection(\Szurubooru\DatabaseConnection $databaseConnection)
|
||||
{
|
||||
$this->pdo = $databaseConnection->getPDO();
|
||||
$this->fpdo = new \FluentPDO($this->pdo);
|
||||
}
|
||||
|
||||
private function decorateQueryFromFilter($query, \Szurubooru\SearchServices\Filters\IFilter $filter)
|
||||
{
|
||||
foreach ($filter->getRequirements() as $requirement)
|
||||
|
|
|
@ -22,6 +22,11 @@ final class Injector
|
|||
{
|
||||
return self::$container->get($className);
|
||||
}
|
||||
|
||||
public static function set($className, $object)
|
||||
{
|
||||
return self::$container->set($className, $object);
|
||||
}
|
||||
}
|
||||
|
||||
Injector::init();
|
||||
|
|
|
@ -19,8 +19,6 @@ class Upgrade04 implements IUpgrade
|
|||
|
||||
public function run(\Szurubooru\DatabaseConnection $databaseConnection)
|
||||
{
|
||||
$this->postDao->setDatabaseConnection($databaseConnection);
|
||||
|
||||
$databaseConnection->getPDO()->exec('ALTER TABLE "posts" ADD COLUMN contentMimeType TEXT DEFAULT NULL');
|
||||
|
||||
$posts = $this->postDao->findAll();
|
||||
|
@ -28,7 +26,7 @@ class Upgrade04 implements IUpgrade
|
|||
{
|
||||
if ($post->getContentType() !== \Szurubooru\Entities\Post::POST_TYPE_YOUTUBE)
|
||||
{
|
||||
$fullPath = $this->fileService->getFullPath($this->postService->getPostContentPath($post));
|
||||
$fullPath = $this->fileService->getFullPath($post->getContentPath());
|
||||
$mime = \Szurubooru\Helpers\MimeHelper::getMimeTypeFromFile($fullPath);
|
||||
$post->setContentMimeType($mime);
|
||||
$this->postDao->save($post);
|
||||
|
|
|
@ -12,6 +12,7 @@ abstract class AbstractDatabaseTestCase extends \Szurubooru\Tests\AbstractTestCa
|
|||
$config->set('database/dsn', 'sqlite::memory:');
|
||||
|
||||
$this->databaseConnection = new \Szurubooru\DatabaseConnection($config);
|
||||
\Szurubooru\Injector::set(\Szurubooru\DatabaseConnection::class, $this->databaseConnection);
|
||||
|
||||
$upgradeRepository = \Szurubooru\Injector::get(\Szurubooru\Upgrades\UpgradeRepository::class);
|
||||
$upgradeService = new \Szurubooru\Services\UpgradeService($config, $this->databaseConnection, $upgradeRepository);
|
||||
|
|
|
@ -36,6 +36,11 @@ abstract class AbstractTestCase extends \PHPUnit_Framework_TestCase
|
|||
return __DIR__ . DIRECTORY_SEPARATOR . 'test_files' . DIRECTORY_SEPARATOR . $fileName;
|
||||
}
|
||||
|
||||
protected function setUp()
|
||||
{
|
||||
\Szurubooru\Injector::init();
|
||||
}
|
||||
|
||||
protected function tearDown()
|
||||
{
|
||||
$this->cleanTestDirectory();
|
||||
|
|
Loading…
Reference in a new issue