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->exactly(3)) ->method('fetchResult') ->willReturnOnConsecutiveCalls( $result, $result, false ); $dbi->expects($this->once()) ->method('getTriggers') ->with('d<"b', 'table') ->will( $this->returnValue( array( array( 'create' => 'crt', 'name' => 'trname' ) ) ) ); $dbi->expects($this->exactly(2)) ->method('getProceduresOrFunctions') ->willReturnOnConsecutiveCalls( array( 'fn' ), array( 'pr' ) ); $dbi->expects($this->exactly(2)) ->method('getDefinition') ->willReturnOnConsecutiveCalls( 'fndef', 'prdef' ); $dbi->expects($this->once()) ->method('getTable') ->will($this->returnValue(new Table('table', 'd<"b', $dbi))); $dbi->expects($this->any())->method('escapeString') ->will($this->returnArgument(0)); $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="' . 'https://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; $dbi = $this->getMockBuilder('PMA\libraries\DatabaseInterface') ->disableOriginalConstructor() ->getMock(); $result_1 = array( array( 'DEFAULT_COLLATION_NAME' => 'utf8_general_ci', 'DEFAULT_CHARACTER_SET_NAME' => 'utf-8', ) ); $result_2 = array( 't1' => array(null, '"tbl"') ); $result_3 = array( 't2' => array(null, '"tbl"') ); $dbi->expects($this->exactly(5)) ->method('fetchResult') ->willReturnOnConsecutiveCalls( $result_1, $result_2, true, $result_3, false ); $dbi->expects($this->any()) ->method('getTable') ->will($this->returnValue(new Table('table', 'd<"b', $dbi))); $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; $GLOBALS['asfile'] = true; $GLOBALS['output_charset_conversion'] = false; $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, ''))); $GLOBALS['dbi'] = $dbi; ob_start(); $this->assertTrue( $this->object->exportData( 'db', 'taassertContains( "", $result ); $this->assertContains( "", $result ); $this->assertContains( "NULL", $result ); $this->assertContains( "<a>" . "", $result ); $this->assertContains( "NULL", $result ); $this->assertContains( "
", $result ); } }