summaryrefslogtreecommitdiffstats
path: root/tests/Builder/StatementTest.php
diff options
context:
space:
mode:
authorDan Ungureanu <udan1107@gmail.com>2015-06-30 01:05:38 +0300
committerDan Ungureanu <udan1107@gmail.com>2015-06-30 01:05:38 +0300
commita2354cf85acd032efa374d1f9f611f02fdbe75f6 (patch)
tree3094a3144239860cb72c2f0871660a3f7c862e53 /tests/Builder/StatementTest.php
parent5f15789bd325c4fcd6642ecfeea18a5b639acc99 (diff)
downloadsql-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.php45
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
+ );
+ }
+}