namespace Friendica\Test;
-use dba;
-use Friendica\Database\DBStructure;
-use PHPUnit_Extensions_Database_DB_IDatabaseConnection;
+use Friendica\App;
+use Friendica\BaseObject;
+use Friendica\Core\Config;
+use Friendica\Database\DBA;
use PHPUnit\DbUnit\DataSet\YamlDataSet;
use PHPUnit\DbUnit\TestCaseTrait;
use PHPUnit\Framework\TestCase;
+use PHPUnit_Extensions_Database_DB_IDatabaseConnection;
+
+require_once __DIR__ . '/../boot.php';
/**
* Abstract class used by tests that need a database.
*/
abstract class DatabaseTest extends TestCase
{
-
use TestCaseTrait;
- /**
- * Creates .htconfig.php for bin/worker.php execution
- */
- protected function setUp()
- {
- parent::setUp();
-
- $base_config_file_name = 'htconfig.php';
- $config_file_name = '.htconfig.php';
-
- $base_config_file_path = stream_resolve_include_path($base_config_file_name);
- $config_file_path = dirname($base_config_file_path) . DIRECTORY_SEPARATOR . $config_file_name;
-
- if (!file_exists($config_file_path)) {
- $config_string = file_get_contents($base_config_file_path);
-
- $config_string = str_replace('die(', '// die(', $config_string);
-
- file_put_contents($config_file_path, $config_string);
- }
- }
-
/**
* Get database connection.
*
*/
protected function getConnection()
{
- if (!dba::$connected) {
- dba::connect(getenv('MYSQL_HOST') . ':' . getenv('MYSQL_PORT'), getenv('MYSQL_USERNAME'), getenv('MYSQL_PASSWORD'), getenv('MYSQL_DATABASE'));
+ if (!getenv('MYSQL_DATABASE')) {
+ $this->markTestSkipped('Please set the MYSQL_* environment variables to your test database credentials.');
+ }
- if (dba::$connected) {
- $app = get_app();
- // We need to do this in order to disable logging
- $app->module = 'install';
+ DBA::connect(getenv('MYSQL_HOST'),
+ getenv('MYSQL_USERNAME'),
+ getenv('MYSQL_PASSWORD'),
+ getenv('MYSQL_DATABASE'));
- // Create database structure
- DBStructure::update(false, true, true);
- } else {
- $this->markTestSkipped('Could not connect to the database.');
- }
+ if (!DBA::connected()) {
+ $this->markTestSkipped('Could not connect to the database.');
}
- return $this->createDefaultDBConnection(dba::get_db(), getenv('DB'));
+ return $this->createDefaultDBConnection(DBA::getConnection(), getenv('MYSQL_DATABASE'));
}
/**