Skip to content

Commit

Permalink
Merge branch '5.11.x'
Browse files Browse the repository at this point in the history
  • Loading branch information
williamdes committed Jan 17, 2025
2 parents 2ce9a41 + 2142141 commit 8db6524
Show file tree
Hide file tree
Showing 6 changed files with 128 additions and 10 deletions.
6 changes: 6 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,12 @@

- Add Translator::setLocale() method (#599)

# [5.10.3] - YYYY-MM-DD

### Fixed

- Add "RECURSIVE" on build() for "WITH RECURSIVE" on the WithStatement class (#605)

## [5.10.2] - 2024-12-05

### Added
Expand Down
16 changes: 8 additions & 8 deletions phpstan-baseline.neon
Original file line number Diff line number Diff line change
Expand Up @@ -716,22 +716,22 @@ parameters:
path: src/Parsers/OptionsArrays.php

-
message: "#^Property PhpMyAdmin\\\\SqlParser\\\\Components\\\\OptionsArray\\:\\:\\$options \\(array\\<int, array\\{name\\: string, equals\\: bool, expr\\: PhpMyAdmin\\\\SqlParser\\\\Components\\\\Expression\\|string, value\\: string\\|null\\}\\|string\\>\\) does not accept non\\-empty\\-array\\<int\\|string, array\\{name\\: bool\\|float\\|int\\|string, equals\\: bool, expr\\: PhpMyAdmin\\\\SqlParser\\\\Components\\\\Expression\\|string, value\\: string\\|null\\}\\|string\\>\\.$#"
message: "#^Property PhpMyAdmin\\\\SqlParser\\\\Components\\\\OptionsArray\\:\\:\\$options \\(array\\<int, array\\{name\\: string, equals\\: bool, expr\\: PhpMyAdmin\\\\SqlParser\\\\Components\\\\Expression\\|string, value\\: string\\|null\\}\\|string\\>\\) does not accept non\\-empty\\-array\\<array\\{name\\: bool\\|float\\|int\\|string, equals\\: bool, expr\\: PhpMyAdmin\\\\SqlParser\\\\Components\\\\Expression\\|string, value\\: string\\|null\\}\\|string\\>\\.$#"
count: 2
path: src/Parsers/OptionsArrays.php

-
message: "#^Property PhpMyAdmin\\\\SqlParser\\\\Components\\\\OptionsArray\\:\\:\\$options \\(array\\<int, array\\{name\\: string, equals\\: bool, expr\\: PhpMyAdmin\\\\SqlParser\\\\Components\\\\Expression\\|string, value\\: string\\|null\\}\\|string\\>\\) does not accept non\\-empty\\-array\\<int\\|string, array\\{name\\: string, equals\\: bool, expr\\: PhpMyAdmin\\\\SqlParser\\\\Components\\\\Expression\\|string, value\\: string\\|null\\}\\|bool\\|float\\|int\\|string\\>\\.$#"
message: "#^Property PhpMyAdmin\\\\SqlParser\\\\Components\\\\OptionsArray\\:\\:\\$options \\(array\\<int, array\\{name\\: string, equals\\: bool, expr\\: PhpMyAdmin\\\\SqlParser\\\\Components\\\\Expression\\|string, value\\: string\\|null\\}\\|string\\>\\) does not accept non\\-empty\\-array\\<array\\{name\\: string, equals\\: bool, expr\\: PhpMyAdmin\\\\SqlParser\\\\Components\\\\Expression\\|string, value\\: string\\|null\\}\\|bool\\|float\\|int\\|string\\>\\.$#"
count: 1
path: src/Parsers/OptionsArrays.php

-
message: "#^Property PhpMyAdmin\\\\SqlParser\\\\Components\\\\OptionsArray\\:\\:\\$options \\(array\\<int, array\\{name\\: string, equals\\: bool, expr\\: PhpMyAdmin\\\\SqlParser\\\\Components\\\\Expression\\|string, value\\: string\\|null\\}\\|string\\>\\) does not accept non\\-empty\\-array\\<int\\|string, array\\{name\\: string, equals\\: bool, expr\\: PhpMyAdmin\\\\SqlParser\\\\Components\\\\Expression\\|string, value\\: string\\|null\\}\\|string\\>\\.$#"
message: "#^Property PhpMyAdmin\\\\SqlParser\\\\Components\\\\OptionsArray\\:\\:\\$options \\(array\\<int, array\\{name\\: string, equals\\: bool, expr\\: PhpMyAdmin\\\\SqlParser\\\\Components\\\\Expression\\|string, value\\: string\\|null\\}\\|string\\>\\) does not accept non\\-empty\\-array\\<array\\{name\\: string, equals\\: bool, expr\\: PhpMyAdmin\\\\SqlParser\\\\Components\\\\Expression\\|string, value\\: string\\|null\\}\\|string\\>\\.$#"
count: 3
path: src/Parsers/OptionsArrays.php

-
message: "#^Property PhpMyAdmin\\\\SqlParser\\\\Components\\\\OptionsArray\\:\\:\\$options \\(array\\<int, array\\{name\\: string, equals\\: bool, expr\\: PhpMyAdmin\\\\SqlParser\\\\Components\\\\Expression\\|string, value\\: string\\|null\\}\\|string\\>\\) does not accept non\\-empty\\-array\\<int\\|string, mixed\\>\\.$#"
message: "#^Property PhpMyAdmin\\\\SqlParser\\\\Components\\\\OptionsArray\\:\\:\\$options \\(array\\<int, array\\{name\\: string, equals\\: bool, expr\\: PhpMyAdmin\\\\SqlParser\\\\Components\\\\Expression\\|string, value\\: string\\|null\\}\\|string\\>\\) does not accept non\\-empty\\-array\\<mixed\\>\\.$#"
count: 3
path: src/Parsers/OptionsArrays.php

Expand Down Expand Up @@ -1722,7 +1722,7 @@ parameters:

-
message: "#^Dynamic call to static method PHPUnit\\\\Framework\\\\Assert\\:\\:assertEquals\\(\\)\\.$#"
count: 33
count: 34
path: tests/Builder/CreateStatementTest.php

-
Expand Down Expand Up @@ -1977,7 +1977,7 @@ parameters:

-
message: "#^Dynamic call to static method PHPUnit\\\\Framework\\\\Assert\\:\\:assertEquals\\(\\)\\.$#"
count: 8
count: 9
path: tests/Components/OptionsArrayTest.php

-
Expand Down Expand Up @@ -2212,12 +2212,12 @@ parameters:

-
message: "#^Dynamic call to static method PHPUnit\\\\Framework\\\\Assert\\:\\:assertCount\\(\\)\\.$#"
count: 8
count: 14
path: tests/Parser/WithStatementTest.php

-
message: "#^Dynamic call to static method PHPUnit\\\\Framework\\\\Assert\\:\\:assertEquals\\(\\)\\.$#"
count: 3
count: 5
path: tests/Parser/WithStatementTest.php

-
Expand Down
10 changes: 8 additions & 2 deletions src/Statements/WithStatement.php
Original file line number Diff line number Diff line change
Expand Up @@ -269,11 +269,17 @@ public function parse(Parser $parser, TokensList $list): void

public function build(): string
{
$str = 'WITH ';
$initial = true;
$str = 'WITH';

if ($this->options !== null && $this->options->options !== []) {
$str .= ' ' . $this->options->build();
}

foreach ($this->withers as $wither) {
$str .= $str === 'WITH ' ? '' : ', ';
$str .= $initial ? ' ' : ', ';
$str .= $wither->build();
$initial = false;
}

$str .= ' ';
Expand Down
29 changes: 29 additions & 0 deletions tests/Builder/CreateStatementTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,8 @@
use PhpMyAdmin\SqlParser\TokenType;
use PHPUnit\Framework\Attributes\DataProvider;

use function implode;

class CreateStatementTest extends TestCase
{
public function testBuilder(): void
Expand Down Expand Up @@ -401,6 +403,33 @@ public function testBuilderView(): void
. ' AS (SELECT 1 UNION ALL SELECT 2) SELECT col1 FROM cte AS `d` ',
$stmt->build(),
);

$parser = new Parser(
implode("\n", [
'CREATE VIEW number_sequence_view AS',
'WITH RECURSIVE number_sequence AS (',
' SELECT 1 AS `number`',
' UNION ALL',
' SELECT `number` + 1',
' FROM number_sequence',
' WHERE `number` < 5',
')',
'SELECT * FROM number_sequence;',
]),
);
$stmt = $parser->statements[0];
$this->assertEquals(
'CREATE VIEW number_sequence_view AS'
. ' WITH RECURSIVE number_sequence AS ('
. 'SELECT 1 AS `number`'
. ' UNION ALL'
. ' SELECT `number`+ 1'
. ' FROM number_sequence'
. ' WHERE `number` < 5'
. ')'
. ' SELECT * FROM number_sequence ',
$stmt->build(),
);
}

public function testBuilderViewComplex(): void
Expand Down
13 changes: 13 additions & 0 deletions tests/Components/OptionsArrayTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -136,4 +136,17 @@ public function testBuild(): void
$component->build(),
);
}

public function testBuildWithRecursive(): void
{
$component = OptionsArrays::parse(
new Parser(),
$this->getTokensList('RECURSIVE'),
['RECURSIVE' => 1],
);
$this->assertEquals(
'RECURSIVE',
$component->build(),
);
}
}
64 changes: 64 additions & 0 deletions tests/Parser/WithStatementTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -70,6 +70,70 @@ public function testWith(): void
$this->assertEquals($expected, $parser->statements[0]->build());
}

public function testWithRecursive(): void
{
$sql = <<<'SQL'
WITH RECURSIVE number_sequence AS (
SELECT 1 AS `number`
UNION ALL
SELECT `number` + 1
FROM number_sequence
WHERE `number` < 5
)
SELECT * FROM number_sequence;
SQL;

$lexer = new Lexer($sql);

$lexerErrors = $this->getErrorsAsArray($lexer);
$this->assertCount(0, $lexerErrors);
$parser = new Parser($lexer->list);
$parserErrors = $this->getErrorsAsArray($parser);
$this->assertCount(0, $parserErrors);
$this->assertCount(1, $parser->statements);

// phpcs:disable Generic.Files.LineLength.TooLong
$expected = <<<'SQL'
WITH RECURSIVE number_sequence AS (SELECT 1 AS `number` UNION ALL SELECT `number`+ 1 FROM number_sequence WHERE `number` < 5) SELECT * FROM number_sequence
SQL;
// phpcs:enable
$this->assertEquals($expected, $parser->statements[0]->build());
}

public function testWithRecursiveWithers(): void
{
$sql = <<<'SQL'
WITH RECURSIVE cte AS
(
SELECT 1 AS n, CAST('abc' AS CHAR(20)) AS str
UNION ALL
SELECT n + 1, CONCAT(str, str) FROM cte WHERE n < 3
), cte2 AS
(
SELECT 1 AS n, CAST('def' AS CHAR(20)) AS str
UNION ALL
SELECT n + 1, CONCAT(str, str) FROM cte WHERE n < 3
)
SELECT * FROM cte UNION SELECT * FROM cte2;
SQL;

$lexer = new Lexer($sql);

$lexerErrors = $this->getErrorsAsArray($lexer);
$this->assertCount(0, $lexerErrors);
$parser = new Parser($lexer->list);
$parserErrors = $this->getErrorsAsArray($parser);
$this->assertCount(0, $parserErrors);
$this->assertCount(1, $parser->statements);

// phpcs:disable Generic.Files.LineLength.TooLong
$expected = <<<'SQL'
WITH RECURSIVE cte AS (SELECT 1 AS `n`, CAST('abc' AS CHAR(20)) AS `str` UNION ALL SELECT n+ 1, CONCAT(str, str) FROM cte WHERE n < 3), cte2 AS (SELECT 1 AS `n`, CAST('def' AS CHAR(20)) AS `str` UNION ALL SELECT n+ 1, CONCAT(str, str) FROM cte WHERE n < 3) SELECT * FROM cte UNION SELECT * FROM cte2
SQL;
// phpcs:enable
$this->assertEquals($expected, $parser->statements[0]->build());
}

public function testWithHasErrors(): void
{
$sql = <<<'SQL'
Expand Down

0 comments on commit 8db6524

Please sign in to comment.