Query/tests/core/query_parser_test.php

58 lines
1.4 KiB
PHP
Raw Normal View History

2012-08-02 11:59:11 -04:00
<?php
/**
* Query
*
* Free Query Builder / Database Abstraction Layer
*
* @package Query
* @author Timothy J. Warren
* @copyright Copyright (c) 2012 - 2014
2012-08-02 11:59:11 -04:00
* @link https://github.com/aviat4ion/Query
* @license http://philsturgeon.co.uk/code/dbad-license
*/
// --------------------------------------------------------------------------
2012-08-09 12:15:36 -04:00
/**
* Tests for the Query Parser
*/
class Query_Parser_Test extends Query_TestCase {
2012-08-02 11:59:11 -04:00
2014-02-14 22:08:19 -05:00
public function setUp()
2012-08-02 11:59:11 -04:00
{
$db = new Query\Drivers\Sqlite\Driver("sqlite::memory:");
2015-11-10 11:18:11 -05:00
$this->parser = new Query\QueryParser($db);
2012-08-02 11:59:11 -04:00
}
public function TestGeneric()
{
2012-08-09 12:15:36 -04:00
$matches = $this->parser->parse_join('table1.field1=table2.field2');
$this->assertEqual($matches['combined'], array(
2012-08-09 12:15:36 -04:00
'table1.field1', '=', 'table2.field2'
));
2012-08-02 11:59:11 -04:00
}
2014-02-14 22:08:19 -05:00
public function testGeneric2()
2012-08-02 11:59:11 -04:00
{
2012-08-09 12:15:36 -04:00
$matches = $this->parser->parse_join('db1.table1.field1!=db2.table2.field2');
$this->assertEqual($matches['combined'], array(
2012-08-09 12:15:36 -04:00
'db1.table1.field1','!=','db2.table2.field2'
));
}
2012-08-02 11:59:11 -04:00
2014-02-14 22:08:19 -05:00
public function testWUnderscore()
2012-08-09 12:15:36 -04:00
{
$matches = $this->parser->parse_join('table_1.field1 = tab_le2.field_2');
$this->assertEqual($matches['combined'], array(
2012-08-09 12:15:36 -04:00
'table_1.field1', '=', 'tab_le2.field_2'
));
2012-08-02 11:59:11 -04:00
}
2014-02-14 22:08:19 -05:00
public function testFunction()
2012-08-09 12:15:36 -04:00
{
$matches = $this->parser->parse_join('table1.field1 > SUM(3+5)');
$this->assertEqual($matches['combined'], array(
2012-08-09 12:15:36 -04:00
'table1.field1', '>', 'SUM(3+5)'
));
}
2012-08-02 11:59:11 -04:00
}