'db', 'server' => 1 ); $dbi = $this->getMockBuilder('PMA\libraries\DatabaseInterface') ->disableOriginalConstructor() ->getMock(); $indexs = array( array( "Schema" => "Schema1", "Key_name"=>"Key_name1", "Column_name"=>"Column_name1" ), array( "Schema" => "Schema2", "Key_name"=>"Key_name2", "Column_name"=>"Column_name2" ), array( "Schema" => "Schema3", "Key_name"=>"Key_name3", "Column_name"=>"Column_name3" ), ); $dbi->expects($this->any())->method('getTableIndexes') ->will($this->returnValue($indexs)); $GLOBALS['dbi'] = $dbi; //$_SESSION $_SESSION['PMA_Theme'] = Theme::load('./themes/pmahomme'); $_SESSION['PMA_Theme'] = new Theme(); } /** * Tests for doSaveDataAction() method * * @return void * @test */ public function testDoSaveDataAction() { $sql_query = 'ALTER TABLE `db`.`table` DROP PRIMARY KEY, ADD UNIQUE ;'; $table = $this->getMockBuilder('PMA\libraries\Table') ->disableOriginalConstructor() ->getMock(); $table->expects($this->any())->method('getSqlQueryForIndexCreateOrEdit') ->will($this->returnValue($sql_query)); $GLOBALS['dbi']->expects($this->any())->method('getTable') ->will($this->returnValue($table)); $container = Container::getDefaultContainer(); $container->set('db', 'db'); $container->set('table', 'table'); $container->set('dbi', $GLOBALS['dbi']); $response = new \PMA\Test\Stubs\Response(); $container->set('PMA\libraries\Response', $response); $container->alias('response', 'PMA\libraries\Response'); $ctrl = new TableIndexesController(null); // Preview SQL $_REQUEST['preview_sql'] = true; $ctrl->doSaveDataAction(); $jsonArray = $response->getJSONResult(); $this->assertArrayHasKey('sql_data', $jsonArray); $this->assertContains( $sql_query, $jsonArray['sql_data'] ); // Alter success $response->clear(); unset($_REQUEST['preview_sql']); $GLOBALS['is_ajax_request'] = true; $ctrl->doSaveDataAction(); $jsonArray = $response->getJSONResult(); $this->assertArrayHasKey('index_table', $jsonArray); $this->assertArrayHasKey('message', $jsonArray); } /** * Tests for displayFormAction() * * @return void * @test */ public function testDisplayFormAction() { $table = $this->getMockBuilder('PMA\libraries\Table') ->disableOriginalConstructor() ->getMock(); $table->expects($this->any())->method('getStatusInfo') ->will($this->returnValue("")); $table->expects($this->any())->method('isView') ->will($this->returnValue(false)); $table->expects($this->any())->method('getNameAndTypeOfTheColumns') ->will($this->returnValue(array("field_name" => "field_type"))); $GLOBALS['dbi']->expects($this->any())->method('getTable') ->will($this->returnValue($table)); $container = Container::getDefaultContainer(); $container->set('db', 'db'); $container->set('table', 'table'); $container->set('dbi', $GLOBALS['dbi']); $response = new \PMA\Test\Stubs\Response(); $container->set('PMA\libraries\Response', $response); $container->alias('response', 'PMA\libraries\Response'); $index = new PMA\libraries\Index(); $ctrl = new TableIndexesController($index); $_REQUEST['create_index'] = true; $_REQUEST['added_fields'] = 3; $ctrl->displayFormAction(); $html = $response->getHTMLResult(); //PMA_URL_getHiddenInputs $this->assertContains( PMA_URL_getHiddenInputs( array( 'db' => 'db', 'table' => 'table', 'create_index' => 1, ) ), $html ); $doc_html = PMA\libraries\Util::showHint( PMA\libraries\Message::notice( __( '"PRIMARY" must be the name of' . ' and only of a primary key!' ) ) ); $this->assertContains( $doc_html, $html ); $this->assertContains( PMA\libraries\Util::showMySQLDocu('ALTER_TABLE'), $html ); // generateIndexSelector $this->assertContains( $index->generateIndexChoiceSelector(false), $html ); $this->assertContains( sprintf(__('Add %s column(s) to index'), 1), $html ); //$field_name & $field_type $this->assertContains( "field_name", $html ); $this->assertContains( "field_type", $html ); } }