object = new ExportOds(); } /** * tearDown for test cases * * @return void */ public function tearDown() { unset($this->object); } /** * Test for PMA\libraries\plugins\export\ExportOds::setProperties * * @return void */ public function testSetProperties() { $method = new ReflectionMethod('PMA\libraries\plugins\export\ExportOds', 'setProperties'); $method->setAccessible(true); $method->invoke($this->object, null); $attrProperties = new ReflectionProperty('PMA\libraries\plugins\export\ExportOds', 'properties'); $attrProperties->setAccessible(true); $properties = $attrProperties->getValue($this->object); $this->assertInstanceOf( 'PMA\libraries\properties\plugins\ExportPluginProperties', $properties ); $this->assertEquals( 'OpenDocument Spreadsheet', $properties->getText() ); $this->assertEquals( 'ods', $properties->getExtension() ); $this->assertEquals( 'application/vnd.oasis.opendocument.spreadsheet', $properties->getMimeType() ); $this->assertEquals( 'Options', $properties->getOptionsText() ); $this->assertTrue( $properties->getForceFile() ); $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() ); $generalProperties = $generalOptions->getProperties(); $property = array_shift($generalProperties); $this->assertInstanceOf( 'PMA\libraries\properties\options\items\TextPropertyItem', $property ); $this->assertEquals( 'null', $property->getName() ); $this->assertEquals( 'Replace NULL with:', $property->getText() ); $property = array_shift($generalProperties); $this->assertInstanceOf( 'PMA\libraries\properties\options\items\BoolPropertyItem', $property ); $this->assertEquals( 'columns', $property->getName() ); $this->assertEquals( 'Put columns names in the first row', $property->getText() ); $property = array_shift($generalProperties); $this->assertInstanceOf( 'PMA\libraries\properties\options\items\HiddenPropertyItem', $property ); $this->assertEquals( 'structure_or_data', $property->getName() ); } /** * Test for PMA\libraries\plugins\export\ExportOds::exportHeader * * @return void */ public function testExportHeader() { $this->assertTrue( isset($GLOBALS['ods_buffer']) ); $this->assertTrue( $this->object->exportHeader() ); } /** * Test for PMA\libraries\plugins\export\ExportOds::exportFooter * * @return void */ public function testExportFooter() { $GLOBALS['ods_buffer'] = 'header'; $this->expectOutputRegex('/^504b.*636f6e74656e742e786d6c/'); $this->setOutputCallback('bin2hex'); $this->assertTrue( $this->object->exportFooter() ); $this->assertContains( 'header', $GLOBALS['ods_buffer'] ); $this->assertContains( '', $GLOBALS['ods_buffer'] ); $this->assertContains( '', $GLOBALS['ods_buffer'] ); $this->assertContains( '', $GLOBALS['ods_buffer'] ); } /** * Test for PMA\libraries\plugins\export\ExportOds::exportDBHeader * * @return void */ public function testExportDBHeader() { $this->assertTrue( $this->object->exportDBHeader('testDB') ); } /** * Test for PMA\libraries\plugins\export\ExportOds::exportDBFooter * * @return void */ public function testExportDBFooter() { $this->assertTrue( $this->object->exportDBFooter('testDB') ); } /** * Test for PMA\libraries\plugins\export\ExportOds::exportDBCreate * * @return void */ public function testExportDBCreate() { $this->assertTrue( $this->object->exportDBCreate('testDB', 'database') ); } /** * Test for PMA\libraries\plugins\export\ExportOds::exportData * * @return void */ public function testExportData() { $dbi = $this->getMockBuilder('PMA\libraries\DatabaseInterface') ->disableOriginalConstructor() ->getMock(); $flags = array(); $a = new StdClass; $flags[] = $a; $a = new StdClass; $a->blob = true; $flags[] = $a; $a = new StdClass; $a->blob = false; $a->type = 'date'; $flags[] = $a; $a = new StdClass; $a->blob = false; $a->type = 'time'; $flags[] = $a; $a = new StdClass; $a->blob = false; $a->type = 'datetime'; $flags[] = $a; $a = new StdClass; $a->numeric = true; $a->type = 'none'; $a->blob = false; $flags[] = $a; $a = new StdClass; $a->numeric = true; $a->type = 'real'; $a->blob = true; $flags[] = $a; $a = new StdClass; $a->type = "dummy"; $a->blob = false; $a->numeric = false; $flags[] = $a; $dbi->expects($this->once()) ->method('getFieldsMeta') ->with(true) ->will($this->returnValue($flags)); $dbi->expects($this->exactly(8)) ->method('fieldFlags') ->willReturnOnConsecutiveCalls( 'BINARYTEST', 'binary', '', '', '', '', '', '' ); $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(8)); $dbi->expects($this->at(11)) ->method('fetchRow') ->with(true) ->will( $this->returnValue( array( null, '01-01-2000', '01-01-2000', '01-01-2000 10:00:00', "01-01-2014 10:02:00", "t>s", "a&b", "<" ) ) ); $GLOBALS['dbi'] = $dbi; $GLOBALS['mediawiki_caption'] = true; $GLOBALS['mediawiki_headers'] = true; $GLOBALS['what'] = 'foo'; $GLOBALS['foo_null'] = "&"; $this->assertTrue( $this->object->exportData( 'db', 'table', "\n", "example.com", "SELECT" ) ); $this->assertEquals( '&' . '' . '01-01' . '-2000' . '01-01-2000 10:00:0001-01-2014 10:02:00' . 't>s' . 'a&b' . '<' . '', $GLOBALS['ods_buffer'] ); } /** * Test for PMA\libraries\plugins\export\ExportOds::exportData * * @return void */ public function testExportDataWithFieldNames() { $dbi = $this->getMockBuilder('PMA\libraries\DatabaseInterface') ->disableOriginalConstructor() ->getMock(); $flags = array(); $dbi->expects($this->once()) ->method('getFieldsMeta') ->with(true) ->will($this->returnValue($flags)); $dbi->expects($this->any()) ->method('fieldFlags') ->will($this->returnValue('BINARYTEST')); $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(5)) ->method('fieldName') ->will($this->returnValue('fna\"me')); $dbi->expects($this->at(6)) ->method('fieldName') ->will($this->returnValue('fnam/expects($this->at(7)) ->method('fetchRow') ->with(true) ->will( $this->returnValue( null ) ); $GLOBALS['dbi'] = $dbi; $GLOBALS['mediawiki_caption'] = true; $GLOBALS['mediawiki_headers'] = true; $GLOBALS['what'] = 'foo'; $GLOBALS['foo_null'] = "&"; $GLOBALS['foo_columns'] = true; $this->assertTrue( $this->object->exportData( 'db', 'table', "\n", "example.com", "SELECT" ) ); $this->assertEquals( 'fna"me' . 'fnam/<e2' . '', $GLOBALS['ods_buffer'] ); // with no row count $dbi = $this->getMockBuilder('PMA\libraries\DatabaseInterface') ->disableOriginalConstructor() ->getMock(); $flags = array(); $dbi->expects($this->once()) ->method('getFieldsMeta') ->with(true) ->will($this->returnValue($flags)); $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(0)); $dbi->expects($this->once()) ->method('fetchRow') ->with(true) ->will( $this->returnValue( null ) ); $GLOBALS['dbi'] = $dbi; $GLOBALS['mediawiki_caption'] = true; $GLOBALS['mediawiki_headers'] = true; $GLOBALS['what'] = 'foo'; $GLOBALS['foo_null'] = "&"; $GLOBALS['ods_buffer'] = ''; $this->assertTrue( $this->object->exportData( 'db', 'table', "\n", "example.com", "SELECT" ) ); $this->assertEquals( '' . '', $GLOBALS['ods_buffer'] ); } }