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",
"Com_execute_sql" => 2,
"Com_stmt_execute" => 2,
);
$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
),
array(
"SELECT concat('Com_', variable_name), variable_value "
. "FROM data_dictionary.GLOBAL_STATEMENTS",
0,
1,
null,
0,
$server_status
),
);
$dbi->expects($this->at(0))
->method('tryQuery')
->with('SHOW GLOBAL STATUS')
->will($this->returnValue(true));
$dbi->expects($this->at(1))
->method('fetchRow')
->will($this->returnValue(array("Aborted_clients", "0")));
$dbi->expects($this->at(2))
->method('fetchRow')
->will($this->returnValue(array("Aborted_connects", "0")));
$dbi->expects($this->at(3))
->method('fetchRow')
->will($this->returnValue(array("Com_delete_multi", "0")));
$dbi->expects($this->at(4))
->method('fetchRow')
->will($this->returnValue(array("Com_create_function", "0")));
$dbi->expects($this->at(5))
->method('fetchRow')
->will($this->returnValue(array("Com_empty_query", "0")));
$dbi->expects($this->at(6))
->method('fetchRow')
->will($this->returnValue(false));
$dbi->expects($this->at(7))->method('freeResult');
$dbi->expects($this->any())->method('fetchResult')
->will($this->returnValueMap($fetchResult));
$GLOBALS['dbi'] = $dbi;
$this->ServerStatusData = new ServerStatusData();
}
/**
* Test for PMA_getHtmlForServerStatus
*
* @return void
* @group medium
*/
public function testPMAGetHtmlForServerStatus()
{
//parameters
$upTime = "10h";
$bytes_received = 100;
$bytes_sent = 200;
$max_used_conn = 500;
$aborted_conn = 200;
$conn = 1000;
$this->ServerStatusData->status['Uptime'] = $upTime;
$this->ServerStatusData->status['Bytes_received'] = $bytes_received;
$this->ServerStatusData->status['Bytes_sent'] = $bytes_sent;
$this->ServerStatusData->status['Max_used_connections'] = $max_used_conn;
$this->ServerStatusData->status['Aborted_connects'] = $aborted_conn;
$this->ServerStatusData->status['Connections'] = $conn;
//Call the test function
$html = PMA_getHtmlForServerStatus($this->ServerStatusData);
//validate 1: PMA_getHtmlForServerStateGeneralInfo
//traffic: $bytes_received + $bytes_sent
$traffic = $bytes_received + $bytes_sent;
$traffic_html = 'Network traffic since startup: ' . $traffic . ' B';
$this->assertContains(
$traffic_html,
$html
);
//updatetime
$upTime_html = 'This MySQL server has been running for '
. '0 days, 0 hours, 0 minutes and 10h seconds';
$this->assertContains(
$upTime_html,
$html
);
//master state
$master_html = 'This MySQL server works as master';
$this->assertContains(
$master_html,
$html
);
//validate 2: PMA_getHtmlForServerStateTraffic
$traffic_html = '
';
$this->assertContains(
$traffic_html,
$html
);
//traffic hint
$traffic_html = 'On a busy server, the byte counters may overrun';
$this->assertContains(
$traffic_html,
$html
);
//$bytes_received
$this->assertContains(
'' . $bytes_received . ' B',
$html
);
//$bytes_sent
$this->assertContains(
' | ' . $bytes_sent . ' B',
$html
);
//validate 3: PMA_getHtmlForServerStateConnections
$this->assertContains(
' | Connections | ',
$html
);
$this->assertContains(
'ø per hour | ',
$html
);
$this->assertContains(
'',
$html
);
$this->assertContains(
'Max. concurrent connections | ',
$html
);
//Max_used_connections
$this->assertContains(
'' . $max_used_conn,
$html
);
$this->assertContains(
' | Failed attempts | ',
$html
);
//Aborted_connects
$this->assertContains(
'' . $aborted_conn,
$html
);
$this->assertContains(
' | Aborted | ',
$html
);
$GLOBALS['replication_info']['master']['status'] = true;
$GLOBALS['replication_info']['slave']['status'] = true;
$this->ServerStatusData->status['Connections'] = 0;
$html = PMA_getHtmlForServerStatus($this->ServerStatusData);
$this->assertContains(
'This MySQL server works as master and slave',
$html
);
$GLOBALS['replication_info']['master']['status'] = false;
$GLOBALS['replication_info']['slave']['status'] = true;
$html = PMA_getHtmlForServerStatus($this->ServerStatusData);
$this->assertContains(
'This MySQL server works as slave',
$html
);
}
}