]> git.mxchange.org Git - friendica.git/blobdiff - tests/DatabaseTest.php
Merge pull request #5331 from nupplaphil/lock_tests_fixings
[friendica.git] / tests / DatabaseTest.php
index 12150932c9dba2a6da019514d2284da17f53f010..e79e9237be9d3a9ce0f1031290cc96cdd23d89e5 100644 (file)
@@ -20,6 +20,54 @@ abstract class DatabaseTest extends TestCase
 
        use TestCaseTrait;
 
+       /**
+        * Renames an eventually existing .htconfig.php to .htconfig.php.tmp
+        * Creates a new .htconfig.php for bin/worker.php execution
+        */
+       public static function setUpBeforeClass()
+       {
+               parent::setUpBeforeClass();
+
+               $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;
+               $config_file_path_tmp = $config_file_path . '.tmp';
+
+               if (file_exists($config_file_path)) {
+                       rename($config_file_path, $config_file_path_tmp);
+               }
+
+               $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);
+       }
+
+       /**
+        * Delete the created .htconfig.php
+        * Renames an eventually existing .htconfig.php.tmp to .htconfig.php
+        */
+       public static function tearDownAfterClass()
+       {
+               $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;
+               $config_file_path_tmp = $config_file_path . '.tmp';
+
+               if (file_exists($config_file_path)) {
+                       unlink($config_file_path);
+               }
+
+               if (file_exists($config_file_path_tmp)) {
+                       rename($config_file_path_tmp, $config_file_path);
+               }
+       }
+
        /**
         * Get database connection.
         *
@@ -34,21 +82,23 @@ abstract class DatabaseTest extends TestCase
        protected function getConnection()
        {
                if (!dba::$connected) {
-                       dba::connect('localhost', getenv('USER'), getenv('PASS'), getenv('DB'));
+                       dba::connect(getenv('MYSQL_HOST') . ':' . getenv('MYSQL_PORT'), getenv('MYSQL_USERNAME'), getenv('MYSQL_PASSWORD'), getenv('MYSQL_DATABASE'));
 
                        if (dba::$connected) {
                                $app = get_app();
                                // We need to do this in order to disable logging
-                               $app->module = 'install';
+                               $app->mode = \Friendica\App::MODE_INSTALL;
 
                                // Create database structure
                                DBStructure::update(false, true, true);
+
+                               $app->mode = \Friendica\App::MODE_NORMAL;
                        } else {
-                               $this->markTestSkipped('Could not connect to the database.');
+                               $this->markTestSkipped('Could not connect to the database. Please check the MYSQL_* environment variables.');
                        }
                }
 
-               return $this->createDefaultDBConnection(dba::get_db(), getenv('DB'));
+               return $this->createDefaultDBConnection(dba::get_db(), getenv('MYSQL_DATABASE'));
        }
 
        /**