Initial commit
This commit is contained in:
223
#pma/test/libraries/PMA_designer_test.php
Normal file
223
#pma/test/libraries/PMA_designer_test.php
Normal file
@ -0,0 +1,223 @@
|
||||
<?php
|
||||
/**
|
||||
* Tests for libraries/db_designer.lib.php
|
||||
*
|
||||
* @package PhpMyAdmin-test
|
||||
*/
|
||||
/*
|
||||
* Include to test.
|
||||
*/
|
||||
require_once 'libraries/db_designer.lib.php';
|
||||
require_once 'libraries/database_interface.inc.php';
|
||||
require_once 'libraries/url_generating.lib.php';
|
||||
require_once 'libraries/relation.lib.php';
|
||||
require_once 'libraries/plugin_interface.lib.php';
|
||||
|
||||
/**
|
||||
* Tests for libraries/db_designer.lib.php
|
||||
*
|
||||
* @package PhpMyAdmin-test
|
||||
*/
|
||||
class PMA_DesignerTest extends PHPUnit_Framework_TestCase
|
||||
{
|
||||
|
||||
/**
|
||||
* Setup for test cases
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function setup()
|
||||
{
|
||||
$GLOBALS['server'] = 1;
|
||||
$GLOBALS['cfg']['ServerDefault'] = 1;
|
||||
$GLOBALS['cfg']['PDFPageSizes'] = array('A3', 'A4');
|
||||
$GLOBALS['cfg']['PDFDefaultPageSize'] = 'A4';
|
||||
$GLOBALS['cfg']['Schema']['pdf_orientation'] = 'L';
|
||||
$GLOBALS['cfg']['Schema']['pdf_paper'] = 'A4';
|
||||
|
||||
$_SESSION = array(
|
||||
'relation' => array(
|
||||
'1' => array(
|
||||
'PMA_VERSION' => PMA_VERSION,
|
||||
'db' => 'pmadb',
|
||||
'pdf_pages' => 'pdf_pages',
|
||||
'pdfwork' => true
|
||||
)
|
||||
),
|
||||
' PMA_token ' => 'token'
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Mocks database interaction for tests.
|
||||
*
|
||||
* @param string $db database name
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
private function _mockDatabaseInteraction($db)
|
||||
{
|
||||
$dbi = $this->getMockBuilder('PMA\libraries\DatabaseInterface')
|
||||
->disableOriginalConstructor()
|
||||
->getMock();
|
||||
|
||||
$dbi->expects($this->once())
|
||||
->method('tryQuery')
|
||||
->with(
|
||||
"SELECT `page_nr`, `page_descr` FROM `pmadb`.`pdf_pages`"
|
||||
. " WHERE db_name = '" . $db . "' ORDER BY `page_descr`",
|
||||
2,
|
||||
PMA\libraries\DatabaseInterface::QUERY_STORE,
|
||||
false
|
||||
)
|
||||
->will($this->returnValue('dummyRS'));
|
||||
|
||||
$dbi->expects($this->exactly(3))
|
||||
->method('fetchAssoc')
|
||||
->willReturnOnConsecutiveCalls(
|
||||
array('page_nr' => '1', 'page_descr' => 'page1'),
|
||||
array('page_nr' => '2', 'page_descr' => 'page2'),
|
||||
false
|
||||
);
|
||||
|
||||
$dbi->expects($this->any())
|
||||
->method('escapeString')
|
||||
->will($this->returnArgument(0));
|
||||
|
||||
$GLOBALS['dbi'] = $dbi;
|
||||
}
|
||||
|
||||
/**
|
||||
* Test for PMA_getPageIdsAndNames()
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function testGetPageIdsAndNames()
|
||||
{
|
||||
$db = 'db';
|
||||
$this->_mockDatabaseInteraction($db);
|
||||
|
||||
$result = PMA_getPageIdsAndNames($db);
|
||||
|
||||
$this->assertEquals(
|
||||
array(
|
||||
'1' => 'page1',
|
||||
'2' => 'page2'
|
||||
),
|
||||
$result
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Test for PMA_getHtmlForEditOrDeletePages()
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function testGetHtmlForEditOrDeletePages()
|
||||
{
|
||||
$db = 'db';
|
||||
$operation = 'edit';
|
||||
$this->_mockDatabaseInteraction($db);
|
||||
|
||||
$result = PMA_getHtmlForEditOrDeletePages($db, $operation);
|
||||
$this->assertContains(
|
||||
'<input type="hidden" name="operation" value="' . $operation . '" />',
|
||||
$result
|
||||
);
|
||||
$this->assertContains(
|
||||
'<select name="selected_page" id="selected_page">',
|
||||
$result
|
||||
);
|
||||
$this->assertContains('<option value="0">', $result);
|
||||
$this->assertContains('<option value="1">', $result);
|
||||
$this->assertContains('page1', $result);
|
||||
$this->assertContains('<option value="2">', $result);
|
||||
$this->assertContains('page2', $result);
|
||||
}
|
||||
|
||||
/**
|
||||
* Test for PMA_getHtmlForPageSaveAs()
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function testGetHtmlForPageSaveAs()
|
||||
{
|
||||
$db = 'db';
|
||||
$this->_mockDatabaseInteraction($db);
|
||||
|
||||
$result = PMA_getHtmlForPageSaveAs($db);
|
||||
$this->assertContains(
|
||||
'<input type="hidden" name="operation" value="savePage" />',
|
||||
$result
|
||||
);
|
||||
$this->assertContains(
|
||||
'<select name="selected_page" id="selected_page">',
|
||||
$result
|
||||
);
|
||||
$this->assertContains('<option value="0">', $result);
|
||||
$this->assertContains('<option value="1">', $result);
|
||||
$this->assertContains('page1', $result);
|
||||
$this->assertContains('<option value="2">', $result);
|
||||
$this->assertContains('page2', $result);
|
||||
|
||||
$this->assertContains(
|
||||
'<input type="radio" name="save_page" id="save_page_same" value="same"'
|
||||
. ' checked="checked" />',
|
||||
$result
|
||||
);
|
||||
$this->assertContains(
|
||||
'<input type="radio" name="save_page" id="save_page_new" value="new" />',
|
||||
$result
|
||||
);
|
||||
$this->assertContains(
|
||||
'<input type="text" name="selected_value" id="selected_value" />',
|
||||
$result
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Test for PMA_getHtmlForSchemaExport()
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function testGetHtmlForSchemaExport()
|
||||
{
|
||||
$db = 'db';
|
||||
$page = 2;
|
||||
|
||||
$result = PMA_getHtmlForSchemaExport($db, $page);
|
||||
// export type
|
||||
$this->assertContains(
|
||||
'<select id="plugins" name="export_type">',
|
||||
$result
|
||||
);
|
||||
|
||||
// hidden field
|
||||
$this->assertContains(
|
||||
'<input type="hidden" name="page_number" value="' . $page . '" />',
|
||||
$result
|
||||
);
|
||||
|
||||
// orientation
|
||||
$this->assertContains(
|
||||
'<select name="pdf_orientation" id="select_pdf_orientation">',
|
||||
$result
|
||||
);
|
||||
$this->assertContains(
|
||||
'<option value="L" selected="selected">Landscape</option>',
|
||||
$result
|
||||
);
|
||||
$this->assertContains('<option value="P">Portrait</option>', $result);
|
||||
|
||||
// paper size
|
||||
$this->assertContains(
|
||||
'<select name="pdf_paper" id="select_pdf_paper">',
|
||||
$result
|
||||
);
|
||||
$this->assertContains('<option value="A3">A3</option>', $result);
|
||||
$this->assertContains(
|
||||
'<option value="A4" selected="selected">A4</option>',
|
||||
$result
|
||||
);
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user