%PDF-1.5 %���� ºaâÚÎΞ-ÌE1ÍØÄ÷{òò2ÿ ÛÖ^ÔÀá TÎ{¦?§®¥kuµùÕ5sLOšuY
Server IP : www.kowitt.ac.th / Your IP : 216.73.216.118 Web Server : Microsoft-IIS/7.5 System : Windows NT SERVER02 6.1 build 7601 (Windows Server 2008 R2 Standard Edition Service Pack 1) i586 User : IUSR ( 0) PHP Version : 5.6.31 Disable Function : NONE MySQL : ON | cURL : ON | WGET : OFF | Perl : OFF | Python : OFF | Sudo : OFF | Pkexec : OFF Directory : C:/inetpub/wwwroot/phpMyAdmin/test/classes/plugin/export/ |
Upload File : |
<?php /* vim: set expandtab sw=4 ts=4 sts=4: */ /** * tests for PMA\libraries\plugins\export\ExportXml class * * @package PhpMyAdmin-test */ use PMA\libraries\plugins\export\ExportXml; use PMA\libraries\Table; $GLOBALS['db'] = 'db'; require_once 'libraries/export.lib.php'; require_once 'libraries/config.default.php'; require_once 'export.php'; require_once 'test/PMATestCase.php'; /** * tests for PMA\libraries\plugins\export\ExportXml class * * @package PhpMyAdmin-test * @group medium */ class ExportXmlTest extends PMATestCase { protected $object; /** * Configures global environment. * * @return void */ function setup() { $GLOBALS['server'] = 0; $GLOBALS['output_kanji_conversion'] = false; $GLOBALS['buffer_needed'] = false; $GLOBALS['asfile'] = false; $GLOBALS['save_on_server'] = false; $GLOBALS['plugin_param'] = array(); $GLOBALS['plugin_param']['export_type'] = 'table'; $GLOBALS['plugin_param']['single_table'] = false; $GLOBALS['cfgRelation']['relation'] = true; $this->object = new ExportXml(); } /** * tearDown for test cases * * @return void */ public function tearDown() { unset($this->object); } /** * Test for PMA\libraries\plugins\export\ExportXml::setProperties * * @return void * @group medium */ public function testSetProperties() { $method = new ReflectionMethod('PMA\libraries\plugins\export\ExportXml', 'setProperties'); $method->setAccessible(true); $method->invoke($this->object, null); $attrProperties = new ReflectionProperty('PMA\libraries\plugins\export\ExportXml', 'properties'); $attrProperties->setAccessible(true); $properties = $attrProperties->getValue($this->object); $this->assertInstanceOf( 'PMA\libraries\properties\plugins\ExportPluginProperties', $properties ); $this->assertEquals( 'XML', $properties->getText() ); $this->assertEquals( 'xml', $properties->getExtension() ); $this->assertEquals( 'text/xml', $properties->getMimeType() ); $options = $properties->getOptions(); $this->assertInstanceOf( 'PMA\libraries\properties\options\groups\OptionsPropertyRootGroup', $options ); $this->assertEquals( 'Format Specific Options', $options->getName() ); $generalOptionsArray = $options->getProperties(); $generalOptions = array_shift($generalOptionsArray); $this->assertInstanceOf( 'PMA\libraries\properties\options\groups\OptionsPropertyMainGroup', $generalOptions ); $this->assertEquals( 'general_opts', $generalOptions->getName() ); $generalProperties = $generalOptions->getProperties(); $property = array_shift($generalProperties); $this->assertInstanceOf( 'PMA\libraries\properties\options\items\HiddenPropertyItem', $property ); $generalOptions = array_shift($generalOptionsArray); $this->assertInstanceOf( 'PMA\libraries\properties\options\groups\OptionsPropertyMainGroup', $generalOptions ); $this->assertEquals( 'structure', $generalOptions->getName() ); $generalProperties = $generalOptions->getProperties(); $property = array_shift($generalProperties); $this->assertInstanceOf( 'PMA\libraries\properties\options\items\BoolPropertyItem', $property ); $property = array_shift($generalProperties); $this->assertInstanceOf( 'PMA\libraries\properties\options\items\BoolPropertyItem', $property ); $property = array_shift($generalProperties); $this->assertInstanceOf( 'PMA\libraries\properties\options\items\BoolPropertyItem', $property ); $property = array_shift($generalProperties); $this->assertInstanceOf( 'PMA\libraries\properties\options\items\BoolPropertyItem', $property ); $property = array_shift($generalProperties); $this->assertInstanceOf( 'PMA\libraries\properties\options\items\BoolPropertyItem', $property ); $generalOptions = array_shift($generalOptionsArray); $this->assertInstanceOf( 'PMA\libraries\properties\options\groups\OptionsPropertyMainGroup', $generalOptions ); $this->assertEquals( 'data', $generalOptions->getName() ); $generalProperties = $generalOptions->getProperties(); $property = array_shift($generalProperties); $this->assertInstanceOf( 'PMA\libraries\properties\options\items\BoolPropertyItem', $property ); } /** * Test for PMA\libraries\plugins\export\ExportXml::exportHeader * * @return void * @group medium */ public function testExportHeader() { if (!defined("PMA_MYSQL_STR_VERSION")) { define("PMA_MYSQL_STR_VERSION", "5.0.0"); } $GLOBALS['xml_export_functions'] = 1; $GLOBALS['xml_export_contents'] = 1; $GLOBALS['output_charset_conversion'] = 1; $GLOBALS['charset'] = 'iso-8859-1'; $GLOBALS['cfg']['Server']['port'] = 80; $GLOBALS['cfg']['Server']['host'] = 'localhost'; $GLOBALS['cfg']['Server']['DisableIS'] = false; $GLOBALS['xml_export_tables'] = 1; $GLOBALS['xml_export_triggers'] = 1; $GLOBALS['xml_export_procedures'] = 1; $GLOBALS['xml_export_functions'] = 1; $GLOBALS['crlf'] = "\n"; $GLOBALS['db'] = 'd<"b'; $result = array( 0 => array( 'DEFAULT_COLLATION_NAME' => 'utf8_general_ci', 'DEFAULT_CHARACTER_SET_NAME' => 'utf-8', ), 'table' => array(null, '"tbl"') ); $dbi = $this->getMockBuilder('PMA\libraries\DatabaseInterface') ->disableOriginalConstructor() ->getMock(); $dbi->expects($this->at(0)) ->method('fetchResult') ->with( 'SELECT `DEFAULT_CHARACTER_SET_NAME`, `DEFAULT_COLLATION_NAME`' . ' FROM `information_schema`.`SCHEMATA` WHERE `SCHEMA_NAME`' . ' = \'d<"b\' LIMIT 1' ) ->will($this->returnValue($result)); $dbi->expects($this->at(1)) ->method('fetchResult') ->with( 'SHOW CREATE TABLE `d<"b`.`table`', 0 ) ->will($this->returnValue($result)); // isView $dbi->expects($this->at(2)) ->method('fetchResult') ->will($this->returnValue(false)); $dbi->expects($this->at(3)) ->method('getTriggers') ->with('d<"b', 'table') ->will( $this->returnValue( array( array( 'create' => 'crt', 'name' => 'trname' ) ) ) ); $dbi->expects($this->at(4)) ->method('getProceduresOrFunctions') ->with('d<"b', 'FUNCTION') ->will( $this->returnValue( array( 'fn' ) ) ); $dbi->expects($this->at(5)) ->method('getDefinition') ->with('d<"b', 'FUNCTION', 'fn') ->will( $this->returnValue( 'fndef' ) ); $dbi->expects($this->at(6)) ->method('getProceduresOrFunctions') ->with('d<"b', 'PROCEDURE') ->will( $this->returnValue( array( 'pr' ) ) ); $dbi->expects($this->at(7)) ->method('getDefinition') ->with('d<"b', 'PROCEDURE', 'pr') ->will( $this->returnValue( 'prdef' ) ); $dbi->expects($this->once()) ->method('getTable') ->will($this->returnValue(new Table('table', 'd<"b'))); $GLOBALS['dbi'] = $dbi; $GLOBALS['tables'] = array(); $GLOBALS['table'] = 'table'; ob_start(); $this->assertTrue( $this->object->exportHeader() ); $result = ob_get_clean(); $this->assertContains( '<pma_xml_export version="1.0" xmlns:pma="' . 'http://www.phpmyadmin.net/some_doc_url/">', $result ); $this->assertContains( '<pma:structure_schemas>' . "\n" . ' <pma:database name="d&lt;&quot;b" collat' . 'ion="utf8_general_ci" charset="utf-8">' . "\n" . ' <pma:table name="table">' . "\n" . ' &quot;tbl&quot;;' . "\n" . ' </pma:table>' . "\n" . ' <pma:trigger name="trname">' . "\n" . ' ' . "\n" . ' </pma:trigger>' . "\n" . ' <pma:function name="fn">' . "\n" . ' fndef' . "\n" . ' </pma:function>' . "\n" . ' <pma:procedure name="pr">' . "\n" . ' prdef' . "\n" . ' </pma:procedure>' . "\n" . ' </pma:database>' . "\n" . ' </pma:structure_schemas>', $result ); // case 2 with isView as true and false unset($GLOBALS['xml_export_contents']); unset($GLOBALS['xml_export_views']); unset($GLOBALS['xml_export_tables']); unset($GLOBALS['xml_export_functions']); unset($GLOBALS['xml_export_procedures']); $GLOBALS['output_charset_conversion'] = 0; $result = array( array( 'DEFAULT_COLLATION_NAME' => 'utf8_general_ci', 'DEFAULT_CHARACTER_SET_NAME' => 'utf-8', ) ); $dbi = $this->getMockBuilder('PMA\libraries\DatabaseInterface') ->disableOriginalConstructor() ->getMock(); $dbi->expects($this->at(0)) ->method('fetchResult') ->with( 'SELECT `DEFAULT_CHARACTER_SET_NAME`, `DEFAULT_COLLATION_NAME`' . ' FROM `information_schema`.`SCHEMATA` WHERE `SCHEMA_NAME`' . ' = \'d<"b\' LIMIT 1' ) ->will($this->returnValue($result)); $result = array( 't1' => array(null, '"tbl"') ); $dbi->expects($this->at(1)) ->method('fetchResult') ->with( 'SHOW CREATE TABLE `d<"b`.`t1`', 0 ) ->will($this->returnValue($result)); // isView $dbi->expects($this->at(2)) ->method('fetchResult') ->will($this->returnValue(true)); $result = array( 't2' => array(null, '"tbl"') ); $dbi->expects($this->at(3)) ->method('fetchResult') ->with( 'SHOW CREATE TABLE `d<"b`.`t2`', 0 ) ->will($this->returnValue($result)); // isView $dbi->expects($this->at(4)) ->method('fetchResult') ->will($this->returnValue(false)); $dbi->expects($this->any()) ->method('getTable') ->will($this->returnValue(new Table('table', 'd<"b'))); $GLOBALS['dbi'] = $dbi; $GLOBALS['tables'] = array('t1', 't2'); ob_start(); $this->assertTrue( $this->object->exportHeader() ); $result = ob_get_clean(); //echo $result; die; $this->assertContains( '<pma:structure_schemas>' . "\n" . ' <pma:database name="d&lt;&quot;b" collat' . 'ion="utf8_general_ci" charset="utf-8">' . "\n" . ' </pma:database>' . "\n" . ' </pma:structure_schemas>', $result ); } /** * Test for PMA\libraries\plugins\export\ExportXml::exportFooter * * @return void */ public function testExportFooter() { $this->expectOutputString( '</pma_xml_export>' ); $this->assertTrue( $this->object->exportFooter() ); } /** * Test for PMA\libraries\plugins\export\ExportXml::exportDBHeader * * @return void */ public function testExportDBHeader() { $GLOBALS['xml_export_contents'] = true; ob_start(); $this->assertTrue( $this->object->exportDBHeader('&db') ); $result = ob_get_clean(); $this->assertContains( '<database name="&amp;db">', $result ); $GLOBALS['xml_export_contents'] = false; $this->assertTrue( $this->object->exportDBHeader('&db') ); } /** * Test for PMA\libraries\plugins\export\ExportXml::exportDBFooter * * @return void */ public function testExportDBFooter() { $GLOBALS['xml_export_contents'] = true; ob_start(); $this->assertTrue( $this->object->exportDBFooter('&db') ); $result = ob_get_clean(); $this->assertContains( '</database>', $result ); $GLOBALS['xml_export_contents'] = false; $this->assertTrue( $this->object->exportDBFooter('&db') ); } /** * Test for PMA\libraries\plugins\export\ExportXml::exportDBCreate * * @return void */ public function testExportDBCreate() { $this->assertTrue( $this->object->exportDBCreate('testDB', 'database') ); } /** * Test for PMA\libraries\plugins\export\ExportXml::exportData * * @return void */ public function testExportData() { $GLOBALS['xml_export_contents'] = true; $dbi = $this->getMockBuilder('PMA\libraries\DatabaseInterface') ->disableOriginalConstructor() ->getMock(); $_table = $this->getMockBuilder('PMA\libraries\Table') ->disableOriginalConstructor() ->getMock(); $_table->expects($this->once()) ->method('isMerge') ->will($this->returnValue(false)); $dbi->expects($this->any()) ->method('getTable') ->will($this->returnValue($_table)); $dbi->expects($this->once()) ->method('getTable') ->will($this->returnValue($_table)); $dbi->expects($this->once()) ->method('query') ->with('SELECT', null, PMA\libraries\DatabaseInterface::QUERY_UNBUFFERED) ->will($this->returnValue(true)); $dbi->expects($this->once()) ->method('numFields') ->with(true) ->will($this->returnValue(3)); $dbi->expects($this->at(3)) ->method('fieldName') ->will($this->returnValue('fName1')); $dbi->expects($this->at(4)) ->method('fieldName') ->will($this->returnValue('fNa"me2')); $dbi->expects($this->at(5)) ->method('fieldName') ->will($this->returnValue('fNa\\me3')); $dbi->expects($this->at(6)) ->method('fetchRow') ->with(true) ->will($this->returnValue(array(null, '<a>'))); $GLOBALS['dbi'] = $dbi; ob_start(); $this->assertTrue( $this->object->exportData( 'db', 'ta<ble', "\n", "example.com", "SELECT" ) ); $result = ob_get_clean(); $this->assertContains( "<!-- Table ta<ble -->", $result ); $this->assertContains( "<table name="ta&lt;ble">", $result ); $this->assertContains( "<column name="fName1">NULL</column>", $result ); $this->assertContains( "<column name="fNa&quot;me2">&lt;a&gt;" . "</column>", $result ); $this->assertContains( "<column name="fName3">NULL</column>", $result ); $this->assertContains( "</table>", $result ); } }