diff options
author | Dan Ungureanu <udan1107@gmail.com> | 2015-06-30 01:05:38 +0300 |
---|---|---|
committer | Dan Ungureanu <udan1107@gmail.com> | 2015-06-30 01:05:38 +0300 |
commit | a2354cf85acd032efa374d1f9f611f02fdbe75f6 (patch) | |
tree | 3094a3144239860cb72c2f0871660a3f7c862e53 /tests/Builder/StatementTest.php | |
parent | 5f15789bd325c4fcd6642ecfeea18a5b639acc99 (diff) | |
download | sql-parser-a2354cf85acd032efa374d1f9f611f02fdbe75f6.zip sql-parser-a2354cf85acd032efa374d1f9f611f02fdbe75f6.tar.gz sql-parser-a2354cf85acd032efa374d1f9f611f02fdbe75f6.tar.bz2 |
Added statement builder (converts statement trees into executable query strings).
Implemented support for UNIONs in parser.
Code coverage is now over 99%.
Fixed CHECKSUM statement (typos).
Refactored code. Removed pieces of duplicated code.
Improved documentation and fixed coding style.
Improved PHPUnit's configuration (more test suites for fine-grained testing).
Diffstat (limited to 'tests/Builder/StatementTest.php')
-rw-r--r-- | tests/Builder/StatementTest.php | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/tests/Builder/StatementTest.php b/tests/Builder/StatementTest.php new file mode 100644 index 0000000..fc646a8 --- /dev/null +++ b/tests/Builder/StatementTest.php @@ -0,0 +1,45 @@ +<?php + +namespace SqlParser\Tests\Builder; + +use SqlParser\Builder; +use SqlParser\Fragments\OptionsFragment; +use SqlParser\Fragments\FieldFragment; +use SqlParser\Fragments\WhereKeyword; +use SqlParser\Fragments\LimitKeyword; +use SqlParser\Statements\SelectStatement; + +use SqlParser\Tests\TestCase; + +class StatementTest extends TestCase +{ + + public function testBuilder() + { + $stmt = new SelectStatement(); + + $stmt->options = new OptionsFragment(array('DISTINCT')); + + $stmt->expr[] = new FieldFragment('sakila', 'film', 'film_id', 'fid'); + $stmt->expr[] = new FieldFragment('COUNT(film_id)'); + + $stmt->from[] = new FieldFragment('', 'film', ''); + $stmt->from[] = new FieldFragment('', 'actor', ''); + + $stmt->where[] = new WhereKeyword('film_id > 10'); + $stmt->where[] = new WhereKeyword('OR'); + $stmt->where[] = new WhereKeyword('actor.age > 25'); + + $stmt->limit = new LimitKeyword(1, 10); + + $builder = new Builder($stmt); + + $this->assertEquals( + 'SELECT DISTINCT sakila.film.film_id AS fid, COUNT(film_id) ' . + 'FROM film, actor ' . + 'WHERE film_id > 10 OR actor.age > 25 ' . + 'LIMIT 10, 1 ', + $builder->query + ); + } +} |