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 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98
|
<?php
declare(strict_types=1);
namespace PhpMyAdmin\Tests\Controllers\Server\Status;
use PhpMyAdmin\Controllers\Server\Status\QueriesController;
use PhpMyAdmin\Server\Status\Data;
use PhpMyAdmin\Template;
use PhpMyAdmin\Tests\AbstractTestCase;
use PhpMyAdmin\Tests\Stubs\ResponseRenderer;
use PhpMyAdmin\Util;
use function __;
use function array_sum;
use function htmlspecialchars;
/**
* @covers \PhpMyAdmin\Controllers\Server\Status\QueriesController
*/
#[\PHPUnit\Framework\Attributes\CoversClass(\PhpMyAdmin\Controllers\Server\Status\QueriesController::class)]
class QueriesControllerTest extends AbstractTestCase
{
/** @var Data */
private $data;
protected function setUp(): void
{
parent::setUp();
$GLOBALS['text_dir'] = 'ltr';
parent::setGlobalConfig();
parent::setTheme();
$GLOBALS['server'] = 1;
$GLOBALS['db'] = 'db';
$GLOBALS['table'] = 'table';
$GLOBALS['PMA_PHP_SELF'] = 'index.php';
$GLOBALS['cfg']['Server']['DisableIS'] = false;
$GLOBALS['cfg']['Server']['host'] = 'localhost';
$this->data = new Data();
$this->data->status['Uptime'] = 36000;
$this->data->usedQueries = [
'Com_change_db' => '15',
'Com_select' => '12',
'Com_set_option' => '54',
'Com_show_databases' => '16',
'Com_show_status' => '14',
'Com_show_tables' => '13',
];
}
public function testIndex(): void
{
global $dbi;
$response = new ResponseRenderer();
$controller = new QueriesController($response, new Template(), $this->data, $dbi);
$this->dummyDbi->addSelectDb('mysql');
$controller();
$this->assertAllSelectsConsumed();
$html = $response->getHTMLResult();
$hourFactor = 3600 / $this->data->status['Uptime'];
$usedQueries = $this->data->usedQueries;
$totalQueries = array_sum($usedQueries);
$questionsFromStart = __('Questions since startup:')
. ' ' . Util::formatNumber($totalQueries, 0);
self::assertStringContainsString('<h3 id="serverstatusqueries">', $html);
self::assertStringContainsString($questionsFromStart, $html);
self::assertStringContainsString(__('per hour:'), $html);
self::assertStringContainsString(Util::formatNumber($totalQueries * $hourFactor, 0), $html);
$valuePerMinute = Util::formatNumber($totalQueries * 60 / $this->data->status['Uptime'], 0);
self::assertStringContainsString(__('per minute:'), $html);
self::assertStringContainsString(htmlspecialchars($valuePerMinute), $html);
self::assertStringContainsString(__('Statements'), $html);
self::assertStringContainsString(htmlspecialchars('change db'), $html);
self::assertStringContainsString('54', $html);
self::assertStringContainsString(htmlspecialchars('select'), $html);
self::assertStringContainsString(htmlspecialchars('set option'), $html);
self::assertStringContainsString(htmlspecialchars('show databases'), $html);
self::assertStringContainsString(htmlspecialchars('show status'), $html);
self::assertStringContainsString(htmlspecialchars('show tables'), $html);
self::assertStringContainsString(
'<div id="serverstatusquerieschart" class="w-100 col-12 col-md-6" data-chart="',
$html
);
}
}
|