object = new PMA\libraries\DisplayResults('as', '', '', '');
        $GLOBALS['PMA_Config'] = new PMA\libraries\Config();
        $GLOBALS['PMA_Config']->enableBc();
        $GLOBALS['text_dir'] = 'ltr';
        $GLOBALS['collation_connection'] = 'utf-8';
        $dbi = $this->getMockBuilder('PMA\libraries\DatabaseInterface')
            ->disableOriginalConstructor()
            ->getMock();
        $dbi->expects($this->any())->method('fieldFlags')
            ->will($this->returnArgument(1));
        $GLOBALS['dbi'] = $dbi;
    }
    /**
     * 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);
    }
    /**
     * Call private functions by setting visibility to public.
     *
     * @param string $name   method name
     * @param array  $params parameters for the invocation
     *
     * @return the output from the private method.
     */
    private function _callPrivateFunction($name, $params)
    {
        $class = new ReflectionClass('PMA\libraries\DisplayResults');
        $method = $class->getMethod($name);
        $method->setAccessible(true);
        return $method->invokeArgs($this->object, $params);
    }
    /**
     * Test for _isSelect function
     *
     * @return void
     */
    public function testisSelect()
    {
        $parser = new \SqlParser\Parser('SELECT * FROM pma');
        $this->assertTrue(
            $this->_callPrivateFunction(
                '_isSelect',
                array(
                    array(
                        'statement' => $parser->statements[0],
                        'select_from' => true,
                    ),
                )
            )
        );
    }
    /**
     * Test for navigation buttons
     *
     * @param string  $caption        iconic caption for button
     * @param string  $title          text for button
     * @param integer $pos            position for next query
     * @param string  $html_sql_query query ready for display
     * @param string  $output         output from the _getTableNavigationButton
     *                                method
     *
     * @return void
     *
     * @dataProvider providerForTestGetTableNavigationButton
     */
    public function testGetTableNavigationButton(
        $caption, $title, $pos, $html_sql_query, $output
    ) {
        $GLOBALS['cfg']['TableNavigationLinksMode'] = 'icons';
        $_SESSION[' PMA_token '] = 'token';
        $this->assertEquals(
            $output,
            $this->_callPrivateFunction(
                '_getTableNavigationButton',
                array(&$caption, $title, $pos, $html_sql_query, true)
            )
        );
    }
    /**
     * Provider for testGetTableNavigationButton
     *
     * @return array array data for testGetTableNavigationButton
     */
    public function providerForTestGetTableNavigationButton()
    {
        return array(
            array(
                'btn',
                'Submit',
                1,
                'SELECT * FROM `pma_bookmark` WHERE 1',
                '
'
                . '' . "\n"
                . '  '
            )
        );
    }
    /**
     * Test for _getEditLink
     *
     * @param string $edit_url          edit url
     * @param string $class             css classes for td element
     * @param string $edit_str          text for the edit link
     * @param string $where_clause      where clause
     * @param string $where_clause_html url encoded where clause
     * @param string $output            output of _getEditLink
     *
     * @return void
     *
     * @dataProvider dataProviderForGetEditLink
     */
    public function testGetEditLink(
        $edit_url, $class, $edit_str, $where_clause, $where_clause_html, $output
    ) {
        $GLOBALS['cfg']['ActionLinksMode'] = 'both';
        $GLOBALS['cfg']['LinkLengthLimit'] = 1000;
        $this->assertEquals(
            $output,
            $this->_callPrivateFunction(
                '_getEditLink',
                array(
                    $edit_url, $class, $edit_str, $where_clause, $where_clause_html
                )
            )
        );
    }
    /**
     * Data provider for testGetCopyLink
     *
     * @return array parameters and output
     */
    public function dataProviderForGetCopyLink()
    {
        return array(
            array(
                'tbl_change.php?db=Data&table=customer&where_clause=%60cust'
                . 'omer%60.%60id%60+%3D+1&clause_is_unique=1&sql_query='
                . 'SELECT+%2A+FROM+%60customer%60&goto=sql.php&default_'
                . 'action=insert&token=f597309d3a066c3c81a6cb015a79636d',
                '' . "\n"
                . ' ' . "\n"
                . 'DELETE FROM `Data`.`customer` WHERE '
                . '`customer`.`id` = 1
 '
            )
        );
    }
    /**
     * Test for _getDeleteLink
     *
     * @param string $del_url delete url
     * @param string $del_str text for the delete link
     * @param string $js_conf text for the JS confirmation
     * @param string $class   css classes for the td element
     * @param string $output  output of _getDeleteLink
     *
     * @return void
     *
     * @dataProvider dataProviderForGetDeleteLink
     */
    public function testGetDeleteLink(
        $del_url, $del_str, $js_conf, $class, $output
    ) {
        $GLOBALS['cfg']['ActionLinksMode'] = 'both';
        $GLOBALS['cfg']['LinkLengthLimit'] = 1000;
        $this->assertEquals(
            $output,
            $this->_callPrivateFunction(
                '_getDeleteLink',
                array(
                    $del_url, $del_str, $js_conf, $class
                )
            )
        );
    }
    /**
     * Data provider for testGetCheckboxAndLinks
     *
     * @return array parameters and output
     */
    public function dataProviderForGetCheckboxAndLinks()
    {
        return array(
            array(
                PMA\libraries\DisplayResults::POSITION_LEFT,
                'sql.php?db=data&table=new&sql_query=DELETE+FROM+%60data'
                . '%60.%60new%60+WHERE+%60new%60.%60id%60+%3D+1&message_to_show='
                . 'The+row+has+been+deleted&goto=sql.php%3Fdb%3Ddata%26table%3D'
                . 'new%26sql_query%3DSELECT%2B%252A%2BFROM%2B%2560new%2560%26'
                . 'message_to_show%3DThe%2Brow%2Bhas%2Bbeen%2Bdeleted%26goto%3D'
                . 'tbl_structure.php%26token%3Dae4c6d18375f446dfa068420c1f6a4e8'
                . '&token=ae4c6d18375f446dfa068420c1f6a4e8',
                array(
                    'edit_lnk' => 'ur',
                    'del_lnk' => 'dr',
                    'sort_lnk' => '0',
                    'nav_bar' => '1',
                    'bkm_form' => '1',
                    'text_btn' => '1',
                    'pview_lnk' => '1'
                ),
                0,
                '`new`.`id` = 1',
                '%60new%60.%60id%60+%3D+1',
                array(
                    '`new`.`id`' => '= 1',
                ),
                'tbl_change.php?db=data&table=new&where_clause=%60new%60.'
                . '%60id%60+%3D+1&clause_is_unique=1&sql_query=SELECT+%2A+'
                . 'FROM+%60new%60&goto=sql.php&default_action=update&'
                . 'token=ae4c6d18375f446dfa068420c1f6a4e8',
                'tbl_change.php?db=data&table=new&where_clause=%60new%60.'
                . '%60id%60+%3D+1&clause_is_unique=1&sql_query=SELECT+%2A+'
                . 'FROM+%60new%60&goto=sql.php&default_action=insert&'
                . 'token=ae4c6d18375f446dfa068420c1f6a4e8',
                'edit_row_anchor',
                '' . "\n"
                . ''
                . ' ' . "\n"
                . ' ' . "\n"
                . ' ' . "\n"
                . 'DELETE FROM `data`.`new` WHERE `new`.`id` = 1'
                . '
 '
            ),
            array(
                PMA\libraries\DisplayResults::POSITION_RIGHT,
                'sql.php?db=data&table=new&sql_query=DELETE+FROM+%60data%60'
                . '.%60new%60+WHERE+%60new%60.%60id%60+%3D+1&message_to_show='
                . 'The+row+has+been+deleted&goto=sql.php%3Fdb%3Ddata%26table%3D'
                . 'new%26sql_query%3DSELECT%2B%252A%2BFROM%2B%2560new%2560%26message'
                . '_to_show%3DThe%2Brow%2Bhas%2Bbeen%2Bdeleted%26goto%3Dtbl_'
                . 'structure.php%26token%3Dae4c6d18375f446dfa068420c1f6a4e8&'
                . 'token=ae4c6d18375f446dfa068420c1f6a4e8',
                array(
                    'edit_lnk' => 'ur',
                    'del_lnk' => 'dr',
                    'sort_lnk' => '0',
                    'nav_bar' => '1',
                    'bkm_form' => '1',
                    'text_btn' => '1',
                    'pview_lnk' => '1'
                ),
                0,
                '`new`.`id` = 1',
                '%60new%60.%60id%60+%3D+1',
                array(
                    '`new`.`id`' => '= 1',
                ),
                'tbl_change.php?db=data&table=new&where_clause=%60new%60.'
                . '%60id%60+%3D+1&clause_is_unique=1&sql_query=SELECT+%2A+'
                . 'FROM+%60new%60&goto=sql.php&default_action=update&'
                . 'token=ae4c6d18375f446dfa068420c1f6a4e8',
                'tbl_change.php?db=data&table=new&where_clause=%60new%60.'
                . '%60id%60+%3D+1&clause_is_unique=1&sql_query=SELECT+%2A+'
                . 'FROM+%60new%60&goto=sql.php&default_action=insert&'
                . 'token=ae4c6d18375f446dfa068420c1f6a4e8',
                'edit_row_anchor',
                '' . "\n"
                . 'DELETE FROM `data`.`new` WHERE `new`.'
                . '`id` = 1
 '
                . "\n" . ' '
                . '' . "\n"
                . '  1001 '
            ),
            array(
                true,
                true,
                'BLOB',
                hex2bin('123456'),
                'PMA_mimeDefaultFunction',
                '',
                'PMA_mimeDefaultFunction',
                $meta,
                $url_params,
                null,
                '0x123456 '
            ),
            array(
                true,
                false,
                'BLOB',
                '1001',
                'PMA_mimeDefaultFunction',
                '',
                'PMA_mimeDefaultFunction',
                $meta,
                $url_params,
                null,
                '[BLOB - 4 B] '
            ),
            array(
                false,
                false,
                'BINARY',
                '1001',
                $transformation_plugin,
                '',
                'PMA_mimeDefaultFunction',
                $meta,
                $url_params,
                null,
                '1001'
            ),
            array(
                false,
                true,
                'GEOMETRY',
                null,
                '',
                '',
                'PMA_mimeDefaultFunction',
                $meta,
                $url_params,
                null,
                '[GEOMETRY - NULL]'
            )
        );
    }
    /**
     * Test _handleNonPrintableContents
     *
     * @param boolean $display_binary        show binary contents?
     * @param boolean $display_blob          show blob contents?
     * @param string  $category              BLOB|BINARY|GEOMETRY
     * @param string  $content               the binary content
     * @param string  $transformation_plugin transformation plugin.
     *                                       Can also be the default function:
     *                                       PMA_mimeDefaultFunction
     * @param string  $transform_options     transformation parameters
     * @param string  $default_function      default transformation function
     * @param object  $meta                  the meta-information about the field
     * @param array   $url_params            parameters that should go to the
     *                                       download link
     * @param boolean $is_truncated          the result is truncated or not
     * @param string  $output                the output of this function
     *
     * @return void
     *
     * @dataProvider dataProviderForTestHandleNonPrintableContents
     */
    public function testHandleNonPrintableContents(
        $display_binary, $display_blob, $category, $content,
        $transformation_plugin, $transform_options, $default_function,
        $meta, $url_params, $is_truncated, $output
    ) {
        $_SESSION['tmpval']['display_binary'] = $display_binary;
        $_SESSION['tmpval']['display_blob'] = $display_blob;
        $GLOBALS['cfg']['LimitChars'] = 50;
        $this->assertEquals(
            $output,
            $this->_callPrivateFunction(
                '_handleNonPrintableContents',
                array(
                    $category, $content, $transformation_plugin,
                    $transform_options, $default_function,
                    $meta, $url_params, &$is_truncated
                )
            )
        );
    }
    /**
     * Data provider for testGetDataCellForNonNumericColumns
     *
     * @return array parameters and output
     */
    public function dataProviderForTestGetDataCellForNonNumericColumns()
    {
        $transformation_plugin = new Text_Plain_Link();
        $meta = new StdClass();
        $meta->db = 'foo';
        $meta->table = 'tbl';
        $meta->orgtable = 'tbl';
        $meta->type = 'BLOB';
        $meta->flags = 'blob binary';
        $meta->name = 'tblob';
        $meta->orgname = 'tblob';
        $meta2 = new StdClass();
        $meta2->db = 'foo';
        $meta2->table = 'tbl';
        $meta2->orgtable = 'tbl';
        $meta2->type = 'string';
        $meta2->flags = '';
        $meta2->decimals = 0;
        $meta2->name = 'varchar';
        $meta2->orgname = 'varchar';
        $url_params = array('db' => 'foo', 'table' => 'tbl');
        return array(
            array(
                'all',
                '1001',
                'grid_edit',
                $meta,
                array(),
                $url_params,
                false,
                'PMA_mimeDefaultFunction',
                'PMA_mimeDefaultFunction',
                array('https://www.example.com/'),
                false,
                array(),
                0,
                'binary',
                '[BLOB - 4 B] '
                . '1001 '
            ),
            array(
                'noblob',
                null,
                'grid_edit',
                $meta2,
                array(),
                $url_params,
                false,
                $transformation_plugin,
                'PMA_mimeDefaultFunction',
                '',
                false,
                array(),
                0,
                0,
                'NULL foo bar baz ' . "\n"
            )
        );
    }
    /**
     * Test _getDataCellForNonNumericColumns
     *
     * @param boolean $protectBinary         all|blob|noblob|no
     * @param string  $column                the relevant column in data row
     * @param string  $class                 the html class for column
     * @param object  $meta                  the meta-information about the field
     * @param array   $map                   the list of relations
     * @param array   $_url_params           the parameters for generate url
     * @param boolean $condition_field       the column should highlighted
     *                                       or not
     * @param string  $transformation_plugin the name of transformation function
     * @param string  $default_function      the default transformation function
     * @param string  $transform_options     the transformation parameters
     * @param boolean $is_field_truncated    is data truncated due to LimitChars
     * @param array   $analyzed_sql_results  the analyzed query
     * @param integer $dt_result             the link id associated to the query
     *                                       which results have to be displayed
     * @param integer $col_index             the column index
     * @param string  $output                the output of this function
     *
     * @return void
     *
     * @dataProvider dataProviderForTestGetDataCellForNonNumericColumns
     */
    public function testGetDataCellForNonNumericColumns(
        $protectBinary, $column, $class, $meta, $map,
        $_url_params, $condition_field, $transformation_plugin,
        $default_function, $transform_options, $is_field_truncated,
        $analyzed_sql_results, $dt_result, $col_index, $output
    ) {
        $_SESSION['tmpval']['display_binary'] = true;
        $_SESSION['tmpval']['display_blob'] = false;
        $_SESSION['tmpval']['relational_display'] = false;
        $GLOBALS['cfg']['LimitChars'] = 50;
        $GLOBALS['cfg']['ProtectBinary'] = $protectBinary;
        $this->assertEquals(
            $output,
            $this->_callPrivateFunction(
                '_getDataCellForNonNumericColumns',
                array(
                    $column, $class, $meta, $map, $_url_params, $condition_field,
                    $transformation_plugin, $default_function, $transform_options,
                    $is_field_truncated, $analyzed_sql_results, &$dt_result, $col_index
                )
            )
        );
    }
}