object = new ImportOds(); //setting $GLOBALS['finished'] = false; $GLOBALS['read_limit'] = 100000000; $GLOBALS['offset'] = 0; $GLOBALS['cfg']['Server']['DisableIS'] = false; $GLOBALS['import_file'] = 'test/test_data/db_test.ods'; /** * Load interface for zip extension. */ include_once 'libraries/zip_extension.lib.php'; $result = PMA_getZipContents($GLOBALS['import_file']); $GLOBALS['import_text'] = $result["data"]; $GLOBALS['compression'] = 'application/zip'; $GLOBALS['read_multiply'] = 10; $GLOBALS['import_type'] = 'ods'; $GLOBALS['import_handle'] = @fopen($GLOBALS['import_file'], 'r'); //variable for Ods $_REQUEST['ods_recognize_percentages'] = true; $_REQUEST['ods_recognize_currency'] = true; $_REQUEST['ods_empty_rows'] = true; } /** * Tears down the fixture, for example, closes a network connection. * This method is called after a test is executed. * * @access protected * @return void */ protected function tearDown() { unset($this->object); } /** * Test for getProperties * * @return void * * @group medium */ public function testGetProperties() { $properties = $this->object->getProperties(); $this->assertEquals( __('OpenDocument Spreadsheet'), $properties->getText() ); $this->assertEquals( 'ods', $properties->getExtension() ); $this->assertEquals( __('Options'), $properties->getOptionsText() ); } /** * Test for doImport * * @return void * * @group medium */ public function testDoImport() { //$sql_query_disabled will show the import SQL detail //$import_notice will show the import detail result global $import_notice, $sql_query, $sql_query_disabled; $sql_query_disabled = false; //Mock DBI $dbi = $this->getMockBuilder('PMA\libraries\DatabaseInterface') ->disableOriginalConstructor() ->getMock(); $dbi->expects($this->any())->method('escapeString') ->will($this->returnArgument(0)); $GLOBALS['dbi'] = $dbi; //Test function called $this->object->doImport(); $this->assertContains( 'CREATE DATABASE IF NOT EXISTS `ODS_DB` DEFAULT CHARACTER SET ' . 'utf8 COLLATE utf8_general_ci', $sql_query ); $this->assertContains( 'CREATE TABLE IF NOT EXISTS `ODS_DB`.`pma_bookmark`', $sql_query ); $this->assertContains( "INSERT INTO `ODS_DB`.`pma_bookmark` (`A`, `B`, `C`, `D`) VALUES " . "(1, 'dbbase', NULL, 'ddd');", $sql_query ); //asset that all databases and tables are imported $this->assertContains( 'The following structures have either been created or altered.', $import_notice ); $this->assertContains( 'Go to database: `ODS_DB`', $import_notice ); $this->assertContains( 'Edit settings for `ODS_DB`', $import_notice ); $this->assertContains( 'Go to table: `pma_bookmark`', $import_notice ); $this->assertContains( 'Edit settings for `pma_bookmark`', $import_notice ); //asset that the import process is finished $this->assertEquals( true, $GLOBALS['finished'] ); } }