2007-05-16 09:07:22 +00:00
|
|
|
<?php
|
|
|
|
/*
|
|
|
|
* $Id: TokenizerTestCase.php 1181 2007-03-20 23:22:51Z gnat $
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
|
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
|
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
|
|
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
|
|
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
|
|
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
|
|
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
|
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
|
|
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
|
|
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
*
|
|
|
|
* This software consists of voluntary contributions made by many individuals
|
|
|
|
* and is licensed under the LGPL. For more information, see
|
|
|
|
* <http://www.phpdoctrine.com>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Doctrine_Tokenizer_TestCase
|
|
|
|
* This class tests the functinality of Doctrine_Tokenizer component
|
|
|
|
*
|
|
|
|
* @package Doctrine
|
|
|
|
* @license http://www.opensource.org/licenses/lgpl-license.php LGPL
|
|
|
|
* @category Object Relational Mapping
|
|
|
|
* @link www.phpdoctrine.com
|
|
|
|
* @since 1.0
|
|
|
|
* @version $Revision: 1181 $
|
|
|
|
* @author Konsta Vesterinen <kvesteri@cc.hut.fi>
|
|
|
|
*/
|
2007-08-03 11:52:47 +00:00
|
|
|
class Doctrine_Tokenizer_TestCase extends Doctrine_UnitTestCase
|
2007-05-16 09:07:22 +00:00
|
|
|
{
|
2007-08-03 11:52:47 +00:00
|
|
|
public function prepareData()
|
2007-05-29 19:03:19 +00:00
|
|
|
{ }
|
2007-08-03 11:52:47 +00:00
|
|
|
public function prepareTables()
|
2007-05-29 19:03:19 +00:00
|
|
|
{ }
|
2007-08-03 11:52:47 +00:00
|
|
|
|
2007-05-16 09:07:22 +00:00
|
|
|
public function testSqlExplode()
|
|
|
|
{
|
2007-11-24 18:58:33 +00:00
|
|
|
$tokenizer = new Doctrine_Query_Tokenizer();
|
2007-12-07 03:23:09 +00:00
|
|
|
|
2007-05-16 09:07:22 +00:00
|
|
|
$str = "word1 word2 word3";
|
2007-11-24 18:58:33 +00:00
|
|
|
$a = $tokenizer->sqlExplode($str);
|
2007-08-03 11:52:47 +00:00
|
|
|
|
2007-05-16 09:07:22 +00:00
|
|
|
$this->assertEqual($a, array("word1", "word2", "word3"));
|
2007-08-03 11:52:47 +00:00
|
|
|
|
2007-05-16 09:07:22 +00:00
|
|
|
$str = "word1 (word2 word3)";
|
2007-11-24 18:58:33 +00:00
|
|
|
$a = $tokenizer->sqlExplode($str);
|
2007-05-16 09:07:22 +00:00
|
|
|
$this->assertEqual($a, array("word1", "(word2 word3)"));
|
2007-08-03 11:52:47 +00:00
|
|
|
|
2007-05-16 09:07:22 +00:00
|
|
|
$str = "word1 'word2 word3'";
|
2007-11-24 18:58:33 +00:00
|
|
|
$a = $tokenizer->sqlExplode($str);
|
2007-05-16 09:07:22 +00:00
|
|
|
$this->assertEqual($a, array("word1", "'word2 word3'"));
|
|
|
|
|
|
|
|
$str = "word1 'word2 word3'";
|
2007-11-24 18:58:33 +00:00
|
|
|
$a = $tokenizer->sqlExplode($str);
|
2007-05-16 09:07:22 +00:00
|
|
|
$this->assertEqual($a, array("word1", "'word2 word3'"));
|
|
|
|
|
|
|
|
$str = "word1 \"word2 word3\"";
|
2007-11-24 18:58:33 +00:00
|
|
|
$a = $tokenizer->sqlExplode($str);
|
2007-05-16 09:07:22 +00:00
|
|
|
$this->assertEqual($a, array("word1", "\"word2 word3\""));
|
|
|
|
|
|
|
|
$str = "word1 ((word2) word3)";
|
2007-11-24 18:58:33 +00:00
|
|
|
$a = $tokenizer->sqlExplode($str);
|
2007-05-16 09:07:22 +00:00
|
|
|
$this->assertEqual($a, array("word1", "((word2) word3)"));
|
|
|
|
|
|
|
|
$str = "word1 ( (word2) 'word3')";
|
2007-11-24 18:58:33 +00:00
|
|
|
$a = $tokenizer->sqlExplode($str);
|
2007-05-16 09:07:22 +00:00
|
|
|
$this->assertEqual($a, array("word1", "( (word2) 'word3')"));
|
|
|
|
|
|
|
|
$str = "word1 ( \"(word2) 'word3')";
|
2007-11-24 18:58:33 +00:00
|
|
|
$a = $tokenizer->sqlExplode($str);
|
2007-05-16 09:07:22 +00:00
|
|
|
$this->assertEqual($a, array("word1", "( \"(word2) 'word3')"));
|
|
|
|
|
|
|
|
$str = "word1 ( ''(word2) 'word3')";
|
2007-11-24 18:58:33 +00:00
|
|
|
$a = $tokenizer->sqlExplode($str);
|
2007-05-16 09:07:22 +00:00
|
|
|
$this->assertEqual($a, array("word1", "( ''(word2) 'word3')"));
|
|
|
|
|
|
|
|
$str = "word1 ( '()()'(word2) 'word3')";
|
2007-11-24 18:58:33 +00:00
|
|
|
$a = $tokenizer->sqlExplode($str);
|
2007-05-16 09:07:22 +00:00
|
|
|
$this->assertEqual($a, array("word1", "( '()()'(word2) 'word3')"));
|
|
|
|
|
|
|
|
$str = "word1 'word2)() word3'";
|
2007-11-24 18:58:33 +00:00
|
|
|
$a = $tokenizer->sqlExplode($str);
|
2007-05-16 09:07:22 +00:00
|
|
|
$this->assertEqual($a, array("word1", "'word2)() word3'"));
|
|
|
|
|
|
|
|
$str = "word1 (word2() word3)";
|
2007-11-24 18:58:33 +00:00
|
|
|
$a = $tokenizer->sqlExplode($str);
|
2007-05-16 09:07:22 +00:00
|
|
|
$this->assertEqual($a, array("word1", "(word2() word3)"));
|
|
|
|
|
|
|
|
$str = "word1 \"word2)() word3\"";
|
2007-11-24 18:58:33 +00:00
|
|
|
$a = $tokenizer->sqlExplode($str);
|
2007-05-16 09:07:22 +00:00
|
|
|
$this->assertEqual($a, array("word1", "\"word2)() word3\""));
|
|
|
|
|
|
|
|
$str = "something (subquery '')";
|
2007-11-24 18:58:33 +00:00
|
|
|
$a = $tokenizer->sqlExplode($str);
|
2007-05-16 09:07:22 +00:00
|
|
|
$this->assertEqual($a, array("something", "(subquery '')"));
|
|
|
|
|
|
|
|
$str = "something (( ))";
|
2007-11-24 18:58:33 +00:00
|
|
|
$a = $tokenizer->sqlExplode($str);
|
2007-08-03 11:52:47 +00:00
|
|
|
$this->assertEqual($a, array("something", "(( ))"));
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testSqlExplode2()
|
|
|
|
{
|
2007-11-24 18:58:33 +00:00
|
|
|
$tokenizer = new Doctrine_Query_Tokenizer();
|
2007-08-03 11:52:47 +00:00
|
|
|
$str = 'rdbms (dbal OR database)';
|
2007-11-24 18:58:33 +00:00
|
|
|
$a = $tokenizer->sqlExplode($str, ' OR ');
|
2007-08-03 11:52:47 +00:00
|
|
|
|
|
|
|
$this->assertEqual($a, array('rdbms (dbal OR database)'));
|
2007-05-16 09:07:22 +00:00
|
|
|
}
|
2007-10-29 20:25:38 +00:00
|
|
|
|
2007-12-07 03:23:09 +00:00
|
|
|
public function testBracketExplode()
|
|
|
|
{
|
|
|
|
$tokenizer = new Doctrine_Query_Tokenizer();
|
|
|
|
|
|
|
|
$str = 'foo.field AND bar.field';
|
|
|
|
$a = $tokenizer->bracketExplode($str, array(' \&\& ', ' AND '), '(', ')');
|
|
|
|
$this->assertEqual($a, array('foo.field', 'bar.field'));
|
|
|
|
|
|
|
|
// delimiters should be case insensitive
|
|
|
|
$str = 'foo.field and bar.field';
|
|
|
|
$a = $tokenizer->bracketExplode($str, array(' \&\& ', ' AND '), '(', ')');
|
|
|
|
$this->assertEqual($a, array('foo.field', 'bar.field'));
|
|
|
|
}
|
|
|
|
|
2007-10-29 20:25:38 +00:00
|
|
|
|
|
|
|
public function testQuoteExplodedShouldQuoteArray()
|
|
|
|
{
|
2007-11-24 18:58:33 +00:00
|
|
|
$tokenizer = new Doctrine_Query_Tokenizer();
|
|
|
|
$term = $tokenizer->quoteExplode("test", array("'test'", "test2"));
|
2007-10-29 20:25:38 +00:00
|
|
|
$this->assertEqual($term[0], "test");
|
|
|
|
}
|
2007-05-16 09:07:22 +00:00
|
|
|
}
|