]> git.mxchange.org Git - friendica.git/blobdiff - tests/DatabaseTest.php
Posts per author/server on the community pages (#13764)
[friendica.git] / tests / DatabaseTest.php
index 98f79e351b5b9f008a24c86d2b357a4a7f8d7960..03bebb7b54b4f69c09c45f74867cc5e9213359f0 100644 (file)
@@ -1,83 +1,44 @@
 <?php
 /**
- * DatabaseTest class.
+ * @copyright Copyright (C) 2010-2023, the Friendica project
+ *
+ * @license GNU AGPL version 3 or any later version
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program.  If not, see <https://www.gnu.org/licenses/>.
+ *
  */
 
 namespace Friendica\Test;
 
-use PDO;
-use PHPUnit\DbUnit\DataSet\YamlDataSet;
-use PHPUnit\DbUnit\TestCaseTrait;
-use PHPUnit_Extensions_Database_DB_IDatabaseConnection;
-
 /**
  * Abstract class used by tests that need a database.
  */
 abstract class DatabaseTest extends MockedTest
 {
-       use TestCaseTrait;
-
-       // only instantiate pdo once for test clean-up/fixture load
-       static private $pdo = null;
-
-       // only instantiate PHPUnit_Extensions_Database_DB_IDatabaseConnection once per test
-       private $conn = null;
+       use DatabaseTestTrait;
 
-       /**
-        * Get database connection.
-        *
-        * This function is executed before each test in order to get a database connection that can be used by tests.
-        * If no prior connection is available, it tries to create one using the USER, PASS and DB environment variables.
-        *
-        * If it could not connect to the database, the test is skipped.
-        *
-        * @return PHPUnit_Extensions_Database_DB_IDatabaseConnection
-        * @see https://phpunit.de/manual/5.7/en/database.html
-        */
-       protected function getConnection()
+       protected function setUp(): void
        {
-               $server = $_SERVER;
-
-               if ($this->conn === null) {
-                       if (self::$pdo == null) {
-
-                               if (!empty($server['MYSQL_HOST'])
-                                   && !empty($server['MYSQL_USERNAME'] || !empty($server['MYSQL_USER']))
-                                   && $server['MYSQL_PASSWORD'] !== false
-                                   && !empty($server['MYSQL_DATABASE'])) {
-
-                                       $connect = "mysql:host=" . $server['MYSQL_HOST'] . ";dbname=" . $server['MYSQL_DATABASE'];
+               $this->setUpDb();
 
-                                       if (!empty($server['MYSQL_PORT'])) {
-                                               $connect .= ";port=" . $server['MYSQL_PORT'];
-                                       }
-
-                                       if (!empty($server['MYSQL_USERNAME'])) {
-                                               $db_user = $server['MYSQL_USERNAME'];
-                                       } else {
-                                               $db_user = $server['MYSQL_USER'];
-                                       }
-
-                                       $db_pass = (string)$server['MYSQL_PASSWORD'];
-
-                                       self::$pdo = @new PDO($connect, $db_user, $db_pass);
-                                       self::$pdo->setAttribute(PDO::ATTR_EMULATE_PREPARES, false);
-                               }
-                       }
-                       $this->conn = $this->createDefaultDBConnection(self::$pdo, getenv('MYSQL_DATABASE'));
-               }
-
-               return $this->conn;
+               parent::setUp();
        }
 
-       /**
-        * Get dataset to populate the database with.
-        *
-        * @return YamlDataSet
-        * @see https://phtablepunit.de/manual/5.7/en/database.html
-        */
-       protected function getDataSet()
+       protected function tearDown(): void
        {
-               return new YamlDataSet(__DIR__ . '/datasets/api.yml');
+               $this->tearDownDb();
+
+               parent::tearDown();
        }
 }