%PDF-1.5 %���� ºaâÚÎΞ-ÌE1ÍØÄ÷{òò2ÿ ÛÖ^ÔÀá TÎ{¦?§®¥kuµùÕ5sLOšuY
| Server IP : 122.154.253.140  /  Your IP : 216.73.216.49 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:/BK/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
        );
    }
}