Initial commit
This commit is contained in:
		
							
								
								
									
										239
									
								
								#pma/test/libraries/PMA_server_status_queries_test.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										239
									
								
								#pma/test/libraries/PMA_server_status_queries_test.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,239 @@ | ||||
| <?php | ||||
| /* vim: set expandtab sw=4 ts=4 sts=4: */ | ||||
| /** | ||||
|  * tests for server_status_queries.lib.php | ||||
|  * | ||||
|  * @package PhpMyAdmin-test | ||||
|  */ | ||||
|  | ||||
| /* | ||||
|  * Include to test. | ||||
|  */ | ||||
|  | ||||
| use PMA\libraries\ServerStatusData; | ||||
| use PMA\libraries\Theme; | ||||
|  | ||||
|  | ||||
| require_once 'libraries/url_generating.lib.php'; | ||||
|  | ||||
| require_once 'libraries/server_status_queries.lib.php'; | ||||
|  | ||||
| require_once 'libraries/database_interface.inc.php'; | ||||
|  | ||||
| require_once 'libraries/sanitizing.lib.php'; | ||||
| require_once 'libraries/js_escape.lib.php'; | ||||
|  | ||||
| /** | ||||
|  * class PMA_ServerStatusVariables_Test | ||||
|  * | ||||
|  * this class is for testing server_status_queries.lib.php functions | ||||
|  * | ||||
|  * @package PhpMyAdmin-test | ||||
|  */ | ||||
| class PMA_ServerStatusQueries_Test extends PHPUnit_Framework_TestCase | ||||
| { | ||||
|     /** | ||||
|      * Prepares environment for the test. | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public $ServerStatusData; | ||||
|  | ||||
|     /** | ||||
|      * Test for setUp | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function setUp() | ||||
|     { | ||||
|         //$GLOBALS | ||||
|         $GLOBALS['cfg']['MaxRows'] = 10; | ||||
|         $GLOBALS['cfg']['ServerDefault'] = "server"; | ||||
|         $GLOBALS['cfg']['RememberSorting'] = true; | ||||
|         $GLOBALS['cfg']['SQP'] = array(); | ||||
|         $GLOBALS['cfg']['MaxCharactersInDisplayedSQL'] = 1000; | ||||
|         $GLOBALS['cfg']['ShowSQL'] = true; | ||||
|         $GLOBALS['cfg']['TableNavigationLinksMode'] = 'icons'; | ||||
|         $GLOBALS['cfg']['LimitChars'] = 100; | ||||
|         $GLOBALS['cfg']['DBG']['sql'] = false; | ||||
|         $GLOBALS['cfg']['Server']['host'] = "localhost"; | ||||
|         $GLOBALS['PMA_PHP_SELF'] = PMA_getenv('PHP_SELF'); | ||||
|         $GLOBALS['replication_info']['master']['status'] = false; | ||||
|         $GLOBALS['replication_info']['slave']['status'] = false; | ||||
|  | ||||
|         $GLOBALS['table'] = "table"; | ||||
|         $GLOBALS['pmaThemeImage'] = 'image'; | ||||
|  | ||||
|         //$_SESSION | ||||
|         $_SESSION['PMA_Theme'] = Theme::load('./themes/pmahomme'); | ||||
|         $_SESSION['PMA_Theme'] = new Theme(); | ||||
|  | ||||
|         //Mock DBI | ||||
|         $dbi = $this->getMockBuilder('PMA\libraries\DatabaseInterface') | ||||
|             ->disableOriginalConstructor() | ||||
|             ->getMock(); | ||||
|  | ||||
|         //this data is needed when ServerStatusData constructs | ||||
|         $server_status = array( | ||||
|             "Aborted_clients" => "0", | ||||
|             "Aborted_connects" => "0", | ||||
|             "Com_delete_multi" => "0", | ||||
|             "Com_create_function" => "0", | ||||
|             "Com_empty_query" => "0", | ||||
|         ); | ||||
|  | ||||
|         $server_variables= array( | ||||
|             "auto_increment_increment" => "1", | ||||
|             "auto_increment_offset" => "1", | ||||
|             "automatic_sp_privileges" => "ON", | ||||
|             "back_log" => "50", | ||||
|             "big_tables" => "OFF", | ||||
|         ); | ||||
|  | ||||
|         $fetchResult = array( | ||||
|             array( | ||||
|                 "SHOW GLOBAL STATUS", | ||||
|                 0, | ||||
|                 1, | ||||
|                 null, | ||||
|                 0, | ||||
|                 $server_status | ||||
|             ), | ||||
|             array( | ||||
|                 "SHOW GLOBAL VARIABLES", | ||||
|                 0, | ||||
|                 1, | ||||
|                 null, | ||||
|                 0, | ||||
|                 $server_variables | ||||
|             ) | ||||
|         ); | ||||
|  | ||||
|         $dbi->expects($this->any())->method('fetchResult') | ||||
|             ->will($this->returnValueMap($fetchResult)); | ||||
|  | ||||
|         $GLOBALS['dbi'] = $dbi; | ||||
|         $this->ServerStatusData = new ServerStatusData(); | ||||
|         $upTime = "10h"; | ||||
|         $this->ServerStatusData->status['Uptime'] = $upTime; | ||||
|         $this->ServerStatusData->used_queries = array( | ||||
|             "Com_change_db" => "15", | ||||
|             "Com_select" => "12", | ||||
|             "Com_set_option" => "54", | ||||
|             "Com_show_databases" => "16", | ||||
|             "Com_show_status" => "14", | ||||
|             "Com_show_tables" => "13", | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Test for PMA_getHtmlForQueryStatistics | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function testPMAGetHtmlForQueryStatistics() | ||||
|     { | ||||
|         //Call the test function | ||||
|         $html = PMA_getHtmlForQueryStatistics($this->ServerStatusData); | ||||
|  | ||||
|         $hour_factor   = 3600 / $this->ServerStatusData->status['Uptime']; | ||||
|         $used_queries = $this->ServerStatusData->used_queries; | ||||
|         $total_queries = array_sum($used_queries); | ||||
|  | ||||
|         $questions_from_start = sprintf( | ||||
|             __('Questions since startup: %s'), | ||||
|             PMA\libraries\Util::formatNumber($total_queries, 0) | ||||
|         ); | ||||
|  | ||||
|         //validate 1: PMA_getHtmlForQueryStatistics | ||||
|         $this->assertContains( | ||||
|             '<h3 id="serverstatusqueries">', | ||||
|             $html | ||||
|         ); | ||||
|         $this->assertContains( | ||||
|             $questions_from_start, | ||||
|             $html | ||||
|         ); | ||||
|  | ||||
|         //validate 2: per hour | ||||
|         $this->assertContains( | ||||
|             __('per hour:'), | ||||
|             $html | ||||
|         ); | ||||
|         $this->assertContains( | ||||
|             PMA\libraries\Util::formatNumber($total_queries * $hour_factor, 0), | ||||
|             $html | ||||
|         ); | ||||
|  | ||||
|         //validate 3:per minute | ||||
|         $value_per_minute = PMA\libraries\Util::formatNumber( | ||||
|             $total_queries * 60 / $this->ServerStatusData->status['Uptime'], | ||||
|             0 | ||||
|         ); | ||||
|         $this->assertContains( | ||||
|             __('per minute:'), | ||||
|             $html | ||||
|         ); | ||||
|         $this->assertContains( | ||||
|             $value_per_minute, | ||||
|             $html | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Test for PMA_getHtmlForServerStatusQueriesDetails | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function testPMAGetHtmlForServerStatusQueriesDetails() | ||||
|     { | ||||
|         //Call the test function | ||||
|         $html = PMA_getHtmlForServerStatusQueriesDetails($this->ServerStatusData); | ||||
|  | ||||
|         //validate 1: PMA_getHtmlForServerStatusQueriesDetails | ||||
|         $this->assertContains( | ||||
|             __('Statements'), | ||||
|             $html | ||||
|         ); | ||||
|  | ||||
|         //validate 2: used queries | ||||
|         $this->assertContains( | ||||
|             htmlspecialchars("change db"), | ||||
|             $html | ||||
|         ); | ||||
|         $this->assertContains( | ||||
|             '54', | ||||
|             $html | ||||
|         ); | ||||
|         $this->assertContains( | ||||
|             htmlspecialchars("select"), | ||||
|             $html | ||||
|         ); | ||||
|         $this->assertContains( | ||||
|             htmlspecialchars("set option"), | ||||
|             $html | ||||
|         ); | ||||
|         $this->assertContains( | ||||
|             htmlspecialchars("show databases"), | ||||
|             $html | ||||
|         ); | ||||
|         $this->assertContains( | ||||
|             htmlspecialchars("show status"), | ||||
|             $html | ||||
|         ); | ||||
|         $this->assertContains( | ||||
|             htmlspecialchars("show tables"), | ||||
|             $html | ||||
|         ); | ||||
|  | ||||
|         //validate 3:serverstatusquerieschart | ||||
|         $this->assertContains( | ||||
|             '<div id="serverstatusquerieschart"></div>', | ||||
|             $html | ||||
|         ); | ||||
|         $this->assertContains( | ||||
|             '<div id="serverstatusquerieschart_data"', | ||||
|             $html | ||||
|         ); | ||||
|     } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user