HEX
Server: nginx/1.22.0
System: Linux iZuf6jdxbygmf6cco977lcZ 5.10.84-10.4.al8.x86_64 #1 SMP Tue Apr 12 12:31:07 CST 2022 x86_64
User: root (0)
PHP: 7.4.29
Disabled: passthru,exec,system,chroot,chgrp,chown,shell_exec,proc_open,proc_get_status,ini_alter,ini_restore,dl,readlink,symlink,popepassthru,stream_socket_server,fsocket,popen
Upload Files
File: /data/wwwroot/wordpress/phpMyAdmin/test/libraries/PMA_tbl_indexes_test.php
<?php
/* vim: set expandtab sw=4 ts=4 sts=4: */
/**
 * Tests for libraries/tbl_indexes.lib.php
 *
 * @package PhpMyAdmin-test
 */

/*
 * Include to test.
 */
require_once 'libraries/tbl_indexes.lib.php';
require_once 'libraries/Util.class.php';
require_once 'libraries/Index.class.php';
require_once 'libraries/Message.class.php';
require_once 'libraries/database_interface.inc.php';
require_once 'libraries/php-gettext/gettext.inc';
require_once 'libraries/relation.lib.php';
require_once 'libraries/url_generating.lib.php';
require_once 'libraries/Theme.class.php';
require_once 'libraries/sanitizing.lib.php';

/**
 * Tests for libraries/tbl_indexes.lib.php
 *
 * @package PhpMyAdmin-test
 */
class PMA_TblIndexTest extends PHPUnit_Framework_TestCase
{

    /**
     * Setup function for test cases
     *
     * @access protected
     * @return void
     */
    protected function setUp()
    {
        /**
         * SET these to avoid undefined index error
         */
        $GLOBALS['server'] = 1;
        $GLOBALS['cfg']['Server']['pmadb'] = '';
        $GLOBALS['pmaThemeImage'] = 'theme/';
        $GLOBALS['cfg']['ServerDefault'] = "server";
        $GLOBALS['cfg']['ShowHint'] = true;

        $dbi = $this->getMockBuilder('PMA_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'] = PMA_Theme::load('./themes/pmahomme');
        $_SESSION['PMA_Theme'] = new PMA_Theme();
    }

    /**
     * Tests for PMA_getSqlQueryForIndexCreateOrEdit() method.
     *
     * @return void
     * @test
     */
    public function testPMAGetSqlQueryForIndexCreateOrEdit()
    {
        $db = "pma_db";
        $table = "pma_table";
        $index = new PMA_Index();
        $error = false;

        $_REQUEST['old_index'] = "PRIMARY";

        $sql = PMA_getSqlQueryForIndexCreateOrEdit(
            $db, $table, $index, $error
        );

        $this->assertEquals(
            "ALTER TABLE `pma_db`.`pma_table` DROP PRIMARY KEY, ADD UNIQUE ;",
            $sql
        );
    }

    /**
     * Tests for PMA_getNumberOfFieldsForForm() method.
     *
     * @return void
     * @test
     */
    public function testPMAGetNumberOfFieldsForForm()
    {
        $index = new PMA_Index();

        $add_fields = PMA_getNumberOfFieldsForForm($index);

        $this->assertEquals(
            0,
            $add_fields
        );

        $_REQUEST['create_index'] = true;
        $_REQUEST['added_fields'] = 2;
        $add_fields = PMA_getNumberOfFieldsForForm($index);
        $this->assertEquals(
            $_REQUEST['added_fields'],
            $add_fields
        );
    }

    /**
     * Tests for PMA_getFormParameters() method.
     *
     * @return void
     * @test
     */
    public function testPMAGetFormParameters()
    {
        $db = "pma_db";
        $table = "pma_table";

        $form_params = PMA_getFormParameters($db, $table);
        $expect = array(
            'db' => $db,
            'table' => $table,
        );
        $this->assertEquals(
            $expect,
            $form_params
        );

        $_REQUEST['index'] = "index";
        $form_params = PMA_getFormParameters($db, $table);
        $expect = array(
            'db' => $db,
            'table' => $table,
            'old_index' => $_REQUEST['index'],
        );
        $this->assertEquals(
            $expect,
            $form_params
        );

        $_REQUEST['old_index'] = "old_index";
        $form_params = PMA_getFormParameters($db, $table);
        $expect = array(
            'db' => $db,
            'table' => $table,
            'old_index' => $_REQUEST['old_index'],
        );
        $this->assertEquals(
            $expect,
            $form_params
        );

        $_REQUEST['create_index'] = "create_index";
        $form_params = PMA_getFormParameters($db, $table);
        $expect = array(
            'db' => $db,
            'table' => $table,
            'create_index' => 1,
        );
        $this->assertEquals(
            $expect,
            $form_params
        );
    }

    /**
     * Tests for PMA_getHtmlForIndexForm() method.
     *
     * @return void
     * @test
     */
    public function testPMAGetHtmlForIndexForm()
    {
        $fields = array("field_name" => "field_type");
        $index = new PMA_Index();
        $form_params = array(
            'db' => 'db',
            'table' => 'table',
            'create_index' => 1,
        );
        $add_fields = 3;

        $html = PMA_getHtmlForIndexForm($fields, $index, $form_params, $add_fields);

        //PMA_URL_getHiddenInputs
        $this->assertContains(
            PMA_URL_getHiddenInputs($form_params),
            $html
        );

        //Index name
        $this->assertContains(
            __('Index name:'),
            $html
        );
        $doc_html = PMA_Util::showHint(
            PMA_Message::notice(
                __(
                    '"PRIMARY" <b>must</b> be the name of'
                    . ' and <b>only of</b> a primary key!'
                )
            )
        );
        $this->assertContains(
            $doc_html,
            $html
        );

        //Index name
        $this->assertContains(
            __('Index name:'),
            $html
        );
        $this->assertContains(
            PMA_Util::showMySQLDocu('ALTER_TABLE'),
            $html
        );

        //generateIndexSelector
        $this->assertContains(
            $index->generateIndexChoiceSelector(false),
            $html
        );

        //items
        $this->assertContains(
            __('Column'),
            $html
        );
        $this->assertContains(
            __('Size'),
            $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
        );
    }
}
?>