connect(); $cons[1][0]->connect(); $cons[2][0]->connect(); $cons[3][0]->connect(); return $cons; } /** * @testdox Mysql database drop forms a valid query * @group framework * @dataProvider dbConnectionProvider */ public function testDrop($con) : void { if (!$con->isInitialized()) { self::markTestSkipped(); return; } $iS = $con->getGrammar()->systemIdentifierStart; $iE = $con->getGrammar()->systemIdentifierEnd; $query = new Builder($con); $sql = 'DROP DATABASE [test];'; $sql = \strtr($sql, '[]', $iS . $iE); self::assertEquals($sql, $query->dropDatabase('test')->toSql()); } /** * @testdox Mysql table drop forms a valid query * @group framework * @dataProvider dbConnectionProvider */ public function testDropTable($con) : void { if (!$con->isInitialized()) { self::markTestSkipped(); return; } $iS = $con->getGrammar()->systemIdentifierStart; $iE = $con->getGrammar()->systemIdentifierEnd; $query = new Builder($con); $sql = 'DROP TABLE [test];'; $sql = \strtr($sql, '[]', $iS . $iE); self::assertEquals($sql, $query->dropTable('test')->toSql()); } /** * @testdox Mysql show tables form a valid query * @group framework * @dataProvider dbConnectionProvider */ public function testShowTables($con) : void { if (!$con->isInitialized()) { self::markTestSkipped(); return; } $iS = $con->getGrammar()->systemIdentifierStart; $iE = $con->getGrammar()->systemIdentifierEnd; $query = new Builder($con); $sql = ''; if ($con instanceof MysqlConnection) { $sql = 'SELECT [table_name] FROM [information_schema].[tables] WHERE [table_schema] = \'' . $GLOBALS['CONFIG']['db']['core']['masters']['admin']['database']. '\';'; } elseif ($con instanceof PostgresConnection) { $sql = 'SELECT [table_name] FROM [information_schema].[tables] WHERE [table_schema] = \'' . $GLOBALS['CONFIG']['db']['core']['masters']['admin']['database']. '\';'; } elseif ($con instanceof SqlServerConnection) { $sql = 'SELECT [table_name] FROM [sys].[tables] INNER JOIN [sys].[schemas] ON [sys].[tables.schema_id] = [sys].[schemas.schema_id];'; } elseif ($con instanceof SQLiteConnection) { $sql = 'SELECT `name` FROM `sqlite_master` WHERE `type` = \'table\';'; } $sql = \strtr($sql, '[]', $iS . $iE); self::assertEquals($sql, $query->selectTables()->toSql()); } /** * @testdox Mysql show fields form a valid query * @group framework * @dataProvider dbConnectionProvider */ public function testShowFields($con) : void { if (!$con->isInitialized()) { self::markTestSkipped(); return; } $iS = $con->getGrammar()->systemIdentifierStart; $iE = $con->getGrammar()->systemIdentifierEnd; $query = new Builder($con); $sql = ''; if ($con instanceof MysqlConnection) { $sql = 'SELECT * FROM [information_schema].[columns] WHERE [table_schema] = \'' . $GLOBALS['CONFIG']['db']['core']['masters']['admin']['database']. '\' AND [table_name] = \'test\';'; } elseif ($con instanceof PostgresConnection) { $sql = 'SELECT * FROM [information_schema].[columns] WHERE [table_schema] = \'' . $GLOBALS['CONFIG']['db']['core']['masters']['admin']['database']. '\' AND [table_name] = \'test\';'; } elseif ($con instanceof SqlServerConnection) { $sql = 'SELECT * FROM [information_schema].[columns] WHERE [table_schema] = \'' . $GLOBALS['CONFIG']['db']['core']['masters']['admin']['database']. '\' AND [table_name] = \'test\';'; } elseif ($con instanceof SQLiteConnection) { $sql = 'SELECT * FROM pragma_table_info(\'test\') WHERE pragma_table_info(\'test\') = \'test\';'; } $sql = ''; $sql = \strtr($sql, '[]', $iS . $iE); self::assertEquals($sql, $query->selectFields('test')->toSql()); } /** * @testdox Mysql create tables form a valid query * @group framework * @dataProvider dbConnectionProvider */ public function testCreateTable($con) : void { if (!$con->isInitialized()) { self::markTestSkipped(); return; } $iS = $con->getGrammar()->systemIdentifierStart; $iE = $con->getGrammar()->systemIdentifierEnd; // @todo: fix, this is not correct for sqlite $query = new Builder($con); $sql = 'CREATE TABLE IF NOT EXISTS [user_roles] ([user_id] INT AUTO_INCREMENT, [role_id] VARCHAR(10) DEFAULT \'1\' NULL, PRIMARY KEY ([user_id]), FOREIGN KEY ([user_id]) REFERENCES [users] ([ext1_id]), FOREIGN KEY ([role_id]) REFERENCES [roles] ([ext2_id])) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 AUTO_INCREMENT=1;'; $sql = \strtr($sql, '[]', $iS . $iE); self::assertEquals( $sql, $query->createTable('user_roles') ->field('user_id', 'INT', null, false, true, false, true, 'users', 'ext1_id') ->field('role_id', 'VARCHAR(10)', '1', true, false, false, false, 'roles', 'ext2_id') ->toSql() ); } /* public function testAlter($con) : void { if (!$con->isInitialized()) { self::markTestSkipped(); return; } $iS = $con->getGrammar()->systemIdentifierStart; $iE = $con->getGrammar()->systemIdentifierEnd; $query = new Builder($con); $sql = 'CREATE TABLE IF NOT EXISTS user_roles (user_id INT NOT NULL AUTO_INCREMENT, role_id VARCHAR(10) DEFAULT \'1\' NULL, PRIMARY KEY (user_id), FOREIGN KEY (user_id) REFERENCES users (ext1_id), FOREIGN KEY (role_id) REFERENCES roles (ext2_id)) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 AUTO_INCREMENT=1;'; $sql = \strtr($sql, '[]', $iS . $iE); self::assertEquals( $sql, $query->createTable('user_roles') ->field('user_id', 'INT', null, false, true, false, true, 'users', 'ext1_id') ->field('role_id', 'VARCHAR(10)', '1', true, false, false, false, 'roles', 'ext2_id') ->toSql() ); } */ /** * @testdox The grammar correctly deletes a table * @covers phpOMS\DataStorage\Database\Schema\Grammar\MysqlGrammar * @group framework * @dataProvider dbConnectionProvider */ public function testCreateFromSchema($con) : void { if (!$con->isInitialized()) { self::markTestSkipped(); return; } $iS = $con->getGrammar()->systemIdentifierStart; $iE = $con->getGrammar()->systemIdentifierEnd; $query = new Builder($con); $sql = 'DROP TABLE [test], [test_foreign];'; $sql = \strtr($sql, '[]', $iS . $iE); self::assertEquals( $sql, $query->dropTable('test')->dropTable('test_foreign')->toSql() ); } }