Leitgedanken/#pma/test/libraries/PMA_mult_submits_test.php
2022-11-21 09:47:28 +01:00

369 lines
9.3 KiB
PHP

<?php
/* vim: set expandtab sw=4 ts=4 sts=4: */
/**
* tests for mult_submits.lib.php
*
* @package PhpMyAdmin-test
*/
/*
* Include to test.
*/
use PMA\libraries\Theme;
require_once 'libraries/url_generating.lib.php';
require_once 'libraries/mult_submits.lib.php';
require_once 'libraries/database_interface.inc.php';
require_once 'libraries/sanitizing.lib.php';
require_once 'libraries/js_escape.lib.php';
require_once 'libraries/relation_cleanup.lib.php';
require_once 'libraries/relation.lib.php';
require_once 'libraries/sql.lib.php';
/**
* class PMA_MultSubmits_Test
*
* this class is for testing mult_submits.lib.php functions
*
* @package PhpMyAdmin-test
*/
class PMA_MultSubmits_Test extends PHPUnit_Framework_TestCase
{
/**
* 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']['Server']['DisableIS'] = false;
$GLOBALS['server'] = 0;
$GLOBALS['cfg']['ActionLinksMode'] = "both";
$GLOBALS['pmaThemeImage'] = 'image';
//_SESSION
$_SESSION['relation'][$GLOBALS['server']] = array(
'PMA_VERSION' => PMA_VERSION,
'table_coords' => "table_name",
'displaywork' => 'displaywork',
'db' => "information_schema",
'table_info' => 'table_info',
'relwork' => 'relwork',
'commwork' => 'commwork',
'pdfwork' => 'pdfwork',
'column_info' => 'column_info',
'relation' => 'relation',
);
//$_SESSION
$_SESSION['PMA_Theme'] = Theme::load('./themes/pmahomme');
$_SESSION['PMA_Theme'] = new Theme();
//Mock DBI
$dbi = $this->getMockBuilder('PMA\libraries\DatabaseInterface')
->disableOriginalConstructor()
->getMock();
$dbi->expects($this->any())
->method('query')
->will($this->returnValue(true));
$GLOBALS['dbi'] = $dbi;
}
/**
* Test for PMA_getHtmlForReplacePrefixTable
*
* @return void
*/
public function testPMAGetHtmlForReplacePrefixTable()
{
$action = 'delete_row';
$_url_params = array('url_query'=>'PMA_original_url_query');
//Call the test function
$html = PMA_getHtmlForReplacePrefixTable($action, $_url_params);
//form action
$this->assertContains(
'<form id="ajax_form" action="delete_row" method="post">',
$html
);
//$PMA_URL_getHiddenInputs
$this->assertContains(
PMA_URL_getHiddenInputs($_url_params),
$html
);
//from_prefix
$this->assertContains(
'<input type="text" name="from_prefix" id="initialPrefix" />',
$html
);
}
/**
* Test for PMA_getHtmlForAddPrefixTable
*
* @return void
*/
public function testPMAGetHtmlForAddPrefixTable()
{
$action = 'delete_row';
$_url_params = array('url_query'=>'PMA_original_url_query');
//Call the test function
$html = PMA_getHtmlForAddPrefixTable($action, $_url_params);
//form action
$this->assertContains(
'<form id="ajax_form" action="' . $action . '" method="post">',
$html
);
//$_url_params
$this->assertContains(
PMA_URL_getHiddenInputs($_url_params),
$html
);
//from_prefix
$this->assertContains(
__('Add prefix'),
$html
);
}
/**
* Test for PMA_getHtmlForOtherActions
*
* @return void
*/
public function testPMAGetHtmlForOtherActions()
{
$what = 'replace_prefix_tbl';
$action = 'delete_row';
$_url_params = array('url_query'=>'PMA_original_url_query');
$full_query = 'select column from PMA_table';
//Call the test function
$html = PMA_getHtmlForOtherActions(
$what, $action, $_url_params, $full_query
);
//validate 1: form action
$this->assertContains(
'<form action="' . $action . '" method="post">',
$html
);
//validate 2: $_url_params
$this->assertContains(
PMA_URL_getHiddenInputs($_url_params),
$html
);
//validate 3: conform
$this->assertContains(
__('Do you really want to execute the following query?'),
$html
);
//validate 4: query
$this->assertContains(
'<code>' . $full_query . '</code>',
$html
);
//validate 5: button : yes or no
$this->assertContains(
__('Yes'),
$html
);
$this->assertContains(
__('No'),
$html
);
}
/**
* Test for PMA_getUrlParams
*
* @return void
*/
public function testPMAGetUrlParams()
{
$what = 'row_delete';
$reload = true;
$action = 'db_delete_row';
$db = "PMA_db";
$table = "PMA_table";
$selected = array(
"index1" => "table1"
);
$views = null;
$original_sql_query = "original_sql_query";
$original_url_query = "original_url_query";
$_url_params = PMA_getUrlParams(
$what, $reload, $action, $db, $table, $selected, $views,
$original_sql_query, $original_url_query
);
$this->assertEquals(
$what,
$_url_params['query_type']
);
$this->assertEquals(
$db,
$_url_params['db']
);
$this->assertEquals(
array('DELETE FROM `PMA_table` WHERE table1 LIMIT 1;'),
$_url_params['selected']
);
$this->assertEquals(
$original_sql_query,
$_url_params['original_sql_query']
);
$this->assertEquals(
$original_url_query,
$_url_params['original_url_query']
);
}
/**
* Test for PMA_buildOrExecuteQueryForMulti
*
* @return void
*/
public function testPMABuildOrExecuteQueryForMulti()
{
$query_type = 'row_delete';
$db = "PMA_db";
$table = "PMA_table";
$selected = array(
"table1", "table2"
);
$views = null;
$primary = null;
$from_prefix = "from_prefix";
$to_prefix = "to_prefix";
$_REQUEST['pos'] = 1000;
$_SESSION['tmpval']['pos'] = 1000;
$_SESSION['tmpval']['max_rows'] = 25;
list(
$result, $rebuild_database_list, $reload_ret,
$run_parts, $execute_query_later,,
) = PMA_buildOrExecuteQueryForMulti(
$query_type, $selected, $db, $table, $views,
$primary, $from_prefix, $to_prefix
);
//validate 1: $run_parts
$this->assertEquals(
true,
$run_parts
);
//validate 2: $result
$this->assertEquals(
true,
$result
);
//validate 3: $rebuild_database_list
$this->assertEquals(
false,
$rebuild_database_list
);
//validate 4: $reload_ret
$this->assertEquals(
null,
$reload_ret
);
$query_type = 'analyze_tbl';
list(
,,,, $execute_query_later,,
) = PMA_buildOrExecuteQueryForMulti(
$query_type, $selected, $db, $table, $views,
$primary, $from_prefix, $to_prefix
);
//validate 5: $execute_query_later
$this->assertEquals(
true,
$execute_query_later
);
}
/**
* Test for PMA_getQueryFromSelected
*
* @return void
*/
public function testPMAGetQueryFromSelected()
{
$what = "drop_tbl";
$table = "PMA_table";
$selected = array(
"table1", "table2"
);
$views = array(
"table1", "table2"
);
list($full_query, $reload, $full_query_views)
= PMA_getQueryFromSelected(
$what, $table, $selected, $views
);
//validate 1: $full_query
$this->assertContains(
"DROP VIEW `table1`, `table2`",
$full_query
);
//validate 2: $reload
$this->assertEquals(
false,
$reload
);
//validate 3: $full_query_views
$this->assertEquals(
null,
$full_query_views
);
$what = "drop_db";
list($full_query, $reload, $full_query_views)
= PMA_getQueryFromSelected(
$what, $table, $selected, $views
);
//validate 1: $full_query
$this->assertContains(
"DROP DATABASE `table1`;<br />DROP DATABASE `table2`;",
$full_query
);
//validate 2: $reload
$this->assertEquals(
true,
$reload
);
}
}