Initial commit
This commit is contained in:
508
#pma/test/classes/plugin/export/ExportOdsTest.php
Normal file
508
#pma/test/classes/plugin/export/ExportOdsTest.php
Normal file
@ -0,0 +1,508 @@
|
||||
<?php
|
||||
/* vim: set expandtab sw=4 ts=4 sts=4: */
|
||||
/**
|
||||
* tests for PMA\libraries\plugins\export\ExportOds class
|
||||
*
|
||||
* @package PhpMyAdmin-test
|
||||
*/
|
||||
use PMA\libraries\plugins\export\ExportOds;
|
||||
|
||||
//ExportOds required because of initialisation inside
|
||||
require_once 'libraries/plugins/export/ExportOds.php';
|
||||
require_once 'libraries/export.lib.php';
|
||||
require_once 'libraries/config.default.php';
|
||||
require_once 'export.php';
|
||||
require_once 'libraries/opendocument.lib.php';
|
||||
require_once 'test/PMATestCase.php';
|
||||
|
||||
/**
|
||||
* tests for PMA\libraries\plugins\export\ExportOds class
|
||||
*
|
||||
* @package PhpMyAdmin-test
|
||||
* @group medium
|
||||
*/
|
||||
class ExportOdsTest 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 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(
|
||||
'</office:spreadsheet>',
|
||||
$GLOBALS['ods_buffer']
|
||||
);
|
||||
|
||||
$this->assertContains(
|
||||
'</office:body>',
|
||||
$GLOBALS['ods_buffer']
|
||||
);
|
||||
|
||||
$this->assertContains(
|
||||
'</office:document-content>',
|
||||
$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(
|
||||
'<table:table table:name="table"><table:table-row><table:table-cell ' .
|
||||
'office:value-type="string"><text:p>&</text:p></table:table-cell>' .
|
||||
'<table:table-cell office:value-type="string"><text:p></text:p>' .
|
||||
'</table:table-cell><table:table-cell office:value-type="date" office:' .
|
||||
'date-value="2000-01-01" table:style-name="DateCell"><text:p>01-01' .
|
||||
'-2000</text:p></table:table-cell><table:table-cell office:value-type=' .
|
||||
'"time" office:time-value="PT10H00M00S" table:style-name="TimeCell">' .
|
||||
'<text:p>01-01-2000 10:00:00</text:p></table:table-cell><table:table-' .
|
||||
'cell office:value-type="date" office:date-value="2014-01-01T10:02:00"' .
|
||||
' table:style-name="DateTimeCell"><text:p>01-01-2014 10:02:00' .
|
||||
'</text:p></table:table-cell><table:table-cell office:value-type=' .
|
||||
'"float" office:value="t>s" ><text:p>t>s</text:p>' .
|
||||
'</table:table-cell><table:table-cell office:value-type="float" ' .
|
||||
'office:value="a&b" ><text:p>a&b</text:p></table:table-cell>' .
|
||||
'<table:table-cell office:value-type="string"><text:p><</text:p>' .
|
||||
'</table:table-cell></table:table-row></table:table>',
|
||||
$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/<e2'));
|
||||
|
||||
$dbi->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(
|
||||
'<table:table table:name="table"><table:table-row><table:table-cell ' .
|
||||
'office:value-type="string"><text:p>fna"me</text:p></table:table' .
|
||||
'-cell><table:table-cell office:value-type="string"><text:p>' .
|
||||
'fnam/<e2</text:p></table:table-cell></table:table-row>' .
|
||||
'</table:table>',
|
||||
$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(
|
||||
'<table:table table:name="table"><table:table-row></table:table-row>' .
|
||||
'</table:table>',
|
||||
$GLOBALS['ods_buffer']
|
||||
);
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user