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
|
<?php
declare(strict_types=1);
namespace PhpMyAdmin\SqlParser\Tests\Builder;
use PhpMyAdmin\SqlParser\Parser;
use PhpMyAdmin\SqlParser\Tests\TestCase;
class ExplainStatementTest extends TestCase
{
public function testBuilder(): void
{
/* Assertion 1 */
$query = 'EXPLAIN SELECT * FROM test;';
$parser = new Parser($query);
$stmt = $parser->statements[0];
$this->assertEquals(
'EXPLAIN SELECT * FROM test',
$stmt->build()
);
/* Assertion 2 */
$query = 'EXPLAIN ANALYZE SELECT * FROM tablename;';
$parser = new Parser($query);
$stmt = $parser->statements[0];
$this->assertEquals(
'EXPLAIN ANALYZE SELECT * FROM tablename',
$stmt->build()
);
/* Assertion 3 */
$query = 'DESC ANALYZE SELECT * FROM tablename;';
$parser = new Parser($query);
$stmt = $parser->statements[0];
$this->assertEquals(
'DESC ANALYZE SELECT * FROM tablename',
$stmt->build()
);
/* Assertion 4 */
$query = 'ANALYZE SELECT * FROM tablename;';
$parser = new Parser($query);
$stmt = $parser->statements[0];
$this->assertEquals(
'ANALYZE SELECT * FROM tablename',
$stmt->build()
);
/* Assertion 5 */
$query = 'DESCRIBE tablename;';
$parser = new Parser($query);
$stmt = $parser->statements[0];
$this->assertEquals(
'DESCRIBE `tablename`',
$stmt->build()
);
/* Assertion 6 */
$query = 'DESC FOR CONNECTION 458';
$parser = new Parser($query);
$stmt = $parser->statements[0];
$this->assertEquals(
'DESC FOR CONNECTION 458',
$stmt->build()
);
/* Assertion 7 */
$query = 'EXPLAIN FORMAT=TREE SELECT * FROM db;';
$parser = new Parser($query);
$stmt = $parser->statements[0];
$this->assertEquals(
'EXPLAIN FORMAT=TREE SELECT * FROM db',
$stmt->build()
);
/* Assertion 8 */
$query = 'DESCRIBE tablename colname;';
$parser = new Parser($query);
$stmt = $parser->statements[0];
$this->assertEquals(
'DESCRIBE `tablename` `colname`',
$stmt->build()
);
/* Assertion 9 */
$query = 'DESCRIBE tablename \'col%me\';';
$parser = new Parser($query);
$stmt = $parser->statements[0];
$this->assertEquals(
'DESCRIBE `tablename` `col%me`',
$stmt->build()
);
/* Assertion 9 */
$query = 'DESCRIBE db.tablename \'col%me\';';
$parser = new Parser($query);
$stmt = $parser->statements[0];
$this->assertEquals(
'DESCRIBE `db`.`tablename` `col%me`',
$stmt->build()
);
}
}
|