Viewing file: PMA_ExportHtmlword_test.php (24.96 KB) -rw-r--r-- Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php /* vim: set expandtab sw=4 ts=4 sts=4: */ /** * tests for ExportHtmlword class * * @package PhpMyAdmin-test */ require_once 'libraries/plugins/export/ExportHtmlword.class.php'; require_once 'libraries/DatabaseInterface.class.php'; require_once 'libraries/export.lib.php'; require_once 'libraries/Util.class.php'; require_once 'libraries/Theme.class.php'; require_once 'libraries/Config.class.php'; require_once 'libraries/php-gettext/gettext.inc'; require_once 'libraries/config.default.php'; require_once 'libraries/relation.lib.php'; require_once 'libraries/transformations.lib.php'; require_once 'export.php'; /** * tests for ExportHtmlword class * * @package PhpMyAdmin-test * @group medium */ class PMA_ExportHtmlword_Test extends PHPUnit_Framework_TestCase { protected $object;
/** * Configures global environment. * * @return void */ function setup() { if (!defined("PMA_DRIZZLE")) { define("PMA_DRIZZLE", false); }
$GLOBALS['server'] = 0; $this->object = new ExportHtmlword(); $GLOBALS['output_kanji_conversion'] = false; $GLOBALS['output_charset_conversion'] = false; $GLOBALS['buffer_needed'] = false; $GLOBALS['asfile'] = true; $GLOBALS['save_on_server'] = false; }
/** * tearDown for test cases * * @return void */ public function tearDown() { unset($this->object); }
/** * Test for ExportHtmlword::setProperties * * @return void */ public function testSetProperties() { $method = new ReflectionMethod('ExportHtmlword', 'setProperties'); $method->setAccessible(true); $method->invoke($this->object, null);
$attrProperties = new ReflectionProperty('ExportHtmlword', 'properties'); $attrProperties->setAccessible(true); $properties = $attrProperties->getValue($this->object);
$this->assertInstanceOf( 'ExportPluginProperties', $properties );
$this->assertEquals( 'Microsoft Word 2000', $properties->getText() );
$this->assertEquals( 'doc', $properties->getExtension() );
$this->assertEquals( 'application/vnd.ms-word', $properties->getMimeType() );
$this->assertEquals( 'Options', $properties->getOptionsText() );
$this->assertTrue( $properties->getForceFile() );
$options = $properties->getOptions();
$this->assertInstanceOf( 'OptionsPropertyRootGroup', $options );
$this->assertEquals( 'Format Specific Options', $options->getName() );
$generalOptionsArray = $options->getProperties(); $generalOptions = $generalOptionsArray[0];
$this->assertInstanceOf( 'OptionsPropertyMainGroup', $generalOptions );
$this->assertEquals( 'dump_what', $generalOptions->getName() );
$this->assertEquals( 'Dump table', $generalOptions->getText() );
$generalProperties = $generalOptions->getProperties();
$property = array_shift($generalProperties);
$this->assertInstanceOf( 'RadioPropertyItem', $property );
$this->assertEquals( 'structure_or_data', $property->getName() );
$this->assertEquals( array( 'structure' => __('structure'), 'data' => __('data'), 'structure_and_data' => __('structure and data') ), $property->getValues() );
$generalOptions = $generalOptionsArray[1];
$this->assertInstanceOf( 'OptionsPropertyMainGroup', $generalOptions );
$this->assertEquals( 'dump_what', $generalOptions->getName() );
$this->assertEquals( 'Data dump options', $generalOptions->getText() );
$this->assertEquals( 'structure', $generalOptions->getForce() );
$generalProperties = $generalOptions->getProperties();
$property = array_shift($generalProperties);
$this->assertInstanceOf( 'TextPropertyItem', $property );
$this->assertEquals( 'null', $property->getName() );
$this->assertEquals( 'Replace NULL with:', $property->getText() );
$property = array_shift($generalProperties);
$this->assertInstanceOf( 'BoolPropertyItem', $property );
$this->assertEquals( 'columns', $property->getName() );
$this->assertEquals( 'Put columns names in the first row', $property->getText() ); }
/** * Test for ExportHtmlword::exportHeader * * @return void */ public function testExportHeader() { ob_start(); $this->object->exportHeader(); $result = ob_get_clean();
$expected = '<html xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:x="urn:schemas-microsoft-com:office:word" xmlns="http://www.w3.org/TR/REC-html40">
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"' . ' "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html> <head> <meta http-equiv="Content-type" content="text/html;charset=' . 'utf-8' . '" /> </head> <body>';
$this->assertEquals( $expected, $result );
// case 2
$GLOBALS['charset_of_file'] = 'ISO-8859-1'; ob_start(); $this->object->exportHeader(); $result = ob_get_clean();
$expected = '<html xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:x="urn:schemas-microsoft-com:office:word" xmlns="http://www.w3.org/TR/REC-html40">
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"' . ' "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html> <head> <meta http-equiv="Content-type" content="text/html;charset=' . 'ISO-8859-1' . '" /> </head> <body>';
$this->assertEquals( $expected, $result ); }
/** * Test for ExportHtmlword::exportFooter * * @return void */ public function testExportFooter() { ob_start(); $this->assertTrue( $this->object->exportFooter() ); $result = ob_get_clean();
$this->assertEquals( '</body></html>', $result ); }
/** * Test for ExportHtmlword::exportDBHeader * * @return void */ public function testExportDBHeader() { ob_start(); $this->assertTrue( $this->object->exportDBHeader('d"b') ); $result = ob_get_clean();
$this->assertEquals( '<h1>Database d"b</h1>', $result ); }
/** * Test for ExportHtmlword::exportDBFooter * * @return void */ public function testExportDBFooter() { $this->assertTrue( $this->object->exportDBFooter('testDB') ); }
/** * Test for ExportHtmlword::exportDBCreate * * @return void */ public function testExportDBCreate() { $this->assertTrue( $this->object->exportDBCreate('testDB') ); }
/** * Test for ExportHtmlword::exportData * * @return void */ public function testExportData() { // case 1
$dbi = $this->getMockBuilder('PMA_DatabaseInterface') ->disableOriginalConstructor() ->getMock();
$dbi->expects($this->once()) ->method('query') ->with('test', null, PMA_DatabaseInterface::QUERY_UNBUFFERED) ->will($this->returnValue(true));
$dbi->expects($this->once()) ->method('numFields') ->with(true) ->will($this->returnValue(5));
$dbi->expects($this->any()) ->method('fieldName') ->will($this->returnValue("foo\\bar"));
$dbi->expects($this->at(7)) ->method('fetchRow') ->with(true) ->will($this->returnValue(array(null, '0', 'test', false)));
$dbi->expects($this->at(8)) ->method('fetchRow') ->with(true) ->will($this->returnValue(null)); $GLOBALS['dbi'] = $dbi;
$GLOBALS['htmlword_columns'] = true; $GLOBALS['what'] = 'UT'; $GLOBALS['UT_null'] = 'customNull'; $GLOBALS['output_kanji_conversion'] = false; $GLOBALS['output_charset_conversion'] = false; $GLOBALS['buffer_needed'] = false; $GLOBALS['asfile'] = true; $GLOBALS['save_on_server'] = false;
ob_start(); $this->assertTrue( $this->object->exportData( 'testDB', 'testTable', "\n", 'example.com', 'test' ) ); $result = htmlspecialchars_decode(ob_get_clean());
$this->assertEquals( '<h2>Dumping data for table testTable</h2>' . '<table class="width100" cellspacing="1"><tr class="print-category">' . '<td class="print"><strong>foobar</strong></td>' . '<td class="print"><strong>foobar</strong></td>' . '<td class="print"><strong>foobar</strong></td>' . '<td class="print"><strong>foobar</strong></td>' . '<td class="print"><strong>foobar</strong></td>' . '</tr><tr class="print-category"><td class="print">' . 'customNull</td><td class="print">0</td><td class="print">test</td>' . '<td class="print"></td><td class="print">customNull</td></tr></table>', $result ); }
/** * Test for ExportHtmlword::getTableDefStandIn * * @return void */ public function testGetTableDefStandIn() { $this->object = $this->getMockBuilder('ExportHtmlword') ->setMethods(array('formatOneColumnDefinition')) ->getMock();
// case 1
$keys = array( array( 'Non_unique' => 0, 'Column_name' => 'name1' ), array( 'Non_unique' => 1, 'Column_name' => 'name2' ) );
$dbi = $this->getMockBuilder('PMA_DatabaseInterface') ->disableOriginalConstructor() ->getMock();
$dbi->expects($this->once()) ->method('getTableIndexes') ->with('database', 'view') ->will($this->returnValue($keys));
$dbi->expects($this->once()) ->method('getColumns') ->with('database', 'view') ->will($this->returnValue(array(array('Field' => 'column'))));
$GLOBALS['dbi'] = $dbi;
$this->object->expects($this->once()) ->method('formatOneColumnDefinition') ->with(array('Field' => 'column'), array('name1'), 'column') ->will($this->returnValue(1));
$this->assertEquals( '<table class="width100" cellspacing="1">' . '<tr class="print-category"><th class="print">Column</th>' . '<td class="print"><strong>Type</strong></td>' . '<td class="print"><strong>Null</strong></td>' . '<td class="print"><strong>Default</strong></td></tr>' . '1</tr></table>', $this->object->getTableDefStandIn('database', 'view', "\n") ); }
/** * Test for ExportHtmlword::getTableDef * * @return void */ public function testGetTableDef() { $this->object = $this->getMockBuilder('ExportHtmlword') ->setMethods(array('formatOneColumnDefinition')) ->getMock();
$keys = array( array( 'Non_unique' => 0, 'Column_name' => 'name1' ), array( 'Non_unique' => 1, 'Column_name' => 'name2' ) );
// case 1
$dbi = $this->getMockBuilder('PMA_DatabaseInterface') ->disableOriginalConstructor() ->getMock();
$dbi->expects($this->at(1)) ->method('fetchResult') ->will($this->returnValue(array()));
$dbi->expects($this->at(6)) ->method('fetchResult') ->will( $this->returnValue( array( 'fieldname' => array( 'values' => 'test-', 'transformation' => 'testfoo', 'mimetype' => 'test<' ) ) ) );
$dbi->expects($this->once()) ->method('getTableIndexes') ->with('database', '') ->will($this->returnValue($keys));
$columns = array( 'Field' => 'fieldname' ); $dbi->expects($this->once()) ->method('getColumns') ->with('database', '') ->will($this->returnValue(array($columns)));
$dbi->expects($this->any()) ->method('query') ->will($this->returnValue(true));
$dbi->expects($this->any()) ->method('numRows') ->will($this->returnValue(1));
$dbi->expects($this->any()) ->method('fetchAssoc') ->will( $this->returnValue( array( 'comment' => array('fieldname' => 'testComment') ) ) );
$GLOBALS['dbi'] = $dbi;
$this->object->expects($this->exactly(3)) ->method('formatOneColumnDefinition') ->with($columns, array('name1')) ->will($this->returnValue(1));
$GLOBALS['cfgRelation']['relation'] = true; $GLOBALS['controllink'] = null; $_SESSION['relation'][0] = array( 'relwork' => true, 'commwork' => true, 'mimework' => true, 'db' => 'database', 'relation' => 'rel', 'column_info' => 'col' );
$result = $this->object->getTableDef( 'database', '', true, true, true );
$this->assertEquals( '<table class="width100" cellspacing="1">' . '<tr class="print-category"><th class="print">Column</th>' . '<td class="print"><strong>Type</strong></td>' . '<td class="print"><strong>Null</strong></td>' . '<td class="print"><strong>Default</strong></td>' . '<td class="print"><strong>Comments</strong></td>' . '<td class="print"><strong>MIME</strong></td></tr>' . '1<td class="print"></td><td class="print">Test<</td></tr></table>', $result );
// case 2
$dbi = $this->getMockBuilder('PMA_DatabaseInterface') ->disableOriginalConstructor() ->getMock();
$dbi->expects($this->at(1)) ->method('fetchResult') ->will( $this->returnValue( array( 'fieldname' => array( 'foreign_table' => 'ftable', 'foreign_field' => 'ffield' ) ) ) );
$dbi->expects($this->at(6)) ->method('fetchResult') ->will( $this->returnValue( array( 'field' => array( 'values' => 'test-', 'transformation' => 'testfoo', 'mimetype' => 'test<' ) ) ) );
$dbi->expects($this->once()) ->method('getTableIndexes') ->with('database', '') ->will($this->returnValue($keys));
$columns = array( 'Field' => 'fieldname' );
$dbi->expects($this->once()) ->method('getColumns') ->with('database', '') ->will($this->returnValue(array($columns)));
$dbi->expects($this->any()) ->method('query') ->will($this->returnValue(true));
$dbi->expects($this->any()) ->method('numRows') ->will($this->returnValue(1));
$dbi->expects($this->any()) ->method('fetchAssoc') ->will( $this->returnValue( array( 'comment' => array('field' => 'testComment') ) ) );
$GLOBALS['dbi'] = $dbi;
$GLOBALS['cfgRelation']['relation'] = true; $_SESSION['relation'][0] = array( 'relwork' => true, 'commwork' => true, 'mimework' => true, 'db' => 'database', 'relation' => 'rel', 'column_info' => 'col' );
$result = $this->object->getTableDef( 'database', '', true, true, true );
$this->assertContains( '<td class="print">ftable (ffield)</td>', $result );
$this->assertContains( '<td class="print"></td><td class="print"></td>', $result );
// case 3
$dbi = $this->getMockBuilder('PMA_DatabaseInterface') ->disableOriginalConstructor() ->getMock();
$dbi->expects($this->once()) ->method('getTableIndexes') ->with('database', '') ->will($this->returnValue($keys));
$columns = array( 'Field' => 'fieldname' );
$dbi->expects($this->once()) ->method('getColumns') ->with('database', '') ->will($this->returnValue(array($columns)));
$dbi->expects($this->any()) ->method('query') ->will($this->returnValue(true));
$dbi->expects($this->any()) ->method('numRows') ->will($this->returnValue(1));
$dbi->expects($this->any()) ->method('fetchAssoc') ->will( $this->returnValue( array( 'comment' => array('field' => 'testComment') ) ) );
$GLOBALS['dbi'] = $dbi;
$GLOBALS['cfgRelation']['relation'] = true; $_SESSION['relation'][0] = array( 'relwork' => false, 'commwork' => false, 'mimework' => false, 'db' => 'database', 'relation' => 'rel', 'column_info' => 'col' );
$result = $this->object->getTableDef( 'database', '', false, false, false );
$this->assertEquals( '<table class="width100" cellspacing="1">' . '<tr class="print-category"><th class="print">Column</th>' . '<td class="print"><strong>Type</strong></td>' . '<td class="print"><strong>Null</strong></td>' . '<td class="print"><strong>Default</strong></td></tr>1</tr></table>', $result ); }
/** * Test for ExportHtmlword::getTriggers * * @return void */ public function testGetTriggers() { $dbi = $this->getMockBuilder('PMA_DatabaseInterface') ->disableOriginalConstructor() ->getMock();
$triggers = array( array( 'name' => 'tna"me', 'action_timing' => 'ac>t', 'event_manipulation' => 'manip&', 'definition' => 'def' ) );
$dbi->expects($this->once()) ->method('getTriggers') ->with('database', 'table') ->will($this->returnValue($triggers));
$GLOBALS['dbi'] = $dbi;
$method = new ReflectionMethod('ExportHtmlword', 'getTriggers'); $method->setAccessible(true); $result = $method->invoke($this->object, 'database', 'table');
$this->assertContains( '<td class="print">tna"me</td>' . '<td class="print">ac>t</td>' . '<td class="print">manip&</td>' . '<td class="print">def</td>', $result ); }
/** * Test for ExportHtmlword::exportStructure * * @return void */ public function testExportStructure() {
$dbi = $this->getMockBuilder('PMA_DatabaseInterface') ->disableOriginalConstructor() ->getMock();
$dbi->expects($this->once()) ->method('getTriggers') ->with('db', 'tbl') ->will($this->returnValue(1));
$this->object = $this->getMockBuilder('ExportHtmlword') ->setMethods(array('getTableDef', 'getTriggers', 'getTableDefStandIn')) ->getMock();
$this->object->expects($this->at(0)) ->method('getTableDef') ->with('db', 'tbl', false, false, false, false) ->will($this->returnValue('dumpText1'));
$this->object->expects($this->once()) ->method('getTriggers') ->with('db', 'tbl') ->will($this->returnValue('dumpText2'));
$this->object->expects($this->at(2)) ->method('getTableDef') ->with('db', 'tbl', false, false, false, true, array()) ->will($this->returnValue('dumpText3'));
$this->object->expects($this->once()) ->method('getTableDefStandIn') ->with('db', 'tbl', "\n") ->will($this->returnValue('dumpText4'));
$GLOBALS['dbi'] = $dbi;
ob_start(); $this->assertTrue( $this->object->exportStructure( 'db', 'tbl', "\n", "example.com", "create_table", "test" ) ); $result = ob_get_clean();
$this->assertEquals( '<h2>Table structure for table tbl</h2>dumpText1', $result );
ob_start(); $this->assertTrue( $this->object->exportStructure( 'db', 'tbl', "\n", "example.com", "triggers", "test" ) ); $result = ob_get_clean();
$this->assertEquals( '<h2>Triggers tbl</h2>dumpText2', $result );
ob_start(); $this->assertTrue( $this->object->exportStructure( 'db', 'tbl', "\n", "example.com", "create_view", "test" ) ); $result = ob_get_clean();
$this->assertEquals( '<h2>Structure for view tbl</h2>dumpText3', $result );
ob_start(); $this->assertTrue( $this->object->exportStructure( 'db', 'tbl', "\n", "example.com", "stand_in", "test" ) ); $result = ob_get_clean();
$this->assertEquals( '<h2>Stand-in structure for view tbl</h2>dumpText4', $result ); }
/** * Test for ExportHtmlword::formatOneColumnDefinition * * @return void */ public function testFormatOneColumnDefinition() { $GLOBALS['cfg']['LimitChars'] = 40;
$method = new ReflectionMethod( 'ExportHtmlword', 'formatOneColumnDefinition' ); $method->setAccessible(true);
$cols = array( 'Null' => 'Yes', 'Field' => 'field', 'Key' => 'PRI', 'Type' => 'set(abc)enum123' );
$unique_keys = array( 'field' );
$this->assertEquals( '<tr class="print-category"><td class="print"><em>' . '<strong>field</strong></em></td><td class="print">set(abc)</td>' . '<td class="print">Yes</td><td class="print">NULL</td>', $method->invoke($this->object, $cols, $unique_keys) );
$cols = array( 'Null' => 'NO', 'Field' => 'fields', 'Key' => 'COMP', 'Type' => '', 'Default' => 'def' );
$unique_keys = array( 'field' );
$this->assertEquals( '<tr class="print-category"><td class="print">fields</td>' . '<td class="print">&nbsp;</td><td class="print">No</td>' . '<td class="print">def</td>', $method->invoke($this->object, $cols, $unique_keys) ); } } ?>
|