1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59
|
<?php
declare(strict_types=1);
namespace PhpMyAdmin\Tests\Controllers\Server\Databases;
use PhpMyAdmin\Controllers\Server\Databases\CreateController;
use PhpMyAdmin\Template;
use PhpMyAdmin\Tests\AbstractTestCase;
use PhpMyAdmin\Tests\Stubs\ResponseRenderer;
use function __;
use function sprintf;
/**
* @covers \PhpMyAdmin\Controllers\Server\Databases\CreateController
*/
#[\PHPUnit\Framework\Attributes\CoversClass(\PhpMyAdmin\Controllers\Server\Databases\CreateController::class)]
final class CreateControllerTest extends AbstractTestCase
{
public function testCreateDatabase(): void
{
$GLOBALS['server'] = 1;
$GLOBALS['text_dir'] = 'ltr';
$GLOBALS['PMA_PHP_SELF'] = 'index.php';
$GLOBALS['cfg']['Server']['DisableIS'] = false;
$GLOBALS['db'] = 'pma_test';
$GLOBALS['table'] = '';
$response = new ResponseRenderer();
$response->setAjax(true);
$template = new Template();
$controller = new CreateController($response, $template, $this->dbi);
$_POST['new_db'] = 'test_db_error';
$controller();
$actual = $response->getJSONResult();
self::assertArrayHasKey('message', $actual);
self::assertStringContainsString('<div class="alert alert-danger" role="alert">', $actual['message']);
$response = new ResponseRenderer();
$response->setAjax(true);
$controller = new CreateController($response, $template, $this->dbi);
$_POST['new_db'] = 'test_db';
$_POST['db_collation'] = 'utf8_general_ci';
$controller();
$actual = $response->getJSONResult();
self::assertArrayHasKey('message', $actual);
self::assertStringContainsString('<div class="alert alert-success" role="alert">', $actual['message']);
self::assertStringContainsString(sprintf(__('Database %1$s has been created.'), 'test_db'), $actual['message']);
}
}
|