421 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			421 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /* vim: set expandtab sw=4 ts=4 sts=4: */
 | |
| /**
 | |
|  * tests for PMA\libraries\plugins\export\ExportMediawiki class
 | |
|  *
 | |
|  * @package PhpMyAdmin-test
 | |
|  */
 | |
| use PMA\libraries\plugins\export\ExportMediawiki;
 | |
| 
 | |
| 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\ExportMediawiki class
 | |
|  *
 | |
|  * @package PhpMyAdmin-test
 | |
|  * @group medium
 | |
|  */
 | |
| class ExportMediawikiTest extends PMATestCase
 | |
| {
 | |
|     protected $object;
 | |
| 
 | |
|     /**
 | |
|      * Configures global environment.
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     function setup()
 | |
|     {
 | |
|         $GLOBALS['server'] = 0;
 | |
|         $GLOBALS['output_kanji_conversion'] = false;
 | |
|         $GLOBALS['output_charset_conversion'] = false;
 | |
|         $GLOBALS['buffer_needed'] = false;
 | |
|         $GLOBALS['asfile'] = true;
 | |
|         $GLOBALS['save_on_server'] = false;
 | |
|         $this->object = new ExportMediawiki();
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * tearDown for test cases
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function tearDown()
 | |
|     {
 | |
|         unset($this->object);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Test for PMA\libraries\plugins\export\ExportMediawiki::setProperties
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testSetProperties()
 | |
|     {
 | |
|         $method = new ReflectionMethod('PMA\libraries\plugins\export\ExportMediawiki', 'setProperties');
 | |
|         $method->setAccessible(true);
 | |
|         $method->invoke($this->object, null);
 | |
| 
 | |
|         $attrProperties = new ReflectionProperty('PMA\libraries\plugins\export\ExportMediawiki', 'properties');
 | |
|         $attrProperties->setAccessible(true);
 | |
|         $properties = $attrProperties->getValue($this->object);
 | |
| 
 | |
|         $this->assertInstanceOf(
 | |
|             'PMA\libraries\properties\plugins\ExportPluginProperties',
 | |
|             $properties
 | |
|         );
 | |
| 
 | |
|         $this->assertEquals(
 | |
|             'MediaWiki Table',
 | |
|             $properties->getText()
 | |
|         );
 | |
| 
 | |
|         $this->assertEquals(
 | |
|             'mediawiki',
 | |
|             $properties->getExtension()
 | |
|         );
 | |
| 
 | |
|         $this->assertEquals(
 | |
|             'text/plain',
 | |
|             $properties->getMimeType()
 | |
|         );
 | |
| 
 | |
|         $this->assertEquals(
 | |
|             'Options',
 | |
|             $properties->getOptionsText()
 | |
|         );
 | |
| 
 | |
|         $options = $properties->getOptions();
 | |
| 
 | |
|         $this->assertInstanceOf(
 | |
|             'PMA\libraries\properties\options\groups\OptionsPropertyRootGroup',
 | |
|             $options
 | |
|         );
 | |
| 
 | |
|         $this->assertEquals(
 | |
|             'Format Specific Options',
 | |
|             $options->getName()
 | |
|         );
 | |
| 
 | |
|         $generalOptionsArray = $options->getProperties();
 | |
|         $generalOptions = $generalOptionsArray[0];
 | |
| 
 | |
|         $this->assertInstanceOf(
 | |
|             'PMA\libraries\properties\options\groups\OptionsPropertyMainGroup',
 | |
|             $generalOptions
 | |
|         );
 | |
| 
 | |
|         $this->assertEquals(
 | |
|             'general_opts',
 | |
|             $generalOptions->getName()
 | |
|         );
 | |
| 
 | |
|         $this->assertEquals(
 | |
|             'Dump table',
 | |
|             $generalOptions->getText()
 | |
|         );
 | |
| 
 | |
|         $generalProperties = $generalOptions->getProperties();
 | |
| 
 | |
|         $property = array_shift($generalProperties);
 | |
| 
 | |
|         $this->assertInstanceOf(
 | |
|             'PMA\libraries\properties\options\groups\OptionsPropertySubgroup',
 | |
|             $property
 | |
|         );
 | |
| 
 | |
|         $this->assertEquals(
 | |
|             'dump_table',
 | |
|             $property->getName()
 | |
|         );
 | |
| 
 | |
|         $this->assertEquals(
 | |
|             'Dump table',
 | |
|             $property->getText()
 | |
|         );
 | |
| 
 | |
|         $sgHeader = $property->getSubGroupHeader();
 | |
| 
 | |
|         $this->assertInstanceOf(
 | |
|             'PMA\libraries\properties\options\items\RadioPropertyItem',
 | |
|             $sgHeader
 | |
|         );
 | |
| 
 | |
|         $this->assertEquals(
 | |
|             'structure_or_data',
 | |
|             $sgHeader->getName()
 | |
|         );
 | |
| 
 | |
|         $this->assertEquals(
 | |
|             array(
 | |
|                 'structure' => __('structure'),
 | |
|                 'data' => __('data'),
 | |
|                 'structure_and_data' => __('structure and data')
 | |
|             ),
 | |
|             $sgHeader->getValues()
 | |
|         );
 | |
| 
 | |
|         $property = array_shift($generalProperties);
 | |
| 
 | |
|         $this->assertInstanceOf(
 | |
|             'PMA\libraries\properties\options\items\BoolPropertyItem',
 | |
|             $property
 | |
|         );
 | |
| 
 | |
|         $this->assertEquals(
 | |
|             'caption',
 | |
|             $property->getName()
 | |
|         );
 | |
| 
 | |
|         $this->assertEquals(
 | |
|             'Export table names',
 | |
|             $property->getText()
 | |
|         );
 | |
| 
 | |
|         $property = array_shift($generalProperties);
 | |
| 
 | |
|         $this->assertInstanceOf(
 | |
|             'PMA\libraries\properties\options\items\BoolPropertyItem',
 | |
|             $property
 | |
|         );
 | |
| 
 | |
|         $this->assertEquals(
 | |
|             'headers',
 | |
|             $property->getName()
 | |
|         );
 | |
| 
 | |
|         $this->assertEquals(
 | |
|             'Export table headers',
 | |
|             $property->getText()
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Test for PMA\libraries\plugins\export\ExportMediawiki::exportHeader
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testExportHeader()
 | |
|     {
 | |
|         $this->assertTrue(
 | |
|             $this->object->exportHeader()
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Test for PMA\libraries\plugins\export\ExportMediawiki::exportFooter
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testExportFooter()
 | |
|     {
 | |
|         $this->assertTrue(
 | |
|             $this->object->exportFooter()
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Test for PMA\libraries\plugins\export\ExportMediawiki::exportDBHeader
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testExportDBHeader()
 | |
|     {
 | |
|         $this->assertTrue(
 | |
|             $this->object->exportDBHeader('testDB')
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Test for PMA\libraries\plugins\export\ExportMediawiki::exportDBFooter
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testExportDBFooter()
 | |
|     {
 | |
|         $this->assertTrue(
 | |
|             $this->object->exportDBFooter('testDB')
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Test for PMA\libraries\plugins\export\ExportMediawiki::exportDBCreate
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testExportDBCreate()
 | |
|     {
 | |
|         $this->assertTrue(
 | |
|             $this->object->exportDBCreate('testDB', 'database')
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Test for ExportMediaWiki::exportStructure
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testExportStructure()
 | |
|     {
 | |
|         $dbi = $this->getMockBuilder('PMA\libraries\DatabaseInterface')
 | |
|             ->disableOriginalConstructor()
 | |
|             ->getMock();
 | |
| 
 | |
|         $columns = array(
 | |
|             array(
 | |
|                 'Null' => 'Yes',
 | |
|                 'Field' => 'name1',
 | |
|                 'Key' => 'PRI',
 | |
|                 'Type' => 'set(abc)enum123',
 | |
|                 'Default' => '',
 | |
|                 'Extra' => ''
 | |
|             ),
 | |
|             array(
 | |
|                 'Null' => 'NO',
 | |
|                 'Field' => 'fields',
 | |
|                 'Key' => 'COMP',
 | |
|                 'Type' => '',
 | |
|                 'Default' => 'def',
 | |
|                 'Extra' => 'ext'
 | |
|             )
 | |
|         );
 | |
| 
 | |
|         $dbi->expects($this->at(0))
 | |
|             ->method('getColumns')
 | |
|             ->with('db', 'table')
 | |
|             ->will($this->returnValue($columns));
 | |
| 
 | |
|         $GLOBALS['dbi'] = $dbi;
 | |
|         $GLOBALS['mediawiki_caption'] = true;
 | |
|         $GLOBALS['mediawiki_headers'] = true;
 | |
| 
 | |
|         ob_start();
 | |
|         $this->assertTrue(
 | |
|             $this->object->exportStructure(
 | |
|                 'db', 'table', "\n", "example.com", "create_table", "test"
 | |
|             )
 | |
|         );
 | |
|         $result = ob_get_clean();
 | |
| 
 | |
|         $this->assertEquals(
 | |
|             "\n<!--\n" .
 | |
|             "Table structure for `table`\n" .
 | |
|             "-->\n" .
 | |
|             "\n" .
 | |
|             "{| class=\"wikitable\" style=\"text-align:center;\"\n" .
 | |
|             "|+'''table'''\n" .
 | |
|             "|- style=\"background:#ffdead;\"\n" .
 | |
|             "! style=\"background:#ffffff\" | \n" .
 | |
|             " | name1\n" .
 | |
|             " | fields\n" .
 | |
|             "|-\n" .
 | |
|             "! Type\n" .
 | |
|             " | set(abc)enum123\n" .
 | |
|             " | \n" .
 | |
|             "|-\n" .
 | |
|             "! Null\n" .
 | |
|             " | Yes\n" .
 | |
|             " | NO\n" .
 | |
|             "|-\n" .
 | |
|             "! Default\n" .
 | |
|             " | \n" .
 | |
|             " | def\n" .
 | |
|             "|-\n" .
 | |
|             "! Extra\n" .
 | |
|             " | \n" .
 | |
|             " | ext\n" .
 | |
|             "|}\n\n",
 | |
|             $result
 | |
|         );
 | |
| 
 | |
|         /**
 | |
|          * This case produces an error, should it be tested?
 | |
| 
 | |
|         ob_start();
 | |
|         $this->assertTrue(
 | |
|             $this->object->exportStructure(
 | |
|                 'db', 'table', "\n", "example.com", "defaultTest", "test"
 | |
|             )
 | |
|         );
 | |
|         $result = ob_get_clean();
 | |
|         */
 | |
|     }
 | |
|     /**
 | |
|      * Test for PMA\libraries\plugins\export\ExportMediawiki::exportData
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testExportData()
 | |
|     {
 | |
|         $dbi = $this->getMockBuilder('PMA\libraries\DatabaseInterface')
 | |
|             ->disableOriginalConstructor()
 | |
|             ->getMock();
 | |
| 
 | |
|         $dbi->expects($this->once())
 | |
|             ->method('getColumnNames')
 | |
|             ->with('db', 'table')
 | |
|             ->will($this->returnValue(array('name1', 'fields')));
 | |
| 
 | |
|         $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(2));
 | |
| 
 | |
|         $dbi->expects($this->at(3))
 | |
|             ->method('fetchRow')
 | |
|             ->with(true)
 | |
|             ->will($this->returnValue(array('r1', 'r2')));
 | |
| 
 | |
|         $dbi->expects($this->at(4))
 | |
|             ->method('fetchRow')
 | |
|             ->with(true)
 | |
|             ->will($this->returnValue(array('r3', '')));
 | |
| 
 | |
|         $dbi->expects($this->at(4))
 | |
|             ->method('fetchRow')
 | |
|             ->with(true)
 | |
|             ->will($this->returnValue(null));
 | |
| 
 | |
|         $GLOBALS['dbi'] = $dbi;
 | |
|         $GLOBALS['mediawiki_caption'] = true;
 | |
|         $GLOBALS['mediawiki_headers'] = true;
 | |
| 
 | |
|         ob_start();
 | |
|         $this->assertTrue(
 | |
|             $this->object->exportData(
 | |
|                 'db', 'table', "\n", "example.com", "SELECT"
 | |
|             )
 | |
|         );
 | |
|         $result = ob_get_clean();
 | |
| 
 | |
|         $this->assertEquals(
 | |
|             "\n<!--\n" .
 | |
|             "Table data for `table`\n" .
 | |
|             "-->\n" .
 | |
|             "\n" .
 | |
|             "{| class=\"wikitable sortable\" style=\"text-align:" .
 | |
|             "center;\"\n" .
 | |
|             "|+'''table'''\n" .
 | |
|             "|-\n" .
 | |
|             " ! name1\n" .
 | |
|             " ! fields\n" .
 | |
|             "|-\n" .
 | |
|             " | r1\n" .
 | |
|             " | r2\n" .
 | |
|             "|-\n" .
 | |
|             " | r3\n" .
 | |
|             " | \n" .
 | |
|             "|}\n\n",
 | |
|             $result
 | |
|         );
 | |
|     }
 | |
| }
 |