File: /data/wwwroot/wordpress/phpMyAdmin/test/classes/plugin/export/PMA_ExportSql_test.php
<?php
/* vim: set expandtab sw=4 ts=4 sts=4: */
/**
* tests for ExportSql class
*
* @package PhpMyAdmin-test
*/
require_once 'libraries/plugins/export/ExportSql.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/mysql_charsets.lib.php';
require_once 'libraries/relation.lib.php';
require_once 'libraries/transformations.lib.php';
require_once 'libraries/Table.class.php';
require_once 'libraries/sqlparser.lib.php';
require_once 'libraries/charset_conversion.lib.php';
require_once 'export.php';
/**
* tests for ExportSql class
*
* @package PhpMyAdmin-test
* @group medium
*/
class PMA_ExportSql_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;
$GLOBALS['output_kanji_conversion'] = false;
$GLOBALS['buffer_needed'] = false;
$GLOBALS['asfile'] = false;
$GLOBALS['save_on_server'] = false;
$GLOBALS['plugin_param'] = array();
$GLOBALS['plugin_param']['export_type'] = 'table';
$GLOBALS['plugin_param']['single_table'] = false;
$GLOBALS['cfgRelation']['relation'] = true;
$GLOBALS['controllink'] = null;
$this->object = new ExportSql();
}
/**
* tearDown for test cases
*
* @return void
*/
public function tearDown()
{
unset($this->object);
}
/**
* Test for ExportSql::setProperties
*
* @return void
* @group medium
*/
public function testSetProperties()
{
$restoreDrizzle = $restoreMySQLIntVersion = 'PMANORESTORE';
if (PMA_DRIZZLE) {
if (!PMA_HAS_RUNKIT) {
$this->markTestSkipped(
"Cannot redefine constant. Missing runkit extension"
);
} else {
if (PMA_DRIZZLE) {
$restoreDrizzle = PMA_DRIZZLE;
runkit_constant_redefine('PMA_DRIZZLE', false);
}
}
}
// test with hide structure and hide sql as true
$GLOBALS['plugin_param']['export_type'] = 'table';
$GLOBALS['plugin_param']['single_table'] = false;
$GLOBALS['cfgRelation']['mimework'] = true;
$method = new ReflectionMethod('ExportSql', 'setProperties');
$method->setAccessible(true);
$method->invoke($this->object, null);
$attrProperties = new ReflectionProperty('ExportSql', 'properties');
$attrProperties->setAccessible(true);
$properties = $attrProperties->getValue($this->object);
$this->assertNull(
$properties
);
// test with hide structure and hide sql as false
$dbi = $this->getMockBuilder('PMA_DatabaseInterface')
->disableOriginalConstructor()
->getMock();
$dbi->expects($this->once())
->method('getCompatibilities')
->will($this->returnValue(array('v1', 'v2')));
$GLOBALS['dbi'] = $dbi;
$GLOBALS['plugin_param']['export_type'] = 'server';
$GLOBALS['plugin_param']['single_table'] = false;
$GLOBALS['cfgRelation']['mimework'] = true;
$GLOBALS['cfgRelation']['relation'] = true;
$method->invoke($this->object, null);
$properties = $attrProperties->getValue($this->object);
$this->assertInstanceOf(
'ExportPluginProperties',
$properties
);
$this->assertEquals(
'SQL',
$properties->getText()
);
$options = $properties->getOptions();
$this->assertInstanceOf(
'OptionsPropertyRootGroup',
$options
);
$generalOptionsArray = $options->getProperties();
$generalOptions = array_shift($generalOptionsArray);
$this->assertInstanceOf(
'OptionsPropertyMainGroup',
$generalOptions
);
$properties = $generalOptions->getProperties();
$property = array_shift($properties);
$this->assertInstanceOf(
'OptionsPropertySubgroup',
$property
);
$this->assertInstanceOf(
'BoolPropertyItem',
$property->getSubgroupHeader()
);
$leaves = $property->getProperties();
$leaf = array_shift($leaves);
$this->assertInstanceOf(
'TextPropertyItem',
$leaf
);
$leaf = array_shift($leaves);
$this->assertInstanceOf(
'BoolPropertyItem',
$leaf
);
$leaf = array_shift($leaves);
$this->assertInstanceOf(
'BoolPropertyItem',
$leaf
);
$leaf = array_shift($leaves);
$this->assertInstanceOf(
'BoolPropertyItem',
$leaf
);
$property = array_shift($properties);
$this->assertInstanceOf(
'BoolPropertyItem',
$property
);
$property = array_shift($properties);
$this->assertInstanceOf(
'BoolPropertyItem',
$property
);
$property = array_shift($properties);
$this->assertInstanceOf(
'BoolPropertyItem',
$property
);
$property = array_shift($properties);
$this->assertInstanceOf(
'SelectPropertyItem',
$property
);
$this->assertEquals(
array(
'v1' => 'v1',
'v2' => 'v2'
),
$property->getValues()
);
$property = array_shift($properties);
$this->assertInstanceOf(
'BoolPropertyItem',
$property
);
$property = array_shift($properties);
$this->assertInstanceOf(
'OptionsPropertySubgroup',
$property
);
$this->assertInstanceOf(
'RadioPropertyItem',
$property->getSubgroupHeader()
);
$structureOptions = array_shift($generalOptionsArray);
$this->assertInstanceOf(
'OptionsPropertyMainGroup',
$structureOptions
);
$properties = $structureOptions->getProperties();
$property = array_shift($properties);
$this->assertInstanceOf(
'OptionsPropertySubgroup',
$property
);
$this->assertInstanceOf(
'MessageOnlyPropertyItem',
$property->getSubgroupHeader()
);
$leaves = $property->getProperties();
$leaf = array_shift($leaves);
$this->assertInstanceOf(
'BoolPropertyItem',
$leaf
);
$leaf = array_shift($leaves);
$this->assertInstanceOf(
'BoolPropertyItem',
$leaf
);
$this->assertEquals(
'Add <code>DROP TABLE / VIEW / PROCEDURE / FUNCTION' .
' / EVENT</code><code> / TRIGGER</code> statement',
$leaf->getText()
);
$leaf = array_shift($leaves);
$this->assertInstanceOf(
'BoolPropertyItem',
$leaf
);
$leaf = array_shift($leaves);
$this->assertInstanceOf(
'BoolPropertyItem',
$leaf
);
$leaf = array_shift($leaves);
$this->assertInstanceOf(
'BoolPropertyItem',
$leaf
);
$leaf = array_shift($leaves);
$this->assertInstanceOf(
'BoolPropertyItem',
$leaf
);
$leaf = array_shift($leaves);
$this->assertInstanceOf(
'OptionsPropertySubgroup',
$leaf
);
$this->assertCount(
2,
$leaf->getProperties()
);
$this->assertInstanceOf(
'BoolPropertyItem',
$leaf->getSubgroupHeader()
);
$property = array_shift($properties);
$this->assertInstanceOf(
'BoolPropertyItem',
$property
);
$dataOptions = array_shift($generalOptionsArray);
$this->assertInstanceOf(
'OptionsPropertyMainGroup',
$dataOptions
);
$properties = $dataOptions->getProperties();
$this->assertCount(
7,
$properties
);
$this->assertCount(
2,
$properties[1]->getProperties()
);
if ($restoreDrizzle !== 'PMANORESTORE') {
runkit_constant_redefine('PMA_DRIZZLE', $restoreDrizzle);
}
if ($restoreMySQLIntVersion !== 'PMANORESTORE') {
runkit_constant_redefine(
'PMA_MYSQL_INT_VERSION', $restoreMySQLIntVersion
);
}
}
/**
* Test for ExportSql::setProperties
*
* @return void
*/
public function testSetPropertiesWithDrizzle()
{
$restoreDrizzle = $restoreMySQLIntVersion = 'PMANORESTORE';
if (!PMA_DRIZZLE) {
if (!PMA_HAS_RUNKIT) {
$this->markTestSkipped(
"Cannot redefine constant. Missing runkit extension"
);
} else {
if (!PMA_DRIZZLE) {
$restoreDrizzle = PMA_DRIZZLE;
runkit_constant_redefine('PMA_DRIZZLE', true);
}
$restoreMySQLIntVersion = PMA_MYSQL_INT_VERSION;
runkit_constant_redefine('PMA_MYSQL_INT_VERSION', 50000);
}
}
$GLOBALS['plugin_param']['export_type'] = 'tableNot';
$GLOBALS['plugin_param']['single_table'] = true;
$GLOBALS['cfgRelation']['mimework'] = false;
$GLOBALS['cfgRelation']['relation'] = false;
$method = new ReflectionMethod('ExportSql', 'setProperties');
$method->setAccessible(true);
$method->invoke($this->object, null);
$attrProperties = new ReflectionProperty('ExportSql', 'properties');
$attrProperties->setAccessible(true);
$properties = $attrProperties->getValue($this->object);
$options = $properties->getOptions();
$generalOptionsArray = $options->getProperties();
$this->assertCount(
3,
$generalOptionsArray
);
// generalOptions
$option = array_shift($generalOptionsArray);
$properties = $option->getProperties();
$this->assertCount(
5,
$properties
);
$this->assertCount(
2,
$properties[0]->getProperties()
);
// structureOptions
$option = array_shift($generalOptionsArray);
$properties = $option->getProperties();
$this->assertCount(
2,
$properties
);
$properties = $properties[0]->getProperties();
$this->assertCount(
6,
$properties
);
$this->assertNotcontains(
'<code> / EVENT </code>',
$properties[1]->getText()
);
// dataOptions
$option = array_shift($generalOptionsArray);
$properties = $option->getProperties();
$this->assertCount(
6,
$properties
);
$properties = $properties[1]->getProperties();
$this->assertCount(
1,
$properties
);
// case 2 with export type as table
$GLOBALS['plugin_param']['export_type'] = 'table';
$method->invoke($this->object, null);
$properties = $attrProperties->getValue($this->object);
$options = $properties->getOptions();
$generalOptionsArray = $options->getProperties();
$structOption = $generalOptionsArray[1];
$properties = $structOption->getProperties();
$subgroupProps = $properties[0]->getProperties();
$this->assertContains(
'<code>DROP TABLE</code>',
$subgroupProps[0]->getText()
);
if ($restoreDrizzle !== 'PMANORESTORE') {
runkit_constant_redefine('PMA_DRIZZLE', $restoreDrizzle);
}
if ($restoreMySQLIntVersion !== 'PMANORESTORE') {
runkit_constant_redefine(
'PMA_MYSQL_INT_VERSION', $restoreMySQLIntVersion
);
}
}
/**
* Test for ExportSql::exportRoutines
*
* @return void
*/
public function testExportRoutines()
{
$GLOBALS['crlf'] = '##';
$GLOBALS['sql_drop_table'] = true;
$dbi = $this->getMockBuilder('PMA_DatabaseInterface')
->disableOriginalConstructor()
->getMock();
$dbi->expects($this->at(0))
->method('getProceduresOrFunctions')
->with('db', 'PROCEDURE')
->will($this->returnValue(array('p1', 'p2')));
$dbi->expects($this->at(1))
->method('getProceduresOrFunctions')
->with('db', 'FUNCTION')
->will($this->returnValue(array('f1')));
$dbi->expects($this->at(2))
->method('getDefinition')
->with('db', 'PROCEDURE', 'p1')
->will($this->returnValue('testp1'));
$dbi->expects($this->at(3))
->method('getDefinition')
->with('db', 'PROCEDURE', 'p2')
->will($this->returnValue('testp2'));
$dbi->expects($this->at(4))
->method('getDefinition')
->with('db', 'FUNCTION', 'f1')
->will($this->returnValue('testf1'));
$GLOBALS['dbi'] = $dbi;
$this->expectOutputString(
'##DELIMITER $$##DROP PROCEDURE IF EXISTS `p1`$$##testp1$$####' .
'DROP PROCEDURE IF EXISTS `p2`$$##testp2$$####DROP FUNCTION IF' .
' EXISTS `f1`$$##testf1$$####DELIMITER ;##'
);
$this->object->exportRoutines('db');
}
/**
* Test for ExportSql::_exportComment
*
* @return void
*/
public function testExportComment()
{
$method = new ReflectionMethod('ExportSql', '_exportComment');
$method->setAccessible(true);
$GLOBALS['crlf'] = '##';
$GLOBALS['sql_include_comments'] = true;
$this->assertEquals(
'--##',
$method->invoke($this->object, '')
);
$this->assertEquals(
'-- Comment##',
$method->invoke($this->object, 'Comment')
);
$GLOBALS['sql_include_comments'] = false;
$this->assertEquals(
'',
$method->invoke($this->object, 'Comment')
);
unset($GLOBALS['sql_include_comments']);
$this->assertEquals(
'',
$method->invoke($this->object, 'Comment')
);
}
/**
* Test for ExportSql::_possibleCRLF
*
* @return void
*/
public function testPossibleCRLF()
{
$method = new ReflectionMethod('ExportSql', '_possibleCRLF');
$method->setAccessible(true);
$GLOBALS['crlf'] = '##';
$GLOBALS['sql_include_comments'] = true;
$this->assertEquals(
'##',
$method->invoke($this->object, '')
);
$this->assertEquals(
'##',
$method->invoke($this->object, 'Comment')
);
$GLOBALS['sql_include_comments'] = false;
$this->assertEquals(
'',
$method->invoke($this->object, 'Comment')
);
unset($GLOBALS['sql_include_comments']);
$this->assertEquals(
'',
$method->invoke($this->object, 'Comment')
);
}
/**
* Test for ExportSql::exportFooter
*
* @return void
*/
public function testExportFooter()
{
$restoreDrizzle = 'PMANORESTORE';
if (PMA_DRIZZLE) {
if (!PMA_HAS_RUNKIT) {
$this->markTestSkipped(
"Cannot redefine constant. Missing runkit extension"
);
} else {
$restoreDrizzle = PMA_DRIZZLE;
runkit_constant_redefine('PMA_DRIZZLE', false);
}
}
$GLOBALS['sql_disable_fk'] = true;
$GLOBALS['sql_use_transaction'] = true;
$GLOBALS['charset_of_file'] = 'utf-8';
$GLOBALS['mysql_charset_map']['utf-8'] = true;
$GLOBALS['sql_utc_time'] = true;
$GLOBALS['old_tz'] = 'GMT';
$GLOBALS['asfile'] = 'yes';
$GLOBALS['output_charset_conversion'] = 'utf-8';
$dbi = $this->getMockBuilder('PMA_DatabaseInterface')
->disableOriginalConstructor()
->getMock();
$dbi->expects($this->once())
->method('query')
->with('SET time_zone = "GMT"');
$GLOBALS['dbi'] = $dbi;
$this->expectOutputString(
'SET FOREIGN_KEY_CHECKS=1;COMMIT;/*!40101 SET CHARACTER_SET_CLIENT' .
'=@OLD_CHARACTER_SET_CLIENT */;/*!40101 SET CHARACTER_SET_RESULTS=@' .
'OLD_CHARACTER_SET_RESULTS */;/*!40101 SET COLLATION_CONNECTION=@OLD' .
'_COLLATION_CONNECTION */;'
);
$this->assertTrue(
$this->object->exportFooter()
);
if ($restoreDrizzle !== 'PMANORESTORE') {
runkit_constant_redefine('PMA_DRIZZLE', $restoreDrizzle);
}
}
/**
* Test for ExportSql::exportHeader
*
* @return void
*/
public function testExportHeader()
{
if (!defined("PMA_MYSQL_STR_VERSION")) {
define("PMA_MYSQL_STR_VERSION", "5.0.0");
}
$restoreDrizzle = 'PMANORESTORE';
if (PMA_DRIZZLE) {
if (!PMA_HAS_RUNKIT) {
$this->markTestSkipped(
"Cannot redefine constant. Missing runkit extension"
);
} else {
$restoreDrizzle = PMA_DRIZZLE;
runkit_constant_redefine('PMA_DRIZZLE', false);
}
}
$GLOBALS['crlf'] = "\n";
$GLOBALS['sql_compatibility'] = 'NONE';
$GLOBALS['cfg']['Server']['host'] = 'localhost';
$GLOBALS['cfg']['Server']['port'] = 80;
$GLOBALS['sql_disable_fk'] = true;
$GLOBALS['sql_use_transaction'] = true;
$GLOBALS['sql_utc_time'] = true;
$GLOBALS['old_tz'] = 'GMT';
$GLOBALS['asfile'] = 'yes';
$GLOBALS['output_charset_conversion'] = 'utf-8';
$GLOBALS['sql_header_comment'] = "h1C\nh2C";
$GLOBALS['sql_use_transaction'] = true;
$GLOBALS['sql_include_comments'] = true;
$GLOBALS['charset_of_file'] = 'utf-8';
$GLOBALS['mysql_charset_map']['utf-8'] = true;
$dbi = $this->getMockBuilder('PMA_DatabaseInterface')
->disableOriginalConstructor()
->getMock();
$dbi->expects($this->once())
->method('tryQuery')
->with('SET SQL_MODE=""');
$dbi->expects($this->once())
->method('fetchValue')
->with('SELECT @@session.time_zone')
->will($this->returnValue('old_tz'));
$dbi->expects($this->once())
->method('query')
->with('SET time_zone = "+00:00"');
$GLOBALS['dbi'] = $dbi;
ob_start();
$this->assertTrue(
$this->object->exportHeader()
);
$result = ob_get_clean();
$this->assertContains(
'h1C',
$result
);
$this->assertContains(
'h2C',
$result
);
$this->assertContains(
"SET FOREIGN_KEY_CHECKS=0;\n",
$result
);
$this->assertContains(
"40101 SET",
$result
);
$this->assertContains(
"SET FOREIGN_KEY_CHECKS=0;\n" .
"SET SQL_MODE = \"NO_AUTO_VALUE_ON_ZERO\";\n" .
"SET AUTOCOMMIT = 0;\n" .
"START TRANSACTION;\n" .
"SET time_zone = \"+00:00\";\n",
$result
);
if ($restoreDrizzle !== 'PMANORESTORE') {
runkit_constant_redefine('PMA_DRIZZLE', $restoreDrizzle);
}
}
/**
* Test for ExportSql::exportDBCreate
*
* @return void
*/
public function testExportDBCreate()
{
$GLOBALS['sql_compatibility'] = 'NONE';
$GLOBALS['sql_drop_database'] = true;
$GLOBALS['sql_backquotes'] = true;
$GLOBALS['sql_create_database'] = true;
$GLOBALS['sql_create_table'] = true;
$GLOBALS['sql_create_view'] = true;
$GLOBALS['crlf'] = "\n";
$dbi = $this->getMockBuilder('PMA_DatabaseInterface')
->disableOriginalConstructor()
->getMock();
$dbi->expects($this->once())
->method('isSystemSchema')
->with('db')
->will($this->returnValue(true));
$GLOBALS['dbi'] = $dbi;
ob_start();
$this->assertTrue(
$this->object->exportDBCreate('db')
);
$result = ob_get_clean();
$this->assertContains(
"DROP DATABASE `db`;\n",
$result
);
$this->assertContains(
'CREATE DATABASE IF NOT EXISTS `db` DEFAULT CHARACTER ' .
'SET utf8 COLLATE utf8_general_ci;',
$result
);
$this->assertContains(
'USE `db`;',
$result
);
// case2: no backquotes
unset($GLOBALS['sql_compatibility']);
$GLOBALS['cfg']['Server']['DisableIS'] = true;
unset($GLOBALS['sql_backquotes']);
$dbi = $this->getMockBuilder('PMA_DatabaseInterface')
->disableOriginalConstructor()
->getMock();
$dbi->expects($this->once())
->method('fetchValue')
->with('SHOW VARIABLES LIKE \'collation_database\'', 0, 1)
->will($this->returnValue('testcollation'));
$GLOBALS['dbi'] = $dbi;
ob_start();
$this->assertTrue(
$this->object->exportDBCreate('db')
);
$result = ob_get_clean();
$this->assertContains(
"DROP DATABASE db;\n",
$result
);
$this->assertContains(
'CREATE DATABASE IF NOT EXISTS db DEFAULT CHARACTER SET testcollation;',
$result
);
$this->assertContains(
'USE db;',
$result
);
}
/**
* Test for ExportSql::exportDBHeader
*
* @return void
*/
public function testExportDBHeader()
{
$GLOBALS['sql_compatibility'] = 'MSSQL';
$GLOBALS['sql_backquotes'] = true;
$GLOBALS['sql_include_comments'] = true;
$GLOBALS['crlf'] = "\n";
ob_start();
$this->assertTrue(
$this->object->exportDBHeader('testDB')
);
$result = ob_get_clean();
$this->assertContains(
""testDB"",
$result
);
// case 2
unset($GLOBALS['sql_compatibility']);
unset($GLOBALS['sql_backquotes']);
ob_start();
$this->assertTrue(
$this->object->exportDBHeader('testDB')
);
$result = ob_get_clean();
$this->assertContains(
"testDB",
$result
);
}
/**
* Test for ExportSql::exportEvents
*
* @return void
*/
public function testExportEventsWithNewerMySQLVersion()
{
$restoreMySQLVersion = "PMANORESTORE";
if (! PMA_HAS_RUNKIT) {
$this->markTestSkipped(
'Cannot redefine constant. Missing runkit extension'
);
} else {
$restoreMySQLVersion = PMA_MYSQL_INT_VERSION;
runkit_constant_redefine('PMA_MYSQL_INT_VERSION', 50101);
}
$GLOBALS['crlf'] = "\n";
$GLOBALS['sql_structure_or_data'] = 'structure';
$GLOBALS['sql_procedure_function'] = true;
$dbi = $this->getMockBuilder('PMA_DatabaseInterface')
->disableOriginalConstructor()
->getMock();
$dbi->expects($this->once())
->method('fetchResult')
->with(
'SELECT EVENT_NAME FROM information_schema.EVENTS WHERE'
. ' EVENT_SCHEMA= \'db\';'
)
->will($this->returnValue(array('f1', 'f2')));
$dbi->expects($this->at(1))
->method('getDefinition')
->with('db', 'EVENT', 'f1')
->will($this->returnValue('f1event'));
$dbi->expects($this->at(2))
->method('getDefinition')
->with('db', 'EVENT', 'f2')
->will($this->returnValue('f2event'));
$GLOBALS['dbi'] = $dbi;
ob_start();
$this->assertTrue(
$this->object->exportEvents('db', array())
);
$result = ob_get_clean();
$this->assertContains(
"DELIMITER $$\n",
$result
);
$this->assertContains(
"DELIMITER ;\n",
$result
);
$this->assertContains(
"f1event$$\n",
$result
);
$this->assertContains(
"f2event$$\n",
$result
);
if ($restoreMySQLVersion !== "PMANORESTORE") {
runkit_constant_redefine('PMA_MYSQL_INT_VERSION', $restoreMySQLVersion);
}
}
/**
* Test for ExportSql::exportDBFooter
*
* @return void
*/
public function testExportDBFooterWithOlderMySQLVersion()
{
$restoreMySQLVersion = "PMANORESTORE";
if (! PMA_HAS_RUNKIT) {
$this->markTestSkipped(
'Cannot redefine constant. Missing runkit extension'
);
} else {
$restoreMySQLVersion = PMA_MYSQL_INT_VERSION;
runkit_constant_redefine('PMA_MYSQL_INT_VERSION', 50100);
}
$GLOBALS['crlf'] = "\n";
$GLOBALS['sql_constraints'] = "SqlConstraints";
$GLOBALS['sql_structure_or_data'] = 'structure';
$GLOBALS['sql_procedure_function'] = true;
$dbi = $this->getMockBuilder('PMA_DatabaseInterface')
->disableOriginalConstructor()
->getMock();
$GLOBALS['dbi'] = $dbi;
ob_start();
$this->assertTrue(
$this->object->exportDBFooter('db')
);
$result = ob_get_clean();
$this->assertEquals(
'SqlConstraints',
$result
);
if ($restoreMySQLVersion !== "PMANORESTORE") {
runkit_constant_redefine('PMA_MYSQL_INT_VERSION', $restoreMySQLVersion);
}
}
/**
* Test for ExportSql::getTableDefStandIn
*
* @return void
*/
public function testGetTableDefStandIn()
{
$GLOBALS['sql_drop_table'] = true;
$GLOBALS['sql_if_not_exists'] = true;
$dbi = $this->getMockBuilder('PMA_DatabaseInterface')
->disableOriginalConstructor()
->getMock();
$dbi->expects($this->once())
->method('getColumnsFull')
->with('db', 'view')
->will(
$this->returnValue(
array('cname' => array('Type' => 'int'))
)
);
$GLOBALS['dbi'] = $dbi;
$result = $this->object->getTableDefStandIn('db', 'view', "");
$this->assertContains(
"DROP VIEW IF EXISTS `view`;",
$result
);
$this->assertContains(
"CREATE TABLE IF NOT EXISTS `view` (`cname` int);",
$result
);
}
/**
* Test for ExportSql::_getTableDefForView
*
* @return void
*/
public function testGetTableDefForView()
{
$GLOBALS['sql_drop_table'] = true;
$GLOBALS['sql_if_not_exists'] = true;
$GLOBALS['cfg']['LimitChars'] = 40;
$dbi = $this->getMockBuilder('PMA_DatabaseInterface')
->disableOriginalConstructor()
->getMock();
$dbi->expects($this->at(0))
->method('getColumns')
->with('db', 'view')
->will(
$this->returnValue(
array(
'cname' => array(
'Type' => 'char',
'Collation' => 'utf-8',
'Null' => 'NO',
'Default' => 'a',
'Comment' => 'cmt',
'Field' => 'fname'
)
)
)
);
$dbi->expects($this->at(1))
->method('getColumns')
->with('db', 'view')
->will(
$this->returnValue(
array(
'cname' => array(
'Type' => 'char',
'Collation' => 'utf-8',
'Null' => 'YES',
'Comment' => 'cmt',
'Field' => 'fname'
)
)
)
);
$GLOBALS['dbi'] = $dbi;
$GLOBALS['sql_compatibility'] = 'MSSQL';
$method = new ReflectionMethod('ExportSql', '_getTableDefForView');
$method->setAccessible(true);
$result = $method->invoke(
$this->object, 'db', 'view', "\n"
);
$this->assertEquals(
"CREATE TABLE `view`(\n" .
" `fname` char COLLATE utf-8 NOT NULL DEFAULT 'a' COMMENT 'cmt'\n" .
");\n",
$result
);
// case 2
unset($GLOBALS['sql_compatibility']);
$result = $method->invoke(
$this->object, 'db', 'view', "\n", false
);
$this->assertEquals(
"CREATE TABLE IF NOT EXISTS `view`(\n" .
" `fname` char COLLATE utf-8 DEFAULT NULL COMMENT 'cmt'\n" .
")\n",
$result
);
}
/**
* Test for ExportSql::getTableDef
*
* @return void
* @group medium
*/
public function testGetTableDefWithoutDrizzle()
{
$restoreDrizzle = 'PMANORESTORE';
if (PMA_DRIZZLE) {
if (!PMA_HAS_RUNKIT) {
$this->markTestSkipped(
"Cannot redefine constant. Missing runkit extension"
);
} else {
$restoreDrizzle = PMA_DRIZZLE;
runkit_constant_redefine('PMA_DRIZZLE', false);
}
}
$GLOBALS['sql_compatibility'] = 'MSSQL';
$GLOBALS['sql_auto_increment'] = true;
$GLOBALS['sql_drop_table'] = true;
$GLOBALS['sql_backquotes'] = true;
$GLOBALS['sql_if_not_exists'] = true;
$GLOBALS['sql_include_comments'] = true;
$GLOBALS['crlf'] = "\n";
if (isset($GLOBALS['sql_constraints'])) {
unset($GLOBALS['sql_constraints']);
}
if (isset($GLOBALS['no_constraints_comments'])) {
unset($GLOBALS['no_constraints_comments']);
}
$dbi = $this->getMockBuilder('PMA_DatabaseInterface')
->disableOriginalConstructor()
->getMock();
$dbi->expects($this->at(0))
->method('query')
->with(
'SHOW TABLE STATUS FROM `db` WHERE Name = \'table\'', null,
PMA_DatabaseInterface::QUERY_STORE
)
->will($this->returnValue('res'));
$dbi->expects($this->never())
->method('fetchSingleRow');
$dbi->expects($this->once())
->method('numRows')
->with('res')
->will($this->returnValue(2));
$dbi->expects($this->any())
->method('fetchValue')
->will($this->returnValue(false));
$tmpres = array(
'Auto_increment' => 1,
'Create_time' => '2000-01-01 10:00:00',
'Update_time' => '2000-01-02 12:00:00',
'Check_time' => '2000-01-02 13:00:00',
);
$dbi->expects($this->once())
->method('fetchAssoc')
->with('res')
->will($this->returnValue($tmpres));
$dbi->expects($this->at(5))
->method('query')
->with('SET SQL_QUOTE_SHOW_CREATE = 1')
->will($this->returnValue('res'));
$dbi->expects($this->once())
->method('tryQuery')
->with('SHOW CREATE TABLE `db`.`table`')
->will($this->returnValue('res'));
$row = array(
'',
"CREATE TABLE `db`.`table`,\n CONSTRAINT KEYS \nFOREIGN KEY\n) " .
"unsigned NOT NULL\n(\r\n"
);
$dbi->expects($this->once())
->method('fetchRow')
->with('res')
->will($this->returnValue($row));
$GLOBALS['dbi'] = $dbi;
$GLOBALS['cfg']['Server']['DisableIS'] = false;
$result = $this->object->getTableDef(
'db', 'table', "\n", "example.com/err", true, true, true
);
$this->assertContains(
'-- Creation: Jan 01, 2000 at 10:00 AM',
$result
);
$this->assertContains(
'-- Last update: Jan 02, 2000 at 12:00 PM',
$result
);
$this->assertContains(
'-- Last check: Jan 02, 2000 at 01:00 PM',
$result
);
$this->assertContains(
'DROP TABLE IF EXISTS `table`;',
$result
);
$this->assertContains(
"CREATE TABLE `table`\n",
$result
);
$this->assertContains(
") NOT NULL\n",
$result
);
$this->assertContains(
'-- Constraints for dumped tables',
$GLOBALS['sql_constraints']
);
$this->assertContains(
'-- Constraints for table "table"',
$GLOBALS['sql_constraints']
);
$this->assertContains(
'ALTER TABLE "table"' . "\n",
$GLOBALS['sql_constraints']
);
$this->assertContains(
'ADD CONSTRAINT KEYS ' . "\n",
$GLOBALS['sql_constraints']
);
$this->assertContains(
'ADD FOREIGN KEY;',
$GLOBALS['sql_constraints']
);
$this->assertContains(
'ALTER TABLE "table"' . "\n",
$GLOBALS['sql_constraints_query']
);
$this->assertContains(
' ADD CONSTRAINT KEYS ADD FOREIGN KEY;',
$GLOBALS['sql_constraints_query']
);
$this->assertContains(
'ALTER TABLE "db"."table"' . "\n",
$GLOBALS['sql_drop_foreign_keys']
);
$this->assertContains(
'DROP FOREIGN KEY KEYS',
$GLOBALS['sql_drop_foreign_keys']
);
if ($restoreDrizzle !== "PMANORESTORE") {
runkit_constant_redefine('PMA_DRIZZLE', $restoreDrizzle);
}
}
/**
* Test for ExportSql::getTableDef
*
* @return void
*/
public function testGetTableDefWithDrizzle()
{
$restoreDrizzle = 'PMANORESTORE';
if (!PMA_DRIZZLE) {
if (!PMA_HAS_RUNKIT) {
$this->markTestSkipped(
"Cannot redefine constant. Missing runkit extension"
);
} else {
$restoreDrizzle = PMA_DRIZZLE;
runkit_constant_redefine('PMA_DRIZZLE', true);
}
}
$GLOBALS['sql_auto_increment'] = true;
$GLOBALS['sql_drop_table'] = true;
$GLOBALS['sql_backquotes'] = true;
$GLOBALS['sql_if_not_exists'] = true;
$GLOBALS['sql_include_comments'] = true;
$GLOBALS['crlf'] = "\n";
if (isset($GLOBALS['sql_compatibility'])) {
unset($GLOBALS['sql_compatibility']);
}
if (isset($GLOBALS['sql_constraints'])) {
unset($GLOBALS['sql_constraints']);
}
$GLOBALS['no_constraints_comments'] = true;
$dbi = $this->getMockBuilder('PMA_DatabaseInterface')
->disableOriginalConstructor()
->getMock();
$dbi->expects($this->at(0))
->method('query')
->with(
'SHOW TABLE STATUS FROM `db` WHERE Name = \'table\'', null,
PMA_DatabaseInterface::QUERY_STORE
)
->will($this->returnValue('res'));
$dbi->expects($this->once())
->method('numRows')
->with('res')
->will($this->returnValue(2));
$dbi->expects($this->once())
->method('fetchSingleRow')
->will($this->returnValue(array()));
$dbi->expects($this->any())
->method('fetchValue')
->will($this->returnValue(false));
$tmpres = array(
'Auto_increment' => 1,
'Create_time' => '2000-01-01 10:00:00',
'Update_time' => '2000-01-02 12:00:00',
'Check_time' => '2000-01-02 13:00:00',
);
$dbi->expects($this->once())
->method('fetchAssoc')
->with('res')
->will($this->returnValue($tmpres));
$dbi->expects($this->once())
->method('tryQuery')
->with('SHOW CREATE TABLE `db`.`table`')
->will($this->returnValue('res'));
$row = array(
'',
"CREATE TABLE `db`.`table` ROW_FORMAT='row',\n CONSTRAINT "
. "KEYS \nFOREIGN KEY\n) unsigned NOT NULL\n(\r"
);
$dbi->expects($this->once())
->method('fetchRow')
->with('res')
->will($this->returnValue($row));
$GLOBALS['dbi'] = $dbi;
$GLOBALS['cfg']['Server']['DisableIS'] = false;
$result = $this->object->getTableDef(
'db', 'table', "\n", "example.com/err", true, true, true
);
$this->assertContains(
"CREATE TABLE IF NOT EXISTS `table` ROW_FORMAT=row",
$result
);
$this->assertContains(
") unsigned NOT NULL\n",
$result
);
$this->assertNotContains(
'-- Constraints for table',
$GLOBALS['sql_constraints']
);
$this->assertNotContains(
'-- Constraints for table "table"',
$GLOBALS['sql_constraints']
);
if ($restoreDrizzle !== "PMANORESTORE") {
runkit_constant_redefine('PMA_DRIZZLE', $restoreDrizzle);
}
}
/**
* Test for ExportSql::getTableDef
*
* @return void
*/
public function testGetTableDefWithError()
{
$restoreDrizzle = 'PMANORESTORE';
if (PMA_DRIZZLE) {
if (!PMA_HAS_RUNKIT) {
$this->markTestSkipped(
"Cannot redefine constant. Missing runkit extension"
);
} else {
$restoreDrizzle = PMA_DRIZZLE;
runkit_constant_redefine('PMA_DRIZZLE', false);
}
}
$GLOBALS['sql_compatibility'] = '';
$GLOBALS['sql_auto_increment'] = true;
$GLOBALS['sql_drop_table'] = true;
$GLOBALS['sql_backquotes'] = false;
$GLOBALS['sql_if_not_exists'] = true;
$GLOBALS['sql_include_comments'] = true;
$GLOBALS['crlf'] = "\n";
if (isset($GLOBALS['sql_constraints'])) {
unset($GLOBALS['sql_constraints']);
}
if (isset($GLOBALS['no_constraints_comments'])) {
unset($GLOBALS['no_constraints_comments']);
}
$dbi = $this->getMockBuilder('PMA_DatabaseInterface')
->disableOriginalConstructor()
->getMock();
$dbi->expects($this->at(0))
->method('query')
->with(
'SHOW TABLE STATUS FROM `db` WHERE Name = \'table\'', null,
PMA_DatabaseInterface::QUERY_STORE
)
->will($this->returnValue('res'));
$dbi->expects($this->never())
->method('fetchSingleRow');
$dbi->expects($this->once())
->method('numRows')
->with('res')
->will($this->returnValue(2));
$dbi->expects($this->any())
->method('fetchValue')
->will($this->returnValue(false));
$tmpres = array(
'Auto_increment' => 1,
'Create_time' => '2000-01-01 10:00:00',
'Update_time' => '2000-01-02 12:00:00',
'Check_time' => '2000-01-02 13:00:00',
);
$dbi->expects($this->once())
->method('fetchAssoc')
->with('res')
->will($this->returnValue($tmpres));
$dbi->expects($this->at(5))
->method('query')
->with('SET SQL_QUOTE_SHOW_CREATE = 0')
->will($this->returnValue('res'));
$dbi->expects($this->once())
->method('tryQuery')
->with('SHOW CREATE TABLE `db`.`table`')
->will($this->returnValue('res'));
$dbi->expects($this->once())
->method('getError')
->will($this->returnValue('error occurred'));
$GLOBALS['dbi'] = $dbi;
$GLOBALS['cfg']['Server']['DisableIS'] = false;
$result = $this->object->getTableDef(
'db', 'table', "\n", "example.com/err", true, true, true
);
$this->assertContains(
'-- in use(error occurred)',
$result
);
if ($restoreDrizzle !== "PMANORESTORE") {
runkit_constant_redefine('PMA_DRIZZLE', $restoreDrizzle);
}
}
/**
* Test for ExportSql::_getTableComments
*
* @return void
*/
public function testGetTableComments()
{
$_SESSION['relation'][0] = array(
'relwork' => true,
'commwork' => true,
'mimework' => true,
'db' => 'database',
'relation' => 'rel',
'column_info' => 'col'
);
$GLOBALS['sql_include_comments'] = true;
$GLOBALS['crlf'] = "\n";
$dbi = $this->getMockBuilder('PMA_DatabaseInterface')
->disableOriginalConstructor()
->getMock();
$dbi->expects($this->at(0))
->method('fetchResult')
->will(
$this->returnValue(
array(
'foo' => array(
'foreign_table' => 'ftable',
'foreign_field' => 'ffield'
)
)
)
);
$dbi->expects($this->at(1))
->method('fetchResult')
->will(
$this->returnValue(
array(
'fieldname' => array(
'values' => 'test-',
'transformation' => 'testfoo',
'mimetype' => 'test<'
)
)
)
);
$GLOBALS['dbi'] = $dbi;
$method = new ReflectionMethod('ExportSql', '_getTableComments');
$method->setAccessible(true);
$result = $method->invoke(
$this->object, 'db', '', "\n", true, true
);
$this->assertContains(
"-- MIME TYPES FOR TABLE :\n" .
"-- fieldname\n" .
"-- Test<",
$result
);
$this->assertContains(
"-- RELATIONS FOR TABLE :\n" .
"-- foo\n" .
"-- ftable -> ffield",
$result
);
}
/**
* Test for ExportSql::exportStructure
*
* @return void
* @group medium
*/
public function testExportStructure()
{
$dbi = $this->getMockBuilder('PMA_DatabaseInterface')
->disableOriginalConstructor()
->getMock();
$dbi->expects($this->once())
->method('getTriggers')
->with('db', 't&bl')
->will(
$this->returnValue(
array(
array('create' => 'bar', 'drop' => 'foo')
)
)
);
$this->object = $this->getMockBuilder('ExportSql')
->setMethods(array('getTableDef', 'getTriggers', 'getTableDefStandIn'))
->getMock();
$this->object->expects($this->at(0))
->method('getTableDef')
->with('db', 't&bl', "\n", "example.com", false)
->will($this->returnValue('dumpText1'));
$this->object->expects($this->at(1))
->method('getTableDef')
->with(
'db', 't&bl', "\n", "example.com", false
)
->will($this->returnValue('dumpText3'));
$this->object->expects($this->once())
->method('getTableDefStandIn')
->with('db', 't&bl', "\n")
->will($this->returnValue('dumpText4'));
$GLOBALS['dbi'] = $dbi;
$GLOBALS['sql_compatibility'] = 'MSSQL';
$GLOBALS['sql_backquotes'] = true;
$GLOBALS['sql_include_comments'] = true;
$GLOBALS['crlf'] = "\n";
// case 1
ob_start();
$this->assertTrue(
$this->object->exportStructure(
'db', 't&bl', "\n", "example.com", "create_table", "test"
)
);
$result = ob_get_clean();
$this->assertContains(
'-- Table structure for table "t&bl"',
$result
);
$this->assertContains(
'dumpText1',
$result
);
// case 2
unset($GLOBALS['sql_compatibility']);
unset($GLOBALS['sql_backquotes']);
$GLOBALS['sql_create_trigger'] = true;
$GLOBALS['sql_drop_table'] = true;
ob_start();
$this->assertTrue(
$this->object->exportStructure(
'db', 't&bl', "\n", "example.com", "triggers", "test"
)
);
$result = ob_get_clean();
$this->assertContains(
"-- Triggers t&bl\n",
$result
);
$this->assertContains(
"foo;\nDELIMITER $$\nbarDELIMITER ;\n",
$result
);
unset($GLOBALS['sql_create_trigger']);
unset($GLOBALS['sql_drop_table']);
// case 3
$GLOBALS['sql_views_as_tables'] = false;
ob_start();
$this->assertTrue(
$this->object->exportStructure(
'db', 't&bl', "\n", "example.com", "create_view", "test"
)
);
$result = ob_get_clean();
$this->assertContains(
"-- Structure for view t&bl\n",
$result
);
$this->assertContains(
"DROP TABLE IF EXISTS `t&bl`;\n" .
"dumpText3",
$result
);
// case 4
$dbi = $this->getMockBuilder('PMA_DatabaseInterface')
->disableOriginalConstructor()
->getMock();
$dbi->expects($this->once())
->method('getColumns')
->will(
$this->returnValue(
array()
)
);
$GLOBALS['dbi'] = $dbi;
$GLOBALS['sql_views_as_tables'] = true;
ob_start();
$this->assertTrue(
$this->object->exportStructure(
'db', 't&bl', "\n", "example.com", "create_view", "test"
)
);
$result = ob_get_clean();
$this->assertContains(
"CREATE TABLE`t&bl`(\n\n);",
$result
);
$this->assertContains(
"DROP TABLE IF EXISTS `t&bl`;\n",
$result
);
// case 5
ob_start();
$this->assertTrue(
$this->object->exportStructure(
'db', 't&bl', "\n", "example.com", "stand_in", "test"
)
);
$result = ob_get_clean();
$this->assertContains(
"dumpText4",
$result
);
}
/**
* Test for ExportSql::exportData
*
* @return void
* @group medium
*/
public function testExportData()
{
$dbi = $this->getMockBuilder('PMA_DatabaseInterface')
->disableOriginalConstructor()
->getMock();
$flags = array();
$a = new StdClass;
$a->blob = false;
$a->numeric = true;
$a->type = 'ts';
$a->name = 'name';
$a->length = 2;
$flags[] = $a;
$a = new StdClass;
$a->blob = false;
$a->numeric = true;
$a->type = 'ts';
$a->name = 'name';
$a->length = 2;
$flags[] = $a;
$a = new StdClass;
$a->blob = true;
$a->numeric = false;
$a->type = 'ts';
$a->name = 'name';
$a->length = 2;
$flags[] = $a;
$a = new StdClass;
$a->type = "bit";
$a->blob = false;
$a->numeric = false;
$a->name = 'name';
$a->length = 2;
$flags[] = $a;
$a = new StdClass;
$a->blob = false;
$a->numeric = true;
$a->type = 'timestamp';
$a->name = 'name';
$a->length = 2;
$flags[] = $a;
$dbi->expects($this->once())
->method('getFieldsMeta')
->with('res')
->will($this->returnValue($flags));
$dbi->expects($this->any())
->method('fieldFlags')
->will($this->returnValue('biNAry'));
$dbi->expects($this->once())
->method('tryQuery')
->with(
"SELECT a FROM b WHERE 1",
null,
PMA_DatabaseInterface::QUERY_UNBUFFERED
)
->will($this->returnValue('res'));
$dbi->expects($this->once())
->method('numFields')
->with('res')
->will($this->returnValue(5));
$dbi->expects($this->at(10))
->method('fetchRow')
->with('res')
->will(
$this->returnValue(
array(null, 'test', '10', '6', "\x00\x0a\x0d\x1a")
)
);
$GLOBALS['dbi'] = $dbi;
$GLOBALS['sql_compatibility'] = 'MSSQL';
$GLOBALS['sql_backquotes'] = true;
$GLOBALS['sql_views_as_tables'] = true;
$GLOBALS['sql_type'] = 'INSERT';
$GLOBALS['sql_delayed'] = ' DELAYED';
$GLOBALS['sql_ignore'] = true;
$GLOBALS['sql_truncate'] = true;
$GLOBALS['sql_insert_syntax'] = 'both';
$GLOBALS['sql_hex_for_binary'] = true;
$GLOBALS['cfg']['Server']['DisableIS'] = false;
ob_start();
$this->object->exportData(
'db', 'table', "\n", "example.com/err",
"SELECT a FROM b WHERE 1"
);
$result = ob_get_clean();
$this->assertContains(
'TRUNCATE TABLE "table";',
$result
);
$this->assertContains(
'SET IDENTITY_INSERT "table" ON ;',
$result
);
$this->assertContains(
'INSERT DELAYED IGNORE INTO "table" ("name", ' .
'"name", "name", "name", ' .
'"name") VALUES',
$result
);
$this->assertContains(
'(NULL, test, 0x3130, 0x36, 0x000a0d1a);',
$result
);
$this->assertContains(
"SET IDENTITY_INSERT "table" OFF;",
$result
);
}
/**
* Test for ExportSql::exportData
*
* @return void
* @group medium
*/
public function testExportDataWithUpdate()
{
$dbi = $this->getMockBuilder('PMA_DatabaseInterface')
->disableOriginalConstructor()
->getMock();
$flags = array();
$a = new StdClass;
$a->blob = false;
$a->numeric = true;
$a->type = 'real';
$a->name = 'name';
$a->length = 2;
$a->table = 'tbl';
$a->orgname = 'pma';
$a->primary_key = 1;
$flags[] = $a;
$a = new StdClass;
$a->blob = false;
$a->numeric = true;
$a->type = '';
$a->name = 'name';
$a->table = 'tbl';
$a->orgname = 'pma';
$a->length = 2;
$a->primary_key = 0;
$a->unique_key = 1;
$flags[] = $a;
$dbi->expects($this->once())
->method('getFieldsMeta')
->with('res')
->will($this->returnValue($flags));
$dbi->expects($this->any())
->method('fieldFlags')
->will($this->returnValue('biNAry'));
$dbi->expects($this->once())
->method('tryQuery')
->with(
"SELECT a FROM b WHERE 1",
null,
PMA_DatabaseInterface::QUERY_UNBUFFERED
)
->will($this->returnValue('res'));
$dbi->expects($this->once())
->method('numFields')
->with('res')
->will($this->returnValue(2));
$dbi->expects($this->at(7))
->method('fetchRow')
->with('res')
->will(
$this->returnValue(
array(null, null)
)
);
$GLOBALS['dbi'] = $dbi;
$GLOBALS['sql_compatibility'] = 'MSSQL';
$GLOBALS['sql_backquotes'] = true;
$GLOBALS['sql_views_as_tables'] = true;
$GLOBALS['sql_type'] = 'UPDATE';
$GLOBALS['sql_delayed'] = ' DELAYED';
$GLOBALS['sql_ignore'] = true;
$GLOBALS['sql_truncate'] = true;
$GLOBALS['sql_insert_syntax'] = 'both';
$GLOBALS['sql_hex_for_binary'] = true;
$GLOBALS['cfg']['Server']['DisableIS'] = false;
ob_start();
$this->object->exportData(
'db', 'table', "\n", "example.com/err",
"SELECT a FROM b WHERE 1"
);
$result = ob_get_clean();
$this->assertContains(
'UPDATE IGNORE "table" SET "name" = NULL,' .
'"name" = NULL WHERE CONCAT(`tbl`.`pma`) IS NULL;',
$result
);
}
/**
* Test for ExportSql::exportData
*
* @return void
*/
public function testExportDataWithIsView()
{
$dbi = $this->getMockBuilder('PMA_DatabaseInterface')
->disableOriginalConstructor()
->getMock();
$dbi->expects($this->once())
->method('fetchResult')
->will($this->returnValue(true));
$GLOBALS['dbi'] = $dbi;
$GLOBALS['cfg']['Server']['DisableIS'] = false;
$GLOBALS['sql_views_as_tables'] = false;
$GLOBALS['sql_include_comments'] = true;
$GLOBALS['crlf'] = "\n";
ob_start();
$this->assertTrue(
$this->object->exportData('db', 'tbl', "\n", "err.com", "SELECT")
);
$result = ob_get_clean();
$this->assertContains(
"-- VIEW tbl\n",
$result
);
$this->assertContains(
"-- Data: None\n",
$result
);
}
/**
* Test for ExportSql::exportData
*
* @return void
*/
public function testExportDataWithError()
{
$dbi = $this->getMockBuilder('PMA_DatabaseInterface')
->disableOriginalConstructor()
->getMock();
$dbi->expects($this->once())
->method('getError')
->will($this->returnValue('err'));
$GLOBALS['dbi'] = $dbi;
$GLOBALS['cfg']['Server']['DisableIS'] = false;
$GLOBALS['sql_views_as_tables'] = true;
$GLOBALS['sql_include_comments'] = true;
$GLOBALS['crlf'] = "\n";
ob_start();
$this->assertTrue(
$this->object->exportData('db', 'table', "\n", "err.com", "SELECT")
);
$result = ob_get_clean();
$this->assertContains(
"-- Error reading data: (err)\n",
$result
);
}
/**
* Test for ExportSql::_makeCreateTableMSSQLCompatible
*
* @return void
*/
public function testMakeCreateTableMSSQLCompatible()
{
$query = "CREATE TABLE IF NOT EXISTS (\" date DEFAULT NULL,\n" .
"\" date DEFAULT NULL\n\" date NOT NULL,\n\" date NOT NULL\n," .
" \" date NOT NULL DEFAULT 'asd'," .
" ) unsigned NOT NULL\n, ) unsigned NOT NULL,\n" .
" ) unsigned DEFAULT NULL\n, ) unsigned DEFAULT NULL,\n" .
" ) unsigned NOT NULL DEFAULT 'dsa',\n" .
" \" int(10) DEFAULT NULL,\n" .
" \" tinyint(0) DEFAULT NULL\n" .
" \" smallint(10) NOT NULL,\n" .
" \" bigint(0) NOT NULL\n" .
" \" bigint(0) NOT NULL DEFAULT '12'\n" .
" \" float(22,2,) DEFAULT NULL,\n" .
" \" double DEFAULT NULL\n" .
" \" float(22,2,) NOT NULL,\n" .
" \" double NOT NULL\n" .
" \" double NOT NULL DEFAULT '213'\n";
$method = new ReflectionMethod(
'ExportSql', '_makeCreateTableMSSQLCompatible'
);
$method->setAccessible(true);
$result = $method->invoke(
$this->object, $query
);
$this->assertEquals(
"CREATE TABLE (\" datetime DEFAULT NULL,\n" .
"\" datetime DEFAULT NULL\n" .
"\" datetime NOT NULL,\n" .
"\" datetime NOT NULL\n" .
", \" datetime NOT NULL DEFAULT 'asd', ) NOT NULL\n" .
", ) NOT NULL,\n" .
" ) DEFAULT NULL\n" .
", ) DEFAULT NULL,\n" .
" ) NOT NULL DEFAULT 'dsa',\n" .
" \" int DEFAULT NULL,\n" .
" \" tinyint DEFAULT NULL\n" .
" \" smallint NOT NULL,\n" .
" \" bigint NOT NULL\n" .
" \" bigint NOT NULL DEFAULT '12'\n" .
" \" float DEFAULT NULL,\n" .
" \" float DEFAULT NULL\n" .
" \" float NOT NULL,\n" .
" \" float NOT NULL\n" .
" \" float NOT NULL DEFAULT '213'\n",
$result
);
}
/**
* Test for ExportSql::initAlias
*
* @return void
*/
public function testInitAlias()
{
$aliases = array(
'a' => array(
'alias' => 'aliastest',
'tables' => array(
'foo' => array(
'alias' => 'qwerty'
),
'bar' => array(
'alias' => 'f'
)
)
)
);
$db = 'a';
$table = null;
$this->object->initAlias($aliases, $db, $table);
$this->assertEquals('aliastest', $db);
$this->assertNull($table);
$db = 'foo';
$table = 'qwerty';
$this->object->initAlias($aliases, $db, $table);
$this->assertEquals('foo', $db);
$this->assertEquals('qwerty', $table);
$db = 'a';
$table = 'foo';
$this->object->initAlias($aliases, $db, $table);
$this->assertEquals('aliastest', $db);
$this->assertEquals('qwerty', $table);
}
/**
* Test for ExportSql::getAlias
*
* @return void
*/
public function testGetAlias()
{
$aliases = array(
'a' => array(
'alias' => 'aliastest',
'tables' => array(
'foo' => array(
'alias' => 'qwerty',
'columns' => array(
'baz' => 'p',
'pqr' => 'pphymdain'
)
),
'bar' => array(
'alias' => 'f',
'columns' => array(
'xy' => 'n'
)
)
)
)
);
$this->assertEquals(
'f', $this->object->getAlias($aliases, 'bar')
);
$this->assertEquals(
'aliastest', $this->object->getAlias($aliases, 'a')
);
$this->assertEquals(
'pphymdain', $this->object->getAlias($aliases, 'pqr')
);
$this->assertEquals(
'', $this->object->getAlias($aliases, 'abc')
);
}
/**
* Test for ExportSql::substituteAlias
*
* @return void
*/
public function testSubstituteAlias()
{
$GLOBALS['sql_backquotes'] = '`';
$sql_query = 'CREATE TABLE `data` ( xyz int )';
$data = '`data`';
$alias = 'sample';
$pos = 19;
$offset = 0;
$result =$this->object->substituteAlias(
$sql_query, $data, $alias, $pos, $offset
);
$this->assertEquals(
'CREATE TABLE `sample` ( xyz int )',
$result
);
$this->assertEquals(2, $offset);
$GLOBALS['sql_backquotes'] = false;
$result =$this->object->substituteAlias(
$sql_query, $data, $alias, $pos
);
$this->assertEquals(
'CREATE TABLE sample ( xyz int )',
$result
);
$GLOBALS['sql_backquotes'] = '`';
$sql_query = 'CREATE TABLE `sample` ( qwerty int )';
$data = 'qwerty';
$alias = 'f';
$offset = 2;
$pos = 28 + 2;
$result =$this->object->substituteAlias(
$sql_query, $data, $alias, $pos, $offset
);
$this->assertEquals(
'CREATE TABLE `sample` ( `f` int )',
$result
);
$this->assertEquals(-1, $offset);
}
/**
* Test for ExportSql::replaceWithAlias
*
* @return void
*/
public function testReplaceWithAlias()
{
$aliases = array(
'a' => array(
'alias' => 'aliastest',
'tables' => array(
'foo' => array(
'alias' => 'bartest',
'columns' => array(
'baz' => 'p',
'pqr' => 'pphymdain'
)
),
'bar' => array(
'alias' => 'f',
'columns' => array(
'xy' => 'n'
)
)
)
)
);
$GLOBALS['sql_backquotes'] = '`';
$db = 'a';
$table = 'foo';
$sql_query = "CREATE TABLE IF NOT EXISTS foo ("
. "baz tinyint(3) unsigned NOT NULL COMMENT 'Primary Key',"
. "xyz varchar(255) COLLATE latin1_general_ci NOT NULL "
. "COMMENT 'xyz',"
. "pqr varchar(10) COLLATE latin1_general_ci NOT NULL "
. "COMMENT 'pqr',"
. "CONSTRAINT fk_om_dept FOREIGN KEY (baz) "
. "REFERENCES dept_master (baz),"
. ") ENGINE=InnoDB DEFAULT CHARSET=latin1 COLLATE="
. "latin1_general_ci COMMENT='List' AUTO_INCREMENT=5";
$result = $this->object->replaceWithAliases(
$sql_query, $aliases, $db, $table
);
$this->assertEquals(
"CREATE TABLE IF NOT EXISTS `bartest` ("
. "`p` tinyint(3) unsigned NOT NULL COMMENT 'Primary Key',"
. "xyz varchar(255) COLLATE latin1_general_ci NOT NULL "
. "COMMENT 'xyz',"
. "`pphymdain` varchar(10) COLLATE latin1_general_ci NOT NULL "
. "COMMENT 'pqr',"
. "CONSTRAINT fk_om_dept FOREIGN KEY (`p`) "
. "REFERENCES dept_master (baz),"
. ") ENGINE=InnoDB DEFAULT CHARSET=latin1 COLLATE="
. "latin1_general_ci COMMENT='List' AUTO_INCREMENT=5",
$result
);
$result = $this->object->replaceWithAliases($sql_query, array(), '', '');
$this->assertEquals(
"CREATE TABLE IF NOT EXISTS foo ("
. "baz tinyint(3) unsigned NOT NULL COMMENT 'Primary Key',"
. "xyz varchar(255) COLLATE latin1_general_ci NOT NULL "
. "COMMENT 'xyz',"
. "pqr varchar(10) COLLATE latin1_general_ci NOT NULL "
. "COMMENT 'pqr',"
. "CONSTRAINT fk_om_dept FOREIGN KEY (baz) "
. "REFERENCES dept_master (baz),"
. ") ENGINE=InnoDB DEFAULT CHARSET=latin1 COLLATE="
. "latin1_general_ci COMMENT='List' AUTO_INCREMENT=5",
$result
);
$GLOBALS['sql_backquotes'] = null;
$table = 'bar';
$sql_query = "CREATE TRIGGER `BEFORE_bar_INSERT` "
. "BEFORE INSERT ON `bar`\r\n"
. "FOR EACH ROW BEGIN\r\n"
. "SET @cnt=(SELECT count(*) FROM bar WHERE "
. "xy=NEW.xy AND id=NEW.id AND "
. "abc=NEW.xy LIMIT 1);\r\n"
. "IF @cnt<>0 THEN\n"
. "SET NEW.xy=1;\r\n"
. "END IF;\nEND\n$$";
$result = $this->object->replaceWithAliases(
$sql_query, $aliases, $db, $table
);
$this->assertEquals(
"CREATE TRIGGER `BEFORE_bar_INSERT` "
. "BEFORE INSERT ON f\n"
. "FOR EACH ROW BEGIN\n"
. "SET @cnt=(SELECT count(*) FROM f WHERE "
. "n=NEW.n AND id=NEW.id AND "
. "abc=NEW.n LIMIT 1);\n"
. "IF @cnt<>0 THEN\n"
. "SET NEW.n=1;\n"
. "END IF;\nEND\n$$",
$result
);
}
}
?>