<?php
/**
- * @copyright Copyright (C) 2020, Friendica
+ * @copyright Copyright (C) 2010-2022, the Friendica project
*
* @license GNU AGPL version 3 or any later version
*
namespace Friendica\Test;
use Friendica\Database\Database;
-use Friendica\Database\DBStructure;
use Friendica\Test\Util\Database\StaticDatabase;
/**
*/
trait DatabaseTestTrait
{
- protected function setUp()
+ protected function setUpDb()
{
StaticDatabase::statConnect($_SERVER);
// Rollbacks every DB usage (in case the test couldn't call tearDown)
StaticDatabase::statRollback();
+ // Rollback the first, outer transaction just 2 be sure
+ StaticDatabase::getGlobConnection()->rollBack();
// Start the first, outer transaction
StaticDatabase::getGlobConnection()->beginTransaction();
-
- $this->dba->setTestmode(true);
-
- DBStructure::checkInitialValues();
-
- parent::setUp();
}
- protected function tearDown()
+ protected function tearDownDb()
{
- // Rollbacks every DB usage so we don't commit anything into the DB
- StaticDatabase::statRollback();
-
- parent::tearDown();
+ try {
+ // Rollbacks every DB usage so we don't commit anything into the DB
+ StaticDatabase::statRollback();
+ } catch (\PDOException $exception) {
+ print_r("Found already rolled back transaction");
+ }
}
/**
}
if (!is_array($rows)) {
- $dba->p('TRUNCATE TABLE `' . $tableName . '``');
+ $dba->e('TRUNCATE TABLE `' . $tableName . '``');
continue;
}