224 lines
6.2 KiB
PHP
224 lines
6.2 KiB
PHP
<?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
|
|
);
|
|
}
|
|
}
|