75 lines
		
	
	
	
		
			2.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			75 lines
		
	
	
	
		
			2.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| namespace Friendica\Test\src\Database;
 | |
| 
 | |
| use Friendica\App;
 | |
| use Friendica\Core\Config\Cache\PConfigCache;
 | |
| use Friendica\Database\DBStructure;
 | |
| use Friendica\Factory;
 | |
| use Friendica\Test\DatabaseTest;
 | |
| use Friendica\Util\BasePath;
 | |
| use Friendica\Util\BaseURL;
 | |
| use Friendica\Util\Config\ConfigFileLoader;
 | |
| 
 | |
| class DBStructureTest extends DatabaseTest
 | |
| {
 | |
| 	public function setUp()
 | |
| 	{
 | |
| 		$basePath = BasePath::create(dirname(__DIR__) . '/../../');
 | |
| 		$mode = new App\Mode($basePath);
 | |
| 		$router = new App\Router();
 | |
| 		$configLoader = new ConfigFileLoader($basePath, $mode);
 | |
| 		$configCache = Factory\ConfigFactory::createCache($configLoader);
 | |
| 		$profiler = Factory\ProfilerFactory::create($configCache);
 | |
| 		$database = Factory\DBFactory::init($configCache, $profiler, $_SERVER);
 | |
| 		$config = Factory\ConfigFactory::createConfig($configCache);
 | |
| 		Factory\ConfigFactory::createPConfig($configCache, new PConfigCache());
 | |
| 		$logger = Factory\LoggerFactory::create('test', $database, $config, $profiler);
 | |
| 		$baseUrl = new BaseURL($config, $_SERVER);
 | |
| 		$this->app = new App($database, $config, $mode, $router, $baseUrl, $logger, $profiler, false);
 | |
| 
 | |
| 		parent::setUp();
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * @small
 | |
| 	 */
 | |
| 	public function testExists() {
 | |
| 		$this->assertTrue(DBStructure::existsTable('config'));
 | |
| 
 | |
| 		$this->assertFalse(DBStructure::existsTable('notatable'));
 | |
| 
 | |
| 		$this->assertTrue(DBStructure::existsColumn('config', ['k']));
 | |
| 		$this->assertFalse(DBStructure::existsColumn('config', ['nonsense']));
 | |
| 		$this->assertFalse(DBStructure::existsColumn('config', ['k', 'nonsense']));
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * @small
 | |
| 	 */
 | |
| 	public function testRename() {
 | |
| 		$fromColumn = 'k';
 | |
| 		$toColumn = 'key';
 | |
| 		$fromType = 'varbinary(255) not null';
 | |
| 		$toType = 'varbinary(255) not null comment \'Test To Type\'';
 | |
| 
 | |
| 		$this->assertTrue(DBStructure::rename('config', [ $fromColumn => [ $toColumn, $toType ]]));
 | |
| 		$this->assertTrue(DBStructure::existsColumn('config', [ $toColumn ]));
 | |
| 		$this->assertFalse(DBStructure::existsColumn('config', [ $fromColumn ]));
 | |
| 
 | |
| 		$this->assertTrue(DBStructure::rename('config', [ $toColumn => [ $fromColumn, $fromType ]]));
 | |
| 		$this->assertTrue(DBStructure::existsColumn('config', [ $fromColumn ]));
 | |
| 		$this->assertFalse(DBStructure::existsColumn('config', [ $toColumn ]));
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * @small
 | |
| 	 */
 | |
| 	public function testChangePrimaryKey() {
 | |
| 		$oldID = 'client_id';
 | |
| 		$newID = 'pw';
 | |
| 
 | |
| 		$this->assertTrue(DBStructure::rename('clients', [ $newID ], DBStructure::RENAME_PRIMARY_KEY));
 | |
| 		$this->assertTrue(DBStructure::rename('clients', [ $oldID ], DBStructure::RENAME_PRIMARY_KEY));
 | |
| 	}
 | |
| }
 |