87 lines
		
	
	
	
		
			2.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			87 lines
		
	
	
	
		
			2.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
|  * DatabaseTest class.
 | |
|  */
 | |
| 
 | |
| namespace Friendica\Test;
 | |
| 
 | |
| use dba;
 | |
| use Friendica\Database\DBStructure;
 | |
| use PHPUnit_Extensions_Database_DB_IDatabaseConnection;
 | |
| use PHPUnit\DbUnit\DataSet\YamlDataSet;
 | |
| use PHPUnit\DbUnit\TestCaseTrait;
 | |
| use PHPUnit\Framework\TestCase;
 | |
| 
 | |
| /**
 | |
|  * 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;
 | |
| 
 | |
| 		$config_string = file_get_contents($base_config_file_path);
 | |
| 
 | |
| 		$config_string = str_replace('die(', '// die(', $config_string);
 | |
| 		$config_string = str_replace('your.mysqlhost.com', 'localhost', $config_string);
 | |
| 		$config_string = str_replace('mysqlusername'     , getenv('USER'), $config_string);
 | |
| 		$config_string = str_replace('mysqlpassword'     , getenv('PASS'), $config_string);
 | |
| 		$config_string = str_replace('mysqldatabasename' , getenv('DB'), $config_string);
 | |
| 
 | |
| 		file_put_contents($config_file_path, $config_string);
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * 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()
 | |
| 	{
 | |
| 		if (!dba::$connected) {
 | |
| 			dba::connect('localhost', getenv('USER'), getenv('PASS'), getenv('DB'));
 | |
| 
 | |
| 			if (dba::$connected) {
 | |
| 				$app = get_app();
 | |
| 				// We need to do this in order to disable logging
 | |
| 				$app->module = 'install';
 | |
| 
 | |
| 				// Create database structure
 | |
| 				DBStructure::update(false, true, true);
 | |
| 			} else {
 | |
| 				$this->markTestSkipped('Could not connect to the database.');
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		return $this->createDefaultDBConnection(dba::get_db(), getenv('DB'));
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Get dataset to populate the database with.
 | |
| 	 * @return YamlDataSet
 | |
| 	 * @see https://phpunit.de/manual/5.7/en/database.html
 | |
| 	 */
 | |
| 	protected function getDataSet()
 | |
| 	{
 | |
| 		return new YamlDataSet(__DIR__ . '/datasets/api.yml');
 | |
| 	}
 | |
| }
 |