PMA_VERSION,
'db' => 'pmadb',
'tracking' => 'tracking',
'trackingwork' => true
);
$_SESSION['PMA_Theme'] = new Theme();
$GLOBALS['cfg']['Server']['tracking_default_statements'] = 'DELETE';
$dbi = $this->getMockBuilder('PMA\libraries\DatabaseInterface')
->disableOriginalConstructor()
->getMock();
$fetchArray = array('version' => "10");
$dbi->expects($this->any())
->method('fetchArray')
->will($this->returnValue($fetchArray));
$dbi->expects($this->any())
->method('query')
->will($this->returnValue(true));
$dbi->expects($this->any())
->method('tryQuery')
->will($this->returnValue(true));
$GLOBALS['dbi'] = $dbi;
}
/**
* Tests for PMA_filterTracking() method.
*
* @return void
* @test
*/
public function testPMAFilterTracking()
{
$data = array(
array(
"date" => "20120102",
"username"=> "username1",
"statement"=>"statement1"
),
array(
"date" => "20130102",
"username"=> "username2",
"statement"=>"statement2"
),
);
$filter_ts_from = 0;
$filter_ts_to = 999999999999;
$filter_users = array("username1");
$ret = PMA_filterTracking(
$data, $filter_ts_from, $filter_ts_to, $filter_users
);
$this->assertEquals(
'username1',
$ret[0]['username']
);
$this->assertEquals(
'statement1',
$ret[0]['statement']
);
}
/**
* Tests for PMA_getHtmlForDataDefinitionAndManipulationStatements() method.
*
* @return void
* @test
*/
public function testPMAGetHtmlForDataDefinitionAndManipulationStatements()
{
$url_query = "url_query";
$last_version = 10;
$html = PMA_getHtmlForDataDefinitionAndManipulationStatements(
$url_query, $last_version, $GLOBALS['db'], array($GLOBALS['table'])
);
$this->assertContains(
'
',
$html
);
$this->assertContains(
$url_query,
$html
);
$this->assertContains(
PMA_URL_getHiddenInputs($GLOBALS['db']),
$html
);
$item = sprintf(
__('Create version %1$s of %2$s'),
($last_version + 1),
htmlspecialchars($GLOBALS['db'] . '.' . $GLOBALS['table'])
);
$this->assertContains(
$item,
$html
);
$item = ' DELETE
';
$this->assertContains(
$item,
$html
);
$this->assertContains(
__('Create version'),
$html
);
}
/**
* Tests for PMA_getHtmlForActivateDeactivateTracking() method.
*
* @return void
* @test
*/
public function testPMAGetHtmlForActivateDeactivateTracking()
{
$url_query = "url_query";
$last_version = "10";
$html = PMA_getHtmlForActivateDeactivateTracking(
'activate', $url_query, $last_version
);
$this->assertContains(
$url_query,
$html
);
$item = sprintf(
__('Activate tracking for %s'),
htmlspecialchars($GLOBALS['db'] . '.' . $GLOBALS['table'])
);
$this->assertContains(
$item,
$html
);
$this->assertContains(
$last_version,
$html
);
$this->assertContains(
__('Activate now'),
$html
);
$html = PMA_getHtmlForActivateDeactivateTracking(
'deactivate', $url_query, $last_version
);
$this->assertContains(
$url_query,
$html
);
$item = sprintf(
__('Deactivate tracking for %s'),
htmlspecialchars($GLOBALS['db'] . '.' . $GLOBALS['table'])
);
$this->assertContains(
$item,
$html
);
$this->assertContains(
$last_version,
$html
);
$this->assertContains(
__('Deactivate now'),
$html
);
}
/**
* Tests for PMA_getTableLastVersionNumber() method.
*
* @return void
* @test
*/
public function testPMAGetTableLastVersionNumber()
{
$sql_result = "sql_result";
$last_version = PMA_getTableLastVersionNumber($sql_result);
$this->assertEquals(
"10",
$last_version
);
}
/**
* Tests for PMA_getSQLResultForSelectableTables() method.
*
* @return void
* @test
*/
public function testPMAGetSQLResultForSelectableTables()
{
$ret = PMA_getSQLResultForSelectableTables();
$this->assertEquals(
true,
$ret
);
}
/**
* Tests for PMA_getHtmlForColumns() method.
*
* @return void
* @test
*/
public function testPMAGetHtmlForColumns()
{
$columns = array(
array(
'Field'=>'Field1',
'Type'=>'Type1',
'Collation'=>'Collation1',
"Null"=>'YES',
'Extra'=>'Extra1',
'Key'=>'PRI',
'Comment'=>'Comment1'
),
array(
'Field'=>'Field2',
'Type'=>'Type2',
'Collation'=>'Collation2',
"Null"=>'No',
'Extra'=>'Extra2',
'Key'=>'Key2',
'Comment'=>'Comment2'
),
);
$html = PMA_getHtmlForColumns($columns);
$this->assertContains(
__('Column'),
$html
);
$this->assertContains(
__('Type'),
$html
);
$this->assertContains(
__('Collation'),
$html
);
$this->assertContains(
__('Default'),
$html
);
$this->assertContains(
__('Comment'),
$html
);
//column1
$item1= $columns[0];
$this->assertContains(
htmlspecialchars($item1['Field']),
$html
);
$this->assertContains(
htmlspecialchars($item1['Type']),
$html
);
$this->assertContains(
htmlspecialchars($item1['Collation']),
$html
);
$this->assertContains(
'NULL',
$html
);
$this->assertContains(
htmlspecialchars($item1['Comment']),
$html
);
//column2
$item1= $columns[1];
$this->assertContains(
htmlspecialchars($item1['Field']),
$html
);
$this->assertContains(
htmlspecialchars($item1['Type']),
$html
);
$this->assertContains(
htmlspecialchars($item1['Collation']),
$html
);
$this->assertContains(
_pgettext('None for default', 'None'),
$html
);
$this->assertContains(
htmlspecialchars($item1['Comment']),
$html
);
}
/**
* Tests for PMA_getListOfVersionsOfTable() method.
*
* @return void
* @test
*/
public function testPMAGetListOfVersionsOfTable()
{
$ret = PMA_getListOfVersionsOfTable();
$this->assertEquals(
true,
$ret
);
}
/**
* Tests for PMA_getHtmlForTableVersionDetails() method.
*
* @return void
* @test
*/
public function testPMAGetHtmlForTableVersionDetails()
{
$sql_result = true;
$last_version = "10";
$url_params = array();
$url_query = "select * from PMA";
$pmaThemeImage = "themePath/img";
$text_dir = "ltr";
$dbi_old = $GLOBALS['dbi'];
$dbi = $this->getMockBuilder('PMA\libraries\DatabaseInterface')
->disableOriginalConstructor()
->getMock();
$fetchArray = array(
'tracking_active' => 1,
'version' => "10",
'db_name' => 'db_name',
'table_name' => 'table_name',
'date_created' => 'date_created',
'date_updated' => 'date_updated'
);
$dbi->expects($this->at(0))
->method('fetchArray')
->will($this->returnValue($fetchArray));
$dbi->expects($this->at(1))
->method('fetchArray')
->will($this->returnValue($fetchArray));
$dbi->expects($this->at(2))
->method('fetchArray')
->will($this->returnValue(false));
$GLOBALS['dbi'] = $dbi;
$ret = PMA_getHtmlForTableVersionDetails(
$sql_result, $last_version, $url_params, $url_query,
$pmaThemeImage, $text_dir
);
$this->assertContains(
__('Version'),
$ret
);
$this->assertContains(
__('Created'),
$ret
);
$this->assertContains(
__('Updated'),
$ret
);
$this->assertContains(
__('Status'),
$ret
);
$this->assertContains(
__('Action'),
$ret
);
$this->assertContains(
__('Show'),
$ret
);
$this->assertContains(
$fetchArray['version'],
$ret
);
$this->assertContains(
$fetchArray['date_created'],
$ret
);
$this->assertContains(
$fetchArray['date_updated'],
$ret
);
$this->assertContains(
__('Tracking report'),
$ret
);
$this->assertContains(
__('Structure snapshot'),
$ret
);
$html = sprintf(
__('Deactivate tracking for %s'),
htmlspecialchars($GLOBALS['db'] . '.' . $GLOBALS['table'])
);
$this->assertContains(
$html,
$ret
);
//restore DBI
$GLOBALS['dbi'] = $dbi_old;
}
/**
* Tests for PMA_getHtmlForSelectableTables() method.
*
* @return void
* @test
*/
public function testPMAGetHtmlForSelectableTables()
{
$selectable_tables_sql_result = true;
$url_query = "select * from PMA";
$dbi_old = $GLOBALS['dbi'];
$dbi = $this->getMockBuilder('PMA\libraries\DatabaseInterface')
->disableOriginalConstructor()
->getMock();
$fetchArray = array(
'tracking_active' => 1,
'version' => "10",
'db_name' => 'db_name',
'table_name' => 'table_name',
'date_created' => 'date_created',
'date_updated' => 'date_updated'
);
$dbi->expects($this->at(0))
->method('fetchArray')
->will($this->returnValue($fetchArray));
$dbi->expects($this->at(1))
->method('fetchArray')
->will($this->returnValue($fetchArray));
$dbi->expects($this->at(2))
->method('fetchArray')
->will($this->returnValue(false));
$GLOBALS['dbi'] = $dbi;
$ret = PMA_getHtmlForSelectableTables(
$selectable_tables_sql_result, $url_query
);
$this->assertContains(
htmlspecialchars($fetchArray['table_name']),
$ret
);
$this->assertContains(
htmlspecialchars($fetchArray['db_name']),
$ret
);
//restore DBI
$GLOBALS['dbi'] = $dbi_old;
}
/**
* Tests for PMA_getHtmlForTrackingReport() method.
*
* @return void
* @test
*/
public function testPMAGetHtmlForTrackingReportr()
{
$_REQUEST['version'] = 10;
$_REQUEST['date_from'] = "date_from";
$_REQUEST['date_to'] = "date_to";
$_REQUEST['users'] = "users";
$_REQUEST['logtype'] = 'logtype';
$url_query = "select * from PMA";
$data = array(
'tracking'=>'tracking',
'ddlog' => array('ddlog'),
'dmlog' => array('dmlog')
);
$url_params = array();
$selection_schema = array();
$selection_data = array();
$selection_both = array();
$filter_ts_to = array();
$filter_ts_from = array();
$filter_users = array();
$html = PMA_getHtmlForTrackingReport(
$url_query, $data, $url_params,
$selection_schema, $selection_data,
$selection_both, $filter_ts_to,
$filter_ts_from, $filter_users
);
$this->assertContains(
__('Tracking report'),
$html
);
$this->assertContains(
$url_query,
$html
);
$this->assertContains(
__('Tracking statements'),
$html
);
$this->assertContains(
$data['tracking'],
$html
);
$version = '