getMockBuilder('PMA\libraries\Table') ->disableOriginalConstructor() ->getMock(); $dbi = $this->getMockBuilder('PMA\libraries\DatabaseInterface') ->disableOriginalConstructor() ->getMock(); $dbi->expects($this->any())->method('getTable') ->will($this->returnValue($table)); $GLOBALS['dbi'] = $dbi; $container = Container::getDefaultContainer(); $container->set('db', 'db'); $container->set('table', 'table'); $container->set('dbi', $GLOBALS['dbi']); $this->_response = new \PMA\Test\Stubs\Response(); $container->set('PMA\libraries\Response', $this->_response); $container->alias('response', 'PMA\libraries\Response'); } /** * Tests for getKeyForTablePrimary() * * Case one: there are no primary key in the table * * @return void * @test */ public function testGetKeyForTablePrimaryOne() { $GLOBALS['dbi']->expects($this->any())->method('fetchAssoc') ->will($this->returnValue(null)); $class = new ReflectionClass('\PMA\libraries\controllers\table\TableStructureController'); $method = $class->getMethod('getKeyForTablePrimary'); $method->setAccessible(true); $container = Container::getDefaultContainer(); $container->set('dbi', $GLOBALS['dbi']); $container->factory('PMA\libraries\controllers\table\TableStructureController'); $container->alias( 'TableStructureController', 'PMA\libraries\controllers\table\TableStructureController' ); $ctrl = $container->get('TableStructureController'); // No primary key in db.table2 $this->assertEquals( '', $method->invoke($ctrl) ); } /** * Tests for getKeyForTablePrimary() * * Case two: there are a primary key in the table * * @return void * @test */ public function testGetKeyForTablePrimaryTwo() { $GLOBALS['dbi']->expects($this->any()) ->method('fetchAssoc') ->will( $this->returnCallback( function () { static $callCount = 0; if ($callCount == 0) { $callCount++; return array( 'Key_name' => 'PRIMARY', 'Column_name' => 'column', ); } else { return null; } } ) ); $class = new ReflectionClass('\PMA\libraries\controllers\table\TableStructureController'); $method = $class->getMethod('getKeyForTablePrimary'); $method->setAccessible(true); $container = Container::getDefaultContainer(); $container->set('dbi', $GLOBALS['dbi']); $container->factory('PMA\libraries\controllers\table\TableStructureController'); $container->alias( 'TableStructureController', 'PMA\libraries\controllers\table\TableStructureController' ); $ctrl = $container->get('TableStructureController'); // With db.table, it has a primary key `column` $this->assertEquals( 'column, ', $method->invoke($ctrl) ); } /** * Tests for adjustColumnPrivileges() * * @return void * @test */ public function testAdjustColumnPrivileges() { $class = new ReflectionClass('\PMA\libraries\controllers\table\TableStructureController'); $method = $class->getMethod('adjustColumnPrivileges'); $method->setAccessible(true); $container = Container::getDefaultContainer(); $container->set('dbi', $GLOBALS['dbi']); $container->factory('PMA\libraries\controllers\table\TableStructureController'); $container->alias( 'TableStructureController', 'PMA\libraries\controllers\table\TableStructureController' ); $ctrl = $container->get('TableStructureController'); $this->assertEquals( false, $method->invokeArgs($ctrl, array(null)) ); } /** * Tests for getMultipleFieldCommandType() * * @return void * @test */ public function testGetMultipleFieldCommandType() { $class = new ReflectionClass('\PMA\libraries\controllers\table\TableStructureController'); $method = $class->getMethod('getMultipleFieldCommandType'); $method->setAccessible(true); $container = Container::getDefaultContainer(); $container->set('dbi', $GLOBALS['dbi']); $container->factory('PMA\libraries\controllers\table\TableStructureController'); $container->alias( 'TableStructureController', 'PMA\libraries\controllers\table\TableStructureController' ); $ctrl = $container->get('TableStructureController'); $this->assertEquals( null, $method->invoke($ctrl) ); $_REQUEST['submit_mult_drop_x'] = true; $this->assertEquals( 'drop', $method->invoke($ctrl) ); unset($_REQUEST['submit_mult_drop_x']); $_REQUEST['submit_mult'] = 'create'; $this->assertEquals( 'create', $method->invoke($ctrl) ); unset($_REQUEST['submit_mult']); $_REQUEST['mult_btn'] = __('Yes'); $this->assertEquals( 'row_delete', $method->invoke($ctrl) ); $_REQUEST['selected'] = array('a', 'b'); $method->invoke($ctrl); $this->assertEquals( $_REQUEST['selected'], $_REQUEST['selected_fld'] ); } /** * Test for getDataForSubmitMult() * * @return void * @test */ public function testPMAGetDataForSubmitMult() { $dbi = $this->getMockBuilder('PMA\libraries\DatabaseInterface') ->disableOriginalConstructor() ->getMock(); $dbi->expects($this->any()) ->method('query') ->will($this->returnValue(true)); $class = new ReflectionClass('PMA\libraries\controllers\table\TableStructureController'); $method = $class->getMethod('getDataForSubmitMult'); $method->setAccessible(true); $container = Container::getDefaultContainer(); $container->set('dbi', $dbi); $container->factory('PMA\libraries\controllers\table\TableStructureController'); $container->alias( 'TableStructureController', 'PMA\libraries\controllers\table\TableStructureController' ); $ctrl = $container->get('TableStructureController'); $submit_mult = "index"; $db = "PMA_db"; $table = "PMA_table"; $selected = array( "table1", "table2" ); $action = 'db_delete_row'; list($what, $query_type, $is_unset_submit_mult, $mult_btn, $centralColsError) = $method->invokeArgs( $ctrl, array($submit_mult, $db, $table, $selected, $action) ); //validate 1: $what $this->assertEquals( null, $what ); //validate 2: $query_type $this->assertEquals( 'index_fld', $query_type ); //validate 3: $is_unset_submit_mult $this->assertEquals( true, $is_unset_submit_mult ); //validate 4: $this->assertEquals( __('Yes'), $mult_btn ); //validate 5: $centralColsError $this->assertEquals( null, $centralColsError ); $submit_mult = "unique"; list($what, $query_type, $is_unset_submit_mult, $mult_btn, $centralColsError) = $method->invokeArgs( $ctrl, array($submit_mult, $db, $table, $selected, $action) ); //validate 1: $what $this->assertEquals( null, $what ); //validate 2: $query_type $this->assertEquals( 'unique_fld', $query_type ); //validate 3: $is_unset_submit_mult $this->assertEquals( true, $is_unset_submit_mult ); //validate 4: $mult_btn $this->assertEquals( __('Yes'), $mult_btn ); //validate 5: $centralColsError $this->assertEquals( null, $centralColsError ); } }