|
| 1 | +<?php |
| 2 | + |
| 3 | +declare(strict_types=1); |
| 4 | + |
| 5 | +namespace PhpMyAdmin\Tests\Controllers; |
| 6 | + |
| 7 | +use PhpMyAdmin\Config; |
| 8 | +use PhpMyAdmin\Controllers\DatabaseController; |
| 9 | +use PhpMyAdmin\DatabaseInterface; |
| 10 | +use PhpMyAdmin\Http\Factory\ServerRequestFactory; |
| 11 | +use PhpMyAdmin\ListDatabase; |
| 12 | +use PhpMyAdmin\Template; |
| 13 | +use PhpMyAdmin\Tests\AbstractTestCase; |
| 14 | +use PhpMyAdmin\Tests\Stubs\ResponseRenderer; |
| 15 | +use PHPUnit\Framework\Attributes\CoversClass; |
| 16 | + |
| 17 | +#[CoversClass(DatabaseController::class)] |
| 18 | +class DatabaseControllerTest extends AbstractTestCase |
| 19 | +{ |
| 20 | + public function testDatabaseController(): void |
| 21 | + { |
| 22 | + $request = ServerRequestFactory::create()->createServerRequest('GET', 'http://example.com/'); |
| 23 | + |
| 24 | + $dbiDummy = $this->createDbiDummy(); |
| 25 | + $dbi = $this->createDatabaseInterface($dbiDummy); |
| 26 | + DatabaseInterface::$instance = $dbi; |
| 27 | + $dbiDummy->addResult( |
| 28 | + 'SELECT `SCHEMA_NAME` FROM `INFORMATION_SCHEMA`.`SCHEMATA`', |
| 29 | + [['test_db_1'], ['test_db_2']], |
| 30 | + ['SCHEMA_NAME'], |
| 31 | + ); |
| 32 | + |
| 33 | + $responseRenderer = new ResponseRenderer(); |
| 34 | + $controller = new DatabaseController($responseRenderer, new Template(new Config()), $dbi); |
| 35 | + $controller($request); |
| 36 | + |
| 37 | + $output = $responseRenderer->getJSONResult(); |
| 38 | + self::assertArrayHasKey('databases', $output); |
| 39 | + self::assertInstanceOf(ListDatabase::class, $output['databases']); |
| 40 | + self::assertSame(['test_db_1', 'test_db_2'], $output['databases']->getArrayCopy()); |
| 41 | + |
| 42 | + $dbiDummy->assertAllQueriesConsumed(); |
| 43 | + } |
| 44 | +} |
0 commit comments