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 60 61
|
<?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
*/
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();
$this->assertArrayHasKey('message', $actual);
$this->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();
$this->assertArrayHasKey('message', $actual);
$this->assertStringContainsString('<div class="alert alert-success" role="alert">', $actual['message']);
$this->assertStringContainsString(
sprintf(__('Database %1$s has been created.'), 'test_db'),
$actual['message']
);
}
}
|