Passed
Push — master ( cee3e6...16d2f0 )
by William
11:48 queued 12s
created

ExpressionTest::testMysqlCommands()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 5
Code Lines 3

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 1
eloc 3
nc 1
nop 2
dl 0
loc 5
rs 10
c 0
b 0
f 0
1
<?php
2
3
declare(strict_types=1);
4
5
namespace PhpMyAdmin\SqlParser\Tests\Components;
6
7
use PhpMyAdmin\SqlParser\Components\Expression;
8
use PhpMyAdmin\SqlParser\Parser;
9
use PhpMyAdmin\SqlParser\Tests\TestCase;
10
11
class ExpressionTest extends TestCase
12
{
13
    public function testParse(): void
14
    {
15
        $component = Expression::parse(new Parser(), $this->getTokensList('IF(film_id > 0, film_id, film_id)'));
16
        $this->assertEquals($component->expr, 'IF(film_id > 0, film_id, film_id)');
17
    }
18
19
    public function testParse2(): void
20
    {
21
        $component = Expression::parse(new Parser(), $this->getTokensList('col`test`'));
22
        $this->assertEquals($component->expr, 'col');
23
    }
24
25
    public function testParse3(): void
26
    {
27
        $component = Expression::parse(new Parser(), $this->getTokensList('col xx'));
28
        $this->assertEquals($component->alias, 'xx');
29
30
        $component = Expression::parse(new Parser(), $this->getTokensList('col y'));
31
        $this->assertEquals($component->alias, 'y');
32
33
        $component = Expression::parse(new Parser(), $this->getTokensList('avg.col FROM (SELECT ev.col FROM ev)'));
34
        $this->assertEquals($component->table, 'avg');
35
        $this->assertEquals($component->expr, 'avg.col');
36
37
        $component = Expression::parse(new Parser(), $this->getTokensList('x.id FROM (SELECT a.id FROM a) x'));
38
        $this->assertEquals($component->table, 'x');
39
        $this->assertEquals($component->expr, 'x.id');
40
    }
41
42
    /**
43
     * @dataProvider parseErrProvider
44
     */
45
    public function testParseErr(string $expr, string $error): void
46
    {
47
        $parser = new Parser();
48
        Expression::parse($parser, $this->getTokensList($expr));
49
        $errors = $this->getErrorsAsArray($parser);
50
        $this->assertEquals($errors[0][0], $error);
51
    }
52
53
    /**
54
     * @return string[][]
55
     */
56
    public static function parseErrProvider(): array
57
    {
58
        return [
59
            /*
60
            [
61
                '(1))',
62
                'Unexpected closing bracket.',
63
            ],
64
            */
65
            [
66
                'tbl..col',
67
                'Unexpected dot.',
68
            ],
69
            [
70
                'id AS AS id2',
71
                'An alias was expected.',
72
            ],
73
            [
74
                'id`id2`\'id3\'',
75
                'An alias was previously found.',
76
            ],
77
            [
78
                '(id) id2 id3',
79
                'An alias was previously found.',
80
            ],
81
        ];
82
    }
83
84
    public function testBuild(): void
85
    {
86
        $component = [
87
            new Expression('1 + 2', 'three'),
88
            new Expression('1 + 3', 'four'),
89
        ];
90
        $this->assertEquals(
91
            Expression::build($component),
92
            '1 + 2 AS `three`, 1 + 3 AS `four`'
93
        );
94
    }
95
96
    /**
97
     * @return string[][]
98
     */
99
    public static function mysqlCommandsProvider(): array
100
    {
101
        return [
102
            [
103
                '/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;',
104
                'SET  @OLD_CHARACTER_SET_CLIENT = @@CHARACTER_SET_CLIENT',
105
            ],
106
            [
107
                '/*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;',
108
                'SET  @OLD_CHARACTER_SET_RESULTS = @@CHARACTER_SET_RESULTS',
109
            ],
110
            [
111
                '/*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */;',
112
                'SET  @OLD_COLLATION_CONNECTION = @@COLLATION_CONNECTION',
113
            ],
114
            [
115
                '/*!40101 SET NAMES utf8 */;',
116
                'SET NAMES utf8',
117
            ],
118
            [
119
                '/*!40103 SET @OLD_TIME_ZONE=@@TIME_ZONE */;',
120
                'SET  @OLD_TIME_ZONE = @@TIME_ZONE',
121
            ],
122
            [
123
                "/*!40103 SET TIME_ZONE='+00:00' */;",
124
                "SET  TIME_ZONE = '+00:00'",
125
            ],
126
            [
127
                '/*!40014 SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0 */;',
128
                'SET  @OLD_UNIQUE_CHECKS = @@UNIQUE_CHECKS, UNIQUE_CHECKS = 0',
129
            ],
130
            [
131
                '/*!40014 SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0 */;',
132
                'SET  @OLD_FOREIGN_KEY_CHECKS = @@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS = 0',
133
            ],
134
            [
135
                "/*!40101 SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='NO_AUTO_VALUE_ON_ZERO' */;",
136
                "SET  @OLD_SQL_MODE = @@SQL_MODE, SQL_MODE = 'NO_AUTO_VALUE_ON_ZERO'",
137
            ],
138
            [
139
                '/*!40111 SET @OLD_SQL_NOTES=@@SQL_NOTES, SQL_NOTES=0 */;',
140
                'SET  @OLD_SQL_NOTES = @@SQL_NOTES, SQL_NOTES = 0',
141
            ],
142
        ];
143
    }
144
145
    /**
146
     * @dataProvider mysqlCommandsProvider
147
     */
148
    public function testMysqlCommands(string $expr, string $expected): void
149
    {
150
        $parser = new Parser($expr, true);
151
        $parser->parse();
152
        self::assertSame($expected, $parser->statements[0]->build());
153
    }
154
}
155