File: SelectTest.php

package info (click to toggle)
phpmyadmin 4%3A5.2.2-really%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 140,312 kB
  • sloc: javascript: 228,447; php: 166,904; xml: 17,847; sql: 504; sh: 275; makefile: 209; python: 205
file content (116 lines) | stat: -rw-r--r-- 3,340 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
<?php

declare(strict_types=1);

namespace PhpMyAdmin\Tests\Server;

use PhpMyAdmin\Server\Select;
use PhpMyAdmin\Tests\AbstractTestCase;
use PhpMyAdmin\Util;

use function __;

/**
 * @covers \PhpMyAdmin\Server\Select
 */
#[\PHPUnit\Framework\Attributes\CoversClass(\PhpMyAdmin\Server\Select::class)]
class SelectTest extends AbstractTestCase
{
    /**
     * Prepares environment for the test.
     */
    protected function setUp(): void
    {
        parent::setUp();
        //$_REQUEST
        $_REQUEST['log'] = 'index1';
        $_REQUEST['pos'] = 3;

        //$GLOBALS
        $GLOBALS['cfg']['MaxRows'] = 10;
        $GLOBALS['server'] = 1;
        $GLOBALS['cfg']['ServerDefault'] = 'server';
        $GLOBALS['cfg']['RememberSorting'] = true;
        $GLOBALS['cfg']['SQP'] = [];
        $GLOBALS['cfg']['MaxCharactersInDisplayedSQL'] = 1000;
        $GLOBALS['cfg']['ShowSQL'] = true;
        $GLOBALS['cfg']['TableNavigationLinksMode'] = 'icons';
        $GLOBALS['cfg']['LimitChars'] = 100;

        $GLOBALS['table'] = 'table';

        $GLOBALS['cfg']['DefaultTabServer'] = 'welcome';

        $GLOBALS['cfg']['Servers'] = [
            '0' => [
                'host' => 'host0',
                'port' => 'port0',
                'only_db' => 'only_db0',
                'user' => 'user0',
                'auth_type' => 'config',
            ],
            '1' => [
                'host' => 'host1',
                'port' => 'port1',
                'only_db' => 'only_db1',
                'user' => 'user1',
                'auth_type' => 'config',
            ],
        ];
        //$_SESSION
    }

    /**
     * Test for Select::render
     *
     * @dataProvider renderDataProvider
     */
    #[\PHPUnit\Framework\Attributes\DataProvider('renderDataProvider')]
    public function testRender(bool $not_only_options, bool $omit_fieldset): void
    {
        if ($not_only_options) {
            $GLOBALS['cfg']['DisplayServersList'] = null;
        }

        $html = Select::render($not_only_options, $omit_fieldset);
        $server = $GLOBALS['cfg']['Servers']['0'];

        if ($not_only_options) {
            if (! $omit_fieldset) {
                self::assertStringContainsString('</fieldset>', $html);
            }

            self::assertStringContainsString(Util::getScriptNameForOption(
                $GLOBALS['cfg']['DefaultTabServer'],
                'server'
            ), $html);

            self::assertStringContainsString(__('Current server:'), $html);
            self::assertStringContainsString('(' . __('Servers') . ')', $html);
        }

        //server items
        self::assertStringContainsString($server['host'], $html);
        self::assertStringContainsString($server['port'], $html);
        self::assertStringContainsString($server['only_db'], $html);
        self::assertStringContainsString($server['user'], $html);
    }

    public static function renderDataProvider(): array
    {
        return [
            'only options, don\'t omit fieldset' => [
                false,
                false,
            ],
            'not only options, omits fieldset' => [
                true,
                true,
            ],
            'not only options, don\'t omit fieldset' => [
                true,
                false,
            ],
        ];
    }
}