/
home
/
obinna
/
html
/
stage
/
phpmyadmin
/
tests
/
unit
/
Upload File
HOME
<?php declare(strict_types=1); namespace PhpMyAdmin\Tests; use PhpMyAdmin\Column; use PhpMyAdmin\ColumnFull; use PhpMyAdmin\Config; use PhpMyAdmin\Config\Settings\Server; use PhpMyAdmin\Current; use PhpMyAdmin\DatabaseInterface; use PhpMyAdmin\Dbal\ConnectionType; use PhpMyAdmin\Dbal\DbiExtension; use PhpMyAdmin\Dbal\ResultInterface; use PhpMyAdmin\Dbal\Statement; use PhpMyAdmin\Index; use PhpMyAdmin\LanguageManager; use PhpMyAdmin\Query\Utilities; use PhpMyAdmin\SqlParser\Context; use PhpMyAdmin\Utils\SessionCache; use PHPUnit\Framework\Attributes\CoversClass; use PHPUnit\Framework\Attributes\DataProvider; use ReflectionProperty; use function array_keys; #[CoversClass(DatabaseInterface::class)] #[CoversClass(Column::class)] #[CoversClass(ColumnFull::class)] class DatabaseInterfaceTest extends AbstractTestCase { protected function setUp(): void { parent::setUp(); DatabaseInterface::$instance = $this->createDatabaseInterface(); } /** * Tear down function for mockResponse method */ protected function tearDown(): void { parent::tearDown(); unset($GLOBALS['lang']); unset(Config::getInstance()->selectedServer['SessionTimeZone']); Context::load(); } public function testUniqueness(): void { DatabaseInterface::$instance = null; $instanceOne = DatabaseInterface::getInstance(); $instanceTwo = DatabaseInterface::getInstance(); self::assertSame($instanceOne, $instanceTwo); } /** * Tests for DBI::getCurrentUser() method. * * @param string[][]|false $value value * @param string $string string * @param mixed[] $expected expected result * @param bool $needsSecondCall The test will need to call another time the DB * @psalm-param list<non-empty-list<string>>|false $value */ #[DataProvider('currentUserData')] public function testGetCurrentUser(array|false $value, string $string, array $expected, bool $needsSecondCall): void { $dummyDbi = $this->createDbiDummy(); $dbi = $this->createDatabaseInterface($dummyDbi); SessionCache::remove('mysql_cur_user'); $dummyDbi->addResult('SELECT CURRENT_USER();', $value); if ($needsSecondCall) { $dummyDbi->addResult('SELECT CURRENT_USER();', $value); } self::assertSame($expected, $dbi->getCurrentUserAndHost()); self::assertSame($string, $dbi->getCurrentUser()); $dummyDbi->assertAllQueriesConsumed(); } /** * Data provider for getCurrentUser() tests. * * @return mixed[] */ public static function currentUserData(): array { return [ [[['pma@localhost']], 'pma@localhost', ['pma', 'localhost'], false], [[['@localhost']], '@localhost', ['', 'localhost'], false], [false, '@', ['', ''], true], ]; } /** * Tests for DBI::getCurrentRole() method. * * @param string[][]|false $value * @param string[] $string * @param string[][] $expected */ #[DataProvider('currentRolesData')] public function testGetCurrentRoles( string $version, bool $isRoleSupported, array|false $value, array $string, array $expected, ): void { $dbiDummy = $this->createDbiDummy(); $dbi = $this->createDatabaseInterface($dbiDummy); $dbi->setVersion(['@@version' => $version]); SessionCache::remove('mysql_cur_role'); if ($isRoleSupported) { $dbiDummy->addResult('SELECT CURRENT_ROLE();', $value); } self::assertSame($expected, $dbi->getCurrentRolesAndHost()); self::assertSame($string, $dbi->getCurrentRoles()); $dbiDummy->assertAllQueriesConsumed(); } /** * Data provider for getCurrentRole() tests. * * @return mixed[] */ public static function currentRolesData(): array { return [ ['10.4.99-MariaDB', false, false, [], []], ['5.7.35 - MySQL Community Server (GPL)', false, false, [], []], [ '8.0.0 - MySQL Community Server - GPL', true, [['`role`@`localhost`']], ['role@localhost'], [['role', 'localhost']], ], [ '8.0.0 - MySQL Community Server - GPL', true, [['`role`@`localhost`, `role2`@`localhost`']], ['role@localhost', 'role2@localhost'], [['role', 'localhost'], ['role2', 'localhost']], ], ['8.0.0 - MySQL Community Server - GPL', true, [['@`localhost`']], ['@localhost'], [['', 'localhost']]], ['10.5.0-MariaDB', true, [['`role`@`localhost`']], ['role@localhost'], [['role', 'localhost']]], [ '10.5.0-MariaDB', true, [['`role`@`localhost`, `role2`@`localhost`']], ['role@localhost', 'role2@localhost'], [['role', 'localhost'], ['role2', 'localhost']], ], ['10.5.0-MariaDB', true, [['@`localhost`']], ['@localhost'], [['', 'localhost']]], ]; } /** * Tests for DBI::postConnect() method. * should not call setVersion method if cannot fetch version */ public function testPostConnectShouldNotCallSetVersionIfNoVersion(): void { $GLOBALS['lang'] = 'en'; LanguageManager::getInstance()->availableLanguages(); $mock = $this->getMockBuilder(DatabaseInterface::class) ->disableOriginalConstructor() ->onlyMethods(['fetchSingleRow', 'query', 'setVersion']) ->getMock(); $mock->expects(self::once()) ->method('fetchSingleRow') ->willReturn(null); $mock->expects(self::never())->method('setVersion'); $mock->postConnect(new Server(['SessionTimeZone' => ''])); } /** * Tests for DBI::postConnect() method. * should call setVersion method if $version has value */ public function testPostConnectShouldCallSetVersionOnce(): void { $GLOBALS['lang'] = 'en'; $versionQueryResult = [ '@@version' => '10.20.7-MariaDB-1:10.9.3+maria~ubu2204', '@@version_comment' => 'mariadb.org binary distribution', ]; LanguageManager::getInstance()->availableLanguages(); $mock = $this->getMockBuilder(DatabaseInterface::class) ->disableOriginalConstructor() ->onlyMethods(['fetchSingleRow', 'query', 'setVersion']) ->getMock(); $mock->expects(self::once()) ->method('fetchSingleRow') ->willReturn($versionQueryResult); $mock->expects(self::once())->method('setVersion')->with($versionQueryResult); $mock->postConnect(new Server(['SessionTimeZone' => ''])); } /** * Tests for DBI::postConnect() method. * should set version int, isMariaDB and isPercona * * @param array $version Database version * @param int $versionInt Database version as integer * @param bool $isMariaDb True if mariadb * @param bool $isPercona True if percona * @phpstan-param array<array-key, mixed> $version */ #[DataProvider('provideDatabaseVersionData')] public function testPostConnectShouldSetVersion( array $version, int $versionInt, bool $isMariaDb, bool $isPercona, ): void { $GLOBALS['lang'] = 'en'; LanguageManager::getInstance()->availableLanguages(); $mock = $this->getMockBuilder(DatabaseInterface::class) ->disableOriginalConstructor() ->onlyMethods(['fetchSingleRow', 'query']) ->getMock(); $mock->expects(self::once()) ->method('fetchSingleRow') ->willReturn($version); $mock->postConnect(new Server(['SessionTimeZone' => ''])); self::assertSame($mock->getVersion(), $versionInt); self::assertSame($mock->isMariaDB(), $isMariaDb); self::assertSame($mock->isPercona(), $isPercona); } /** * Test for getDbCollation */ public function testGetDbCollation(): void { $dbiDummy = $this->createDbiDummy(); $dbi = $this->createDatabaseInterface($dbiDummy); $config = Config::getInstance(); $config->selectedServer['DisableIS'] = false; self::assertSame( 'utf8_general_ci', $dbi->getDbCollation('pma_test'), ); $config->selectedServer['DisableIS'] = true; $dbiDummy->addSelectDb('information_schema'); Current::$database = 'information_schema'; $dbiDummy->removeDefaultResults(); $dbiDummy->addResult('SELECT @@collation_database', [['utf8mb3_general_ci']], ['@@collation_database']); self::assertSame('utf8mb3_general_ci', $dbi->getDbCollation('information_schema')); } /** * Test for getServerCollation */ public function testGetServerCollation(): void { $dbi = $this->createDatabaseInterface(); $config = Config::getInstance(); $config->config->debug->sql = true; self::assertSame('utf8_general_ci', $dbi->getServerCollation()); $config->config->debug->sql = false; } /** * Test error formatting * * @param int $errorNumber Error code * @param string $errorMessage Error message as returned by server * @param string $match Expected text */ #[DataProvider('errorData')] public function testFormatError(int $errorNumber, string $errorMessage, string $match): void { self::assertStringContainsString( $match, Utilities::formatError($errorNumber, $errorMessage), ); } /** @return mixed[][] */ public static function errorData(): array { return [ [2002, 'msg', 'The server is not responding'], [2003, 'msg', 'The server is not responding'], [1698, 'msg', 'index.php?route=/logout'], [1005, 'msg', 'index.php?route=/server/engines'], [1005, 'errno: 13', 'Please check privileges'], [-1, 'error message', 'error message'], ]; } /** * Tests for DBI::isAmazonRds() method. * * @param string[][] $value value * @param bool $expected expected result * @psalm-param list<non-empty-list<string>> $value */ #[DataProvider('isAmazonRdsData')] public function testIsAmazonRdsData(array $value, bool $expected): void { $dummyDbi = $this->createDbiDummy(); $dbi = $this->createDatabaseInterface($dummyDbi); SessionCache::remove('is_amazon_rds'); $dummyDbi->addResult('SELECT @@basedir', $value); self::assertSame( $expected, $dbi->isAmazonRds(), ); $dummyDbi->assertAllQueriesConsumed(); } /** * Data provider for isAmazonRds() tests. * * @return mixed[] */ public static function isAmazonRdsData(): array { return [ [[['/usr']], false], [[['E:/mysql']], false], [[['/rdsdbbin/mysql/']], true], [[['/rdsdbbin/mysql-5.7.18/']], true], ]; } /** * Test for version parsing * * @param string $version version to parse * @param int $expected expected numeric version * @param int $major expected major version * @param bool $upgrade whether upgrade should ne needed */ #[DataProvider('versionData')] public function testVersion(string $version, int $expected, int $major, bool $upgrade): void { $verInt = Utilities::versionToInt($version); self::assertSame($expected, $verInt); self::assertSame($major, (int) ($verInt / 10000)); $mysqlMinVersion = 50500; self::assertSame($upgrade, $verInt < $mysqlMinVersion); } /** @return mixed[][] */ public static function versionData(): array { return [ ['5.0.5', 50005, 5, true], ['5.05.01', 50501, 5, false], ['5.6.35', 50635, 5, false], ['10.1.22-MariaDB-', 100122, 10, false], ]; } /** * Tests for DBI::setCollation() method. */ public function testSetCollation(): void { $dummyDbi = $this->createDbiDummy(); $dbi = $this->createDatabaseInterface($dummyDbi); $dummyDbi->addResult('SET collation_connection = \'utf8_czech_ci\';', true); $dummyDbi->addResult('SET collation_connection = \'utf8mb4_bin_ci\';', true); $dummyDbi->addResult('SET collation_connection = \'utf8_czech_ci\';', true); $dummyDbi->addResult('SET collation_connection = \'utf8_bin_ci\';', true); (new ReflectionProperty(DatabaseInterface::class, 'versionInt'))->setValue($dbi, 50504); $dbi->setCollation('utf8_czech_ci'); $dbi->setCollation('utf8mb4_bin_ci'); (new ReflectionProperty(DatabaseInterface::class, 'versionInt'))->setValue($dbi, 50503); $dbi->setCollation('utf8_czech_ci'); $dbi->setCollation('utf8mb4_bin_ci'); $dummyDbi->assertAllQueriesConsumed(); } public function testGetTablesFull(): void { $dbi = $this->createDatabaseInterface(); Config::getInstance()->selectedServer['DisableIS'] = true; $expected = [ 'test_table' => [ 'Name' => 'test_table', 'Engine' => 'InnoDB', 'Version' => '10', 'Row_format' => 'Dynamic', 'Rows' => '3', 'Avg_row_length' => '5461', 'Data_length' => '16384', 'Max_data_length' => '0', 'Index_length' => '0', 'Data_free' => '0', 'Auto_increment' => '4', 'Create_time' => '2011-12-13 14:15:16', 'Update_time' => null, 'Check_time' => null, 'Collation' => 'utf8mb4_general_ci', 'Checksum' => null, 'Create_options' => '', 'Comment' => '', 'Max_index_length' => '0', 'Temporary' => 'N', 'Type' => 'InnoDB', 'TABLE_SCHEMA' => 'test_db', 'TABLE_NAME' => 'test_table', 'ENGINE' => 'InnoDB', 'VERSION' => '10', 'ROW_FORMAT' => 'Dynamic', 'TABLE_ROWS' => '3', 'AVG_ROW_LENGTH' => '5461', 'DATA_LENGTH' => '16384', 'MAX_DATA_LENGTH' => '0', 'INDEX_LENGTH' => '0', 'DATA_FREE' => '0', 'AUTO_INCREMENT' => '4', 'CREATE_TIME' => '2011-12-13 14:15:16', 'UPDATE_TIME' => null, 'CHECK_TIME' => null, 'TABLE_COLLATION' => 'utf8mb4_general_ci', 'CHECKSUM' => null, 'CREATE_OPTIONS' => '', 'TABLE_COMMENT' => '', 'TABLE_TYPE' => 'BASE TABLE', ], ]; $actual = $dbi->getTablesFull('test_db'); self::assertSame($expected, $actual); } public function testGetTablesFullWithInformationSchema(): void { $dbi = $this->createDatabaseInterface(); Config::getInstance()->selectedServer['DisableIS'] = false; $expected = [ 'test_table' => [ 'TABLE_CATALOG' => 'def', 'TABLE_SCHEMA' => 'test_db', 'TABLE_NAME' => 'test_table', 'TABLE_TYPE' => 'BASE TABLE', 'ENGINE' => 'InnoDB', 'VERSION' => '10', 'ROW_FORMAT' => 'Dynamic', 'TABLE_ROWS' => '3', 'AVG_ROW_LENGTH' => '5461', 'DATA_LENGTH' => '16384', 'MAX_DATA_LENGTH' => '0', 'INDEX_LENGTH' => '0', 'DATA_FREE' => '0', 'AUTO_INCREMENT' => '4', 'CREATE_TIME' => '2011-12-13 14:15:16', 'UPDATE_TIME' => null, 'CHECK_TIME' => null, 'TABLE_COLLATION' => 'utf8mb4_general_ci', 'CHECKSUM' => null, 'CREATE_OPTIONS' => '', 'TABLE_COMMENT' => '', 'MAX_INDEX_LENGTH' => '0', 'TEMPORARY' => 'N', 'Db' => 'test_db', 'Name' => 'test_table', 'Engine' => 'InnoDB', 'Type' => 'InnoDB', 'Version' => '10', 'Row_format' => 'Dynamic', 'Rows' => '3', 'Avg_row_length' => '5461', 'Data_length' => '16384', 'Max_data_length' => '0', 'Index_length' => '0', 'Data_free' => '0', 'Auto_increment' => '4', 'Create_time' => '2011-12-13 14:15:16', 'Update_time' => null, 'Check_time' => null, 'Collation' => 'utf8mb4_general_ci', 'Checksum' => null, 'Create_options' => '', 'Comment' => '', ], ]; $actual = $dbi->getTablesFull('test_db'); self::assertSame($expected, $actual); } public function testGetTablesFullBug18913(): void { $dbiDummy = $this->createDbiDummy(); $dbi = $this->createDatabaseInterface($dbiDummy); $config = Config::getInstance(); $config->selectedServer['DisableIS'] = true; $config->settings['NaturalOrder'] = false; $expected = ['0', '1', '42']; $dbiDummy->addResult('SHOW TABLE STATUS FROM `test_db_bug_18913`', [ ['0', ''], ['1', ''], ['42', ''], ], ['Name', 'Engine']); $actual = $dbi->getTablesFull('test_db_bug_18913'); self::assertEquals($expected, array_keys($actual)); } /** * Test for queryAsControlUser */ public function testQueryAsControlUser(): void { $dummyDbi = $this->createDbiDummy(); $dbi = $this->createDatabaseInterface($dummyDbi); $sql = 'insert into PMA_bookmark A,B values(1, 2)'; $dummyDbi->addResult($sql, true); $dummyDbi->addResult($sql, true); $dummyDbi->addResult('Invalid query', false); $dbi->queryAsControlUser($sql); self::assertInstanceOf( ResultInterface::class, $dbi->tryQueryAsControlUser($sql), ); self::assertFalse($dbi->tryQueryAsControlUser('Invalid query')); } public function testGetDatabasesFullDisabledISAndSortIntColumn(): void { $dummyDbi = $this->createDbiDummy(); $dbi = $this->createDatabaseInterface($dummyDbi); DatabaseInterface::$instance = $dbi; Current::$database = ''; Current::$table = ''; $config = Config::getInstance(); $config->selectedServer['DisableIS'] = true; $config->selectedServer['only_db'] = ''; $config->settings['NaturalOrder'] = true; $dummyDbi->removeDefaultResults(); $dummyDbi->addResult('SELECT CURRENT_USER();', []); $dummyDbi->addResult('SHOW DATABASES', [['db1'], ['db2']], ['Database']); $dummyDbi->addResult( 'SELECT @@collation_database', [['utf8_general_ci']], ['@@collation_database'], ); $dummyDbi->addResult( 'SELECT @@collation_database', [['utf8_general_ci']], ['@@collation_database'], ); $dummyDbi->addResult( 'SHOW TABLE STATUS FROM `db1`;', [ [ 'pma__bookmark', 'InnoDB', 10, 'Dynamic', 0, 0, 16384, 0, 0, 0, 1, '2021-08-27 14:11:52', null, null, 'utf8_bin', null, 'Bookmarks', ], [ 'pma__central_columns', 'InnoDB', 10, 'Dynamic', 0, 0, 16384, 0, 0, 0, null, '2021-08-27 14:11:52', null, null, 'utf8_bin', null, 'Central list of columns', ], ], [ 'Name', 'Engine', 'Version', 'Row_format', 'Rows', 'Avg_row_length', 'Data_length', 'Max_data_length', 'Index_length', 'Data_free', 'Auto_increment', 'Create_time', 'Update_time', 'Check_time', 'Collation', 'Checksum', 'Create_options', 'Comment', ], ); $dummyDbi->addResult( 'SHOW TABLE STATUS FROM `db2`;', [ [ 'pma__bookmark', 'InnoDB', 10, 'Dynamic', 0, 0, 16324, 0, 0, 0, 1, '2021-08-27 14:11:52', null, null, 'utf8_bin', null, 'Bookmarks', ], [ 'pma__central_columns', 'InnoDB', 10, 'Dynamic', 0, 0, 14384, 0, 0, 0, null, '2021-08-27 14:11:52', null, null, 'utf8_bin', null, 'Central list of columns', ], ], [ 'Name', 'Engine', 'Version', 'Row_format', 'Rows', 'Avg_row_length', 'Data_length', 'Max_data_length', 'Index_length', 'Data_free', 'Auto_increment', 'Create_time', 'Update_time', 'Check_time', 'Collation', 'Checksum', 'Create_options', 'Comment', ], ); $dummyDbi->addSelectDb(''); $dummyDbi->addSelectDb(''); $dummyDbi->addSelectDb('db1'); $dummyDbi->addSelectDb('db2'); $databaseList = $dbi->getDatabasesFull(null, true, ConnectionType::User, 'SCHEMA_DATA_LENGTH', 'ASC', 0, 100); self::assertSame([ [ 'SCHEMA_NAME' => 'db2', 'DEFAULT_COLLATION_NAME' => 'utf8_general_ci', 'SCHEMA_TABLES' => 2, 'SCHEMA_TABLE_ROWS' => 0, 'SCHEMA_DATA_LENGTH' => 30708, 'SCHEMA_MAX_DATA_LENGTH' => 0, 'SCHEMA_INDEX_LENGTH' => 0, 'SCHEMA_LENGTH' => 30708, 'SCHEMA_DATA_FREE' => 0, ], [ 'SCHEMA_NAME' => 'db1', 'DEFAULT_COLLATION_NAME' => 'utf8_general_ci', 'SCHEMA_TABLES' => 2, 'SCHEMA_TABLE_ROWS' => 0, 'SCHEMA_DATA_LENGTH' => 32768, 'SCHEMA_MAX_DATA_LENGTH' => 0, 'SCHEMA_INDEX_LENGTH' => 0, 'SCHEMA_LENGTH' => 32768, 'SCHEMA_DATA_FREE' => 0, ], ], $databaseList); $dummyDbi->assertAllQueriesConsumed(); } public function testPrepare(): void { $query = 'SELECT * FROM `mysql`.`user` WHERE `User` = ? AND `Host` = ?;'; $stmtStub = self::createStub(Statement::class); $dummyDbi = $this->createMock(DbiExtension::class); $dummyDbi->expects(self::once())->method('prepare') ->with(self::isType('object'), self::equalTo($query)) ->willReturn($stmtStub); $dbi = $this->createDatabaseInterface($dummyDbi); $stmt = $dbi->prepare($query, ConnectionType::ControlUser); self::assertSame($stmtStub, $stmt); } /** * Tests for setVersion method. * * @param array $version Database version * @param int $versionInt Database version as integer * @param bool $isMariaDb True if mariadb * @param bool $isPercona True if percona * @phpstan-param array<array-key, mixed> $version */ #[DataProvider('provideDatabaseVersionData')] public function testSetVersion( array $version, int $versionInt, bool $isMariaDb, bool $isPercona, ): void { $dummyDbi = $this->createDbiDummy(); $dbi = $this->createDatabaseInterface($dummyDbi); $dbi->setVersion($version); self::assertSame($versionInt, $dbi->getVersion()); self::assertSame($isMariaDb, $dbi->isMariaDB()); self::assertSame($isPercona, $dbi->isPercona()); self::assertSame($version['@@version'], $dbi->getVersionString()); } /** * Data provider for setVersion() tests. * * @return mixed[] * @psalm-return array<int, array{array<array-key, mixed>, int, bool, bool}> */ public static function provideDatabaseVersionData(): array { return [ [ [ '@@version' => '6.1.0', '@@version_comment' => "Percona Server (GPL), Release '11', Revision 'c1y2gr1df4a'", ], 60100, false, true, ], [ [ '@@version' => '10.01.40-MariaDB-1:10.01.40+maria~ubu2204', '@@version_comment' => 'mariadb.org binary distribution', ], 100140, true, false, ], [['@@version' => '7.10.3', '@@version_comment' => 'MySQL Community Server (GPL)'], 71003, false, false], [['@@version' => '5.5.0', '@@version_comment' => ''], 50500, false, false], ]; } #[DataProvider('providerForTestGetLowerCaseNames')] public function testGetLowerCaseNames(string|false|null $result, int $expected): void { $dbiDummy = $this->createDbiDummy(); $expectedResult = $result !== false ? [[$result]] : []; $dbiDummy->addResult('SELECT @@lower_case_table_names', $expectedResult, ['@@lower_case_table_names']); $dbi = $this->createDatabaseInterface($dbiDummy); self::assertSame($expected, $dbi->getLowerCaseNames()); $dbiDummy->assertAllQueriesConsumed(); } /** @return iterable<string, array{string|false|null, int}> */ public static function providerForTestGetLowerCaseNames(): iterable { yield 'string 0' => ['0', 0]; yield 'string 1' => ['1', 1]; yield 'string 2' => ['2', 2]; yield 'invalid lower value' => ['-1', 0]; yield 'invalid higher value' => ['3', 0]; yield 'empty string' => ['', 0]; yield 'null' => [null, 0]; yield 'false' => [false, 0]; } public function testGetColumn(): void { (new ReflectionProperty(Index::class, 'registry'))->setValue(null, []); $dbiDummy = $this->createDbiDummy(); $dbiDummy->removeDefaultResults(); $dbiDummy->addResult( 'SHOW COLUMNS FROM `test_db`.`test_table` LIKE \'test\\\\_column\'', [['test_column', 'varchar(45)', 'NO', '', null, '']], ['Field', 'Type', 'Null', 'Key', 'Default', 'Extra'], ); $dbiDummy->addResult('SHOW INDEXES FROM `test_db`.`test_table`', []); $dbi = $this->createDatabaseInterface($dbiDummy); $column = new Column('test_column', 'varchar(45)', false, '', null, ''); self::assertEquals($column, $dbi->getColumn('test_db', 'test_table', 'test_column')); $dbiDummy->assertAllQueriesConsumed(); } public function testGetColumnWithFullColumn(): void { (new ReflectionProperty(Index::class, 'registry'))->setValue(null, []); $dbiDummy = $this->createDbiDummy(); $dbiDummy->removeDefaultResults(); $dbiDummy->addResult( 'SHOW FULL COLUMNS FROM `test_db`.`test_table` LIKE \'test\\\\_column\'', // phpcs:ignore Generic.Files.LineLength.TooLong [['test_column', 'varchar(45)', 'utf8mb4_general_ci', 'NO', '', null, '', 'select,insert,update,references', '']], ['Field', 'Type', 'Collation', 'Null', 'Key', 'Default', 'Extra', 'Privileges', 'Comment'], ); $dbiDummy->addResult('SHOW INDEXES FROM `test_db`.`test_table`', []); $dbi = $this->createDatabaseInterface($dbiDummy); $column = new ColumnFull( 'test_column', 'varchar(45)', 'utf8mb4_general_ci', false, '', null, '', 'select,insert,update,references', '', ); self::assertEquals($column, $dbi->getColumn('test_db', 'test_table', 'test_column', true)); $dbiDummy->assertAllQueriesConsumed(); } }