532 lines
16 KiB
PHP
532 lines
16 KiB
PHP
<?php
|
|
/* vim: set expandtab sw=4 ts=4 sts=4: */
|
|
/**
|
|
* tests for normalization.lib.php
|
|
*
|
|
* @package PhpMyAdmin-test
|
|
*/
|
|
|
|
/*
|
|
* Include to test.
|
|
*/
|
|
use PMA\libraries\Theme;
|
|
use PMA\libraries\TypesMySQL;
|
|
|
|
$GLOBALS['server'] = 1;
|
|
|
|
require_once 'libraries/database_interface.inc.php';
|
|
|
|
require_once 'libraries/relation.lib.php';
|
|
|
|
require_once 'libraries/url_generating.lib.php';
|
|
|
|
|
|
require_once 'libraries/mysql_charsets.inc.php';
|
|
require_once 'libraries/normalization.lib.php';
|
|
|
|
|
|
/**
|
|
* tests for normalization.lib.php
|
|
*
|
|
* @package PhpMyAdmin-test
|
|
*/
|
|
class PMA_Normalization_Test extends PHPUnit_Framework_TestCase
|
|
{
|
|
/**
|
|
* prepares environment for tests
|
|
*
|
|
* @return void
|
|
*/
|
|
public function setUp()
|
|
{
|
|
$GLOBALS['cfg']['LimitChars'] = 50;
|
|
$GLOBALS['PMA_Types'] = new TypesMySQL();
|
|
$GLOBALS['cfg']['ServerDefault'] = "PMA_server";
|
|
$GLOBALS['pmaThemeImage'] = 'image';
|
|
$GLOBALS['cfg']['ShowHint'] = true;
|
|
$GLOBALS['cfg']['CharEditing'] = '';
|
|
$GLOBALS['cfg']['ActionLinksMode'] = 'icons';
|
|
$GLOBALS['db'] = 'PMA_db';
|
|
$GLOBALS['table'] = 'PMA_table';
|
|
$GLOBALS['server'] = 1;
|
|
|
|
//$_SESSION
|
|
$_SESSION['PMA_Theme'] = Theme::load('./themes/pmahomme');
|
|
$_SESSION['PMA_Theme'] = new Theme();
|
|
|
|
//mock DBI
|
|
$dbi = $this->getMockBuilder('PMA\libraries\DatabaseInterface')
|
|
->disableOriginalConstructor()
|
|
->getMock();
|
|
$GLOBALS['dbi'] = $dbi;
|
|
// set expectations
|
|
$dbi->expects($this->any())
|
|
->method('selectDb')
|
|
->will($this->returnValue(true));
|
|
$dbi->expects($this->any())
|
|
->method('getColumns')
|
|
->will(
|
|
$this->returnValue(
|
|
array(
|
|
"id"=>array("Type"=>"integer"),
|
|
"col1"=>array("Type"=>'varchar(100)'),
|
|
"col2"=>array("Type"=>'DATETIME')
|
|
)
|
|
)
|
|
);
|
|
$dbi->expects($this->any())
|
|
->method('getColumnNames')
|
|
->will($this->returnValue(array("id", "col1", "col2")));
|
|
$map = array(
|
|
array('PMA_db', 'PMA_table1', null, array()),
|
|
array(
|
|
'PMA_db', 'PMA_table', null,
|
|
array(array('Key_name'=>'PRIMARY', 'Column_name'=>'id'))
|
|
),
|
|
array(
|
|
'PMA_db', 'PMA_table2', null,
|
|
array(
|
|
array('Key_name'=>'PRIMARY', 'Column_name'=>'id'),
|
|
array('Key_name'=>'PRIMARY', 'Column_name'=>'col1')
|
|
)
|
|
),
|
|
);
|
|
$dbi->expects($this->any())
|
|
->method('getTableIndexes')
|
|
->will($this->returnValueMap($map));
|
|
$dbi->expects($this->any())
|
|
->method('tryQuery')
|
|
->will($this->returnValue(true));
|
|
$dbi->expects($this->any())
|
|
->method('fetchResult')
|
|
->will($this->returnValue(array(0)));
|
|
|
|
}
|
|
|
|
/**
|
|
* Test for PMA_getHtmlForColumnsList
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testPMAGetHtmlForColumnsList()
|
|
{
|
|
$db = "PMA_db";
|
|
$table= "PMA_table";
|
|
$this->assertContains(
|
|
'<option value="id">id [ integer ]</option>',
|
|
PMA_getHtmlForColumnsList($table, $db)
|
|
);
|
|
$this->assertEquals(
|
|
'<input type="checkbox" value="col1"/>col1 [ varchar(100) ]</br>',
|
|
PMA_getHtmlForColumnsList($table, $db, 'String', 'checkbox')
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Test for PMA_getHtmlForCreateNewColumn
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testPMAGetHtmlForCreateNewColumn()
|
|
{
|
|
$db = "PMA_db";
|
|
$table= "PMA_table";
|
|
$num_fields = 1;
|
|
$result = PMA_getHtmlForCreateNewColumn($num_fields, $db, $table);
|
|
$this->assertContains(
|
|
'<table id="table_columns"',
|
|
$result
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Test for PMA_getHtmlFor1NFStep1
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testPMAGetHtmlFor1NFStep1()
|
|
{
|
|
$db = "PMA_db";
|
|
$table= "PMA_table";
|
|
$normalizedTo = '1nf';
|
|
$result = PMA_getHtmlFor1NFStep1($db, $table, $normalizedTo);
|
|
$this->assertContains(
|
|
"<h3 class='center'>"
|
|
. __('First step of normalization (1NF)') . "</h3>",
|
|
$result
|
|
);
|
|
$this->assertContains(
|
|
"<div id='mainContent'",
|
|
$result
|
|
);
|
|
$this->assertContains("<legend>" . __('Step 1.'), $result);
|
|
|
|
$this->assertContains(
|
|
'<h4',
|
|
$result
|
|
);
|
|
|
|
$this->assertContains(
|
|
'<p',
|
|
$result
|
|
);
|
|
|
|
$this->assertContains(
|
|
"<select id='selectNonAtomicCol'",
|
|
$result
|
|
);
|
|
|
|
$this->assertContains(
|
|
PMA_getHtmlForColumnsList(
|
|
$db, $table, _pgettext('string types', 'String')
|
|
), $result
|
|
);
|
|
|
|
}
|
|
|
|
/**
|
|
* Test for PMA_getHtmlContentsFor1NFStep2
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testPMAGetHtmlContentsFor1NFStep2()
|
|
{
|
|
$db = "PMA_db";
|
|
$table= "PMA_table1";
|
|
$result = PMA_getHtmlContentsFor1NFStep2($db, $table);
|
|
$this->assertInternalType('array', $result);
|
|
$this->assertArrayHasKey('legendText', $result);
|
|
$this->assertArrayHasKey('headText', $result);
|
|
$this->assertArrayHasKey('subText', $result);
|
|
$this->assertArrayHasKey('hasPrimaryKey', $result);
|
|
$this->assertArrayHasKey('extra', $result);
|
|
$this->assertContains(
|
|
'<a href="#" id="createPrimaryKey">',
|
|
$result['subText']
|
|
);
|
|
$this->assertContains(
|
|
'<a href="#" id="addNewPrimary">',
|
|
$result['extra']
|
|
);
|
|
$this->assertEquals('0', $result['hasPrimaryKey']);
|
|
$this->assertContains(__('Step 1.') . 2, $result['legendText']);
|
|
$result1 = PMA_getHtmlContentsFor1NFStep2($db, 'PMA_table');
|
|
$this->assertEquals('1', $result1['hasPrimaryKey']);
|
|
}
|
|
|
|
/**
|
|
* Test for PMA_getHtmlContentsFor1NFStep4
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testPMAGetHtmlContentsFor1NFStep4()
|
|
{
|
|
$db = "PMA_db";
|
|
$table= "PMA_table";
|
|
$result = PMA_getHtmlContentsFor1NFStep4($db, $table);
|
|
$this->assertInternalType('array', $result);
|
|
$this->assertArrayHasKey('legendText', $result);
|
|
$this->assertArrayHasKey('headText', $result);
|
|
$this->assertArrayHasKey('subText', $result);
|
|
$this->assertArrayHasKey('extra', $result);
|
|
$this->assertContains(__('Step 1.') . 4, $result['legendText']);
|
|
$this->assertContains(
|
|
PMA_getHtmlForColumnsList($db, $table, 'all', "checkbox"),
|
|
$result['extra']
|
|
);
|
|
$this->assertContains(
|
|
'<input type="submit" id="removeRedundant"',
|
|
$result['extra']
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Test for PMA_getHtmlContentsFor1NFStep3
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testPMAGetHtmlContentsFor1NFStep3()
|
|
{
|
|
$db = "PMA_db";
|
|
$table= "PMA_table";
|
|
$result = PMA_getHtmlContentsFor1NFStep3($db, $table);
|
|
$this->assertInternalType('array', $result);
|
|
$this->assertArrayHasKey('legendText', $result);
|
|
$this->assertArrayHasKey('headText', $result);
|
|
$this->assertArrayHasKey('subText', $result);
|
|
$this->assertArrayHasKey('extra', $result);
|
|
$this->assertArrayHasKey('primary_key', $result);
|
|
$this->assertContains(__('Step 1.') . 3, $result['legendText']);
|
|
$this->assertContains(
|
|
PMA_getHtmlForColumnsList($db, $table, 'all', "checkbox"),
|
|
$result['extra']
|
|
);
|
|
$this->assertContains(
|
|
'<input type="submit" id="moveRepeatingGroup"',
|
|
$result['extra']
|
|
);
|
|
$this->assertEquals(json_encode(array('id')), $result['primary_key']);
|
|
}
|
|
|
|
/**
|
|
* Test for PMA_getHtmlFor2NFstep1
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testPMAGetHtmlFor2NFstep1()
|
|
{
|
|
$db = "PMA_db";
|
|
$table= "PMA_table";
|
|
$result = PMA_getHtmlFor2NFstep1($db, $table);
|
|
$this->assertInternalType('array', $result);
|
|
$this->assertArrayHasKey('legendText', $result);
|
|
$this->assertArrayHasKey('headText', $result);
|
|
$this->assertArrayHasKey('subText', $result);
|
|
$this->assertArrayHasKey('extra', $result);
|
|
$this->assertArrayHasKey('primary_key', $result);
|
|
$this->assertContains(__('Step 2.') . 1, $result['legendText']);
|
|
$this->assertEquals('id', $result['primary_key']);
|
|
$result1 = PMA_getHtmlFor2NFstep1($db, "PMA_table2");
|
|
$this->assertEquals('id, col1', $result1['primary_key']);
|
|
$this->assertContains(
|
|
'<a href="#" id="showPossiblePd"',
|
|
$result1['headText']
|
|
);
|
|
$this->assertContains(
|
|
'<input type="checkbox" name="pd" value="id"',
|
|
$result1['extra']
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Test for PMA_getHtmlForNewTables2NF
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testPMAGetHtmlForNewTables2NF()
|
|
{
|
|
$table= "PMA_table";
|
|
$partialDependencies = array('col1'=>array('col2'));
|
|
$result = PMA_getHtmlForNewTables2NF($partialDependencies, $table);
|
|
$this->assertContains(
|
|
'<input type="text" name="col1"',
|
|
$result
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Test for PMA_createNewTablesFor2NF
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testPMACreateNewTablesFor2NF()
|
|
{
|
|
$table= "PMA_table";
|
|
$db = 'PMA_db';
|
|
$tablesName = new stdClass();
|
|
$tablesName->id = 'PMA_table';
|
|
$tablesName->col1 = 'PMA_table1';
|
|
$partialDependencies = array('id'=>array('col2'));
|
|
$result = PMA_createNewTablesFor2NF(
|
|
$partialDependencies, $tablesName, $table, $db
|
|
);
|
|
$this->assertInternalType('array', $result);
|
|
$this->assertArrayHasKey('legendText', $result);
|
|
$this->assertArrayHasKey('headText', $result);
|
|
$this->assertArrayHasKey('queryError', $result);
|
|
$partialDependencies = array('id'=>array('col2'), 'col1'=>array('col2'));
|
|
$result1 = PMA_createNewTablesFor2NF(
|
|
$partialDependencies, $tablesName, $table, $db
|
|
);
|
|
$this->assertArrayHasKey('extra', $result1);
|
|
$this->assertEquals(__('End of step'), $result1['legendText']);
|
|
$this->assertEquals('', $result1['extra']);
|
|
}
|
|
|
|
/**
|
|
* Test for PMA_getHtmlForNewTables3NF
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testPMAGetHtmlForNewTables3NF()
|
|
{
|
|
$tables= array("PMA_table"=>array('col1'));
|
|
$db = 'PMA_db';
|
|
$dependencies = new stdClass();
|
|
$dependencies->col1 = array('col2');
|
|
$result = PMA_getHtmlForNewTables3NF($dependencies, $tables, $db);
|
|
$this->assertEquals(
|
|
array(
|
|
'html' => '',
|
|
'newTables' => array()
|
|
), $result
|
|
);
|
|
$tables= array("PMA_table"=>array('col1', 'PMA_table'));
|
|
$dependencies->PMA_table = array('col4', 'col5');
|
|
$result1 = PMA_getHtmlForNewTables3NF($dependencies, $tables, $db);
|
|
$this->assertInternalType('array', $result1);
|
|
$this->assertContains(
|
|
'<input type="text" name="PMA_table"',
|
|
$result1['html']
|
|
);
|
|
$this->assertEquals(
|
|
array(
|
|
'PMA_table' => array (
|
|
'PMA_table' => array (
|
|
'pk' => 'col1',
|
|
'nonpk' => 'col2'
|
|
),
|
|
'table2' => array (
|
|
'pk' => 'id',
|
|
'nonpk' => 'col4, col5'
|
|
)
|
|
)
|
|
), $result1['newTables']
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Test for PMA_createNewTablesFor3NF
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testPMACreateNewTablesFor3NF()
|
|
{
|
|
$db = 'PMA_db';
|
|
$cols = new stdClass();
|
|
$cols->pk = 'id';
|
|
$cols->nonpk = 'col1, col2';
|
|
$cols1 = new stdClass();
|
|
$cols1->pk = 'col2';
|
|
$cols1->nonpk = 'col3, col4';
|
|
$newTables = array('PMA_table'=>array('PMA_table'=>$cols, 'table1'=>$cols1));
|
|
$result = PMA_createNewTablesFor3NF(
|
|
$newTables, $db
|
|
);
|
|
$this->assertInternalType('array', $result);
|
|
$this->assertArrayHasKey('legendText', $result);
|
|
$this->assertArrayHasKey('headText', $result);
|
|
$this->assertArrayHasKey('queryError', $result);
|
|
$newTables1 = array();
|
|
$result1 = PMA_createNewTablesFor3NF(
|
|
$newTables1, $db
|
|
);
|
|
$this->assertArrayHasKey('queryError', $result1);
|
|
$this->assertEquals(__('End of step'), $result1['legendText']);
|
|
$this->assertEquals(false, $result1['queryError']);
|
|
}
|
|
|
|
/**
|
|
* Test for PMA_moveRepeatingGroup
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testPMAMoveRepeatingGroup()
|
|
{
|
|
$repeatingColumns = 'col1, col2';
|
|
$primary_columns = 'id,col1';
|
|
$newTable = 'PMA_newTable';
|
|
$newColumn = 'PMA_newCol';
|
|
$table= "PMA_table";
|
|
$db = 'PMA_db';
|
|
$result = PMA_moveRepeatingGroup(
|
|
$repeatingColumns, $primary_columns, $newTable, $newColumn, $table, $db
|
|
);
|
|
$this->assertInternalType('array', $result);
|
|
$this->assertArrayHasKey('queryError', $result);
|
|
$this->assertArrayHasKey('message', $result);
|
|
$this->assertInstanceOf(
|
|
'PMA\libraries\Message', $result['message']
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Test for PMA_getHtmlFor3NFstep1
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testPMAGetHtmlFor3NFstep1()
|
|
{
|
|
$db = "PMA_db";
|
|
$tables= array("PMA_table");
|
|
$result = PMA_getHtmlFor3NFstep1($db, $tables);
|
|
$this->assertInternalType('array', $result);
|
|
$this->assertArrayHasKey('legendText', $result);
|
|
$this->assertArrayHasKey('headText', $result);
|
|
$this->assertArrayHasKey('subText', $result);
|
|
$this->assertArrayHasKey('extra', $result);
|
|
$this->assertContains(__('Step 3.') . 1, $result['legendText']);
|
|
$this->assertContains(
|
|
'<form',
|
|
$result['extra']
|
|
);
|
|
$this->assertContains(
|
|
'<input type="checkbox" name="pd" value="col1"',
|
|
$result['extra']
|
|
);
|
|
$result1 = PMA_getHtmlFor3NFstep1($db, array("PMA_table2"));
|
|
$this->assertEquals(
|
|
'', $result1['subText']
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Test for PMA_getHtmlForNormalizetable
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testPMAGetHtmlForNormalizetable()
|
|
{
|
|
$result = PMA_getHtmlForNormalizetable();
|
|
$this->assertContains(
|
|
'<form method="post" action="normalization.php"'
|
|
. ' name="normalize" id="normalizeTable"',
|
|
$result
|
|
);
|
|
$this->assertContains(
|
|
'<input type="hidden" name="step1" value="1">', $result
|
|
);
|
|
$choices = array(
|
|
'1nf' => __('First step of normalization (1NF)'),
|
|
'2nf' => __('Second step of normalization (1NF+2NF)'),
|
|
'3nf' => __('Third step of normalization (1NF+2NF+3NF)'));
|
|
|
|
$html_tmp = PMA\libraries\Util::getRadioFields(
|
|
'normalizeTo', $choices, '1nf', true
|
|
);
|
|
$this->assertContains($html_tmp, $result);
|
|
}
|
|
|
|
/**
|
|
* Test for PMA_findPartialDependencies
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testPMAFindPartialDependencies()
|
|
{
|
|
$table= "PMA_table2";
|
|
$db = 'PMA_db';
|
|
$result = PMA_findPartialDependencies($table, $db);
|
|
$this->assertContains(
|
|
'<div class="dependencies_box"',
|
|
$result
|
|
);
|
|
$this->assertContains(__('No partial dependencies found!'), $result);
|
|
}
|
|
|
|
/**
|
|
* Test for PMA_getAllCombinationPartialKeys
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testPMAGetAllCombinationPartialKeys()
|
|
{
|
|
$primaryKey = array('id', 'col1', 'col2');
|
|
$result = PMA_getAllCombinationPartialKeys($primaryKey);
|
|
$this->assertEquals(
|
|
array('', 'id', 'col1', 'col1,id', 'col2', 'col2,id', 'col2,col1'),
|
|
$result
|
|
);
|
|
}
|
|
}
|