2007-07-12 21:50:08 +00:00
< ? php
/*
* $Id $
*
* 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_Search_Query_TestCase
*
* @ package Doctrine
* @ author Konsta Vesterinen < kvesteri @ cc . hut . fi >
* @ license http :// www . opensource . org / licenses / lgpl - license . php LGPL
* @ category Object Relational Mapping
* @ link www . phpdoctrine . com
* @ since 1.0
* @ version $Revision $
*/
class Doctrine_Search_Query_TestCase extends Doctrine_UnitTestCase
{
public function prepareTables ()
{
$this -> tables = array ( 'SearchTest' , 'SearchTestIndex' );
2007-07-27 20:19:19 +00:00
2007-07-12 21:50:08 +00:00
parent :: prepareTables ();
}
public function prepareData ()
{ }
public function testInitData ()
{
$e = new SearchTest ();
$e -> title = 'Once there was an ORM framework' ;
$e -> content = 'There are many ORM frameworks, but nevertheless we decided to create one.' ;
$e -> save ();
$e = new SearchTest ();
$e -> title = 'Doctrine development continues' ;
$e -> content = 'The development has been going well so far.' ;
$e -> save ();
}
2007-07-30 19:34:05 +00:00
2007-07-27 19:03:48 +00:00
public function testParseClauseSupportsAndOperator ()
{
$q = new Doctrine_Search_Query ( 'SearchTestIndex' );
$ret = $q -> parseClause ( 'doctrine AND orm' );
2007-08-01 23:41:51 +00:00
$sql = 'search_test_id IN (SELECT search_test_id FROM search_test_index WHERE keyword = ?) '
. 'AND search_test_id IN (SELECT search_test_id FROM search_test_index WHERE keyword = ?)' ;
2007-07-27 20:19:19 +00:00
$this -> assertEqual ( $ret , $sql );
}
public function testParseClauseSupportsMixingOfOperatorsAndParenthesis ()
{
$q = new Doctrine_Search_Query ( 'SearchTestIndex' );
$ret = $q -> parseClause ( '((doctrine OR orm) AND dbal) OR database' );
2007-08-01 23:41:51 +00:00
$sql = '(search_test_id IN (SELECT search_test_id FROM search_test_index WHERE keyword = ? OR keyword = ?) AND search_test_id IN (SELECT search_test_id FROM search_test_index WHERE keyword = ?)) OR keyword = ?' ;
2007-07-27 19:03:48 +00:00
$this -> assertEqual ( $ret , $sql );
}
public function testParseClauseSupportsMixingOfOperators3 ()
{
$q = new Doctrine_Search_Query ( 'SearchTestIndex' );
$ret = $q -> parseClause ( 'doctrine OR orm AND dbal' );
2007-08-01 23:41:51 +00:00
$sql = 'keyword = ? OR search_test_id IN (SELECT search_test_id FROM search_test_index WHERE keyword = ?) AND search_test_id IN (SELECT search_test_id FROM search_test_index WHERE keyword = ?)' ;
2007-07-27 20:19:19 +00:00
2007-07-27 19:03:48 +00:00
$this -> assertEqual ( $ret , $sql );
}
public function testParseClauseSupportsMixingOfOperators ()
{
$q = new Doctrine_Search_Query ( 'SearchTestIndex' );
$ret = $q -> parseClause ( '(doctrine OR orm) AND dbal' );
2007-08-01 23:41:51 +00:00
$sql = 'search_test_id IN (SELECT search_test_id FROM search_test_index WHERE keyword = ? OR keyword = ?) AND search_test_id IN (SELECT search_test_id FROM search_test_index WHERE keyword = ?)' ;
2007-07-27 20:19:19 +00:00
2007-07-27 19:03:48 +00:00
$this -> assertEqual ( $ret , $sql );
}
public function testParseClauseSupportsMixingOfOperators2 ()
{
$q = new Doctrine_Search_Query ( 'SearchTestIndex' );
$ret = $q -> parseClause ( '(doctrine OR orm) dbal' );
2007-07-27 20:19:19 +00:00
2007-08-01 23:41:51 +00:00
$sql = 'search_test_id IN (SELECT search_test_id FROM search_test_index WHERE keyword = ? OR keyword = ?) AND search_test_id IN (SELECT search_test_id FROM search_test_index WHERE keyword = ?)' ;
2007-07-27 20:19:19 +00:00
$this -> assertEqual ( $ret , $sql );
}
public function testParseClauseSupportsMixingOfOperatorsAndDeeplyNestedParenthesis ()
{
$q = new Doctrine_Search_Query ( 'SearchTestIndex' );
$ret = $q -> parseClause ( '(((doctrine OR orm) AND dbal) OR database) AND rdbms' );
2007-08-01 23:41:51 +00:00
$sql = '((search_test_id IN (SELECT search_test_id FROM search_test_index WHERE keyword = ? OR keyword = ?) AND search_test_id IN (SELECT search_test_id FROM search_test_index WHERE keyword = ?)) OR keyword = ?) AND search_test_id IN (SELECT search_test_id FROM search_test_index WHERE keyword = ?)' ;
$this -> assertEqual ( $ret , $sql );
}
public function testParseClauseSupportsMixingOfOperatorsAndParenthesis2 ()
{
$q = new Doctrine_Search_Query ( 'SearchTestIndex' );
$ret = $q -> parseClause ( 'rdbms (dbal OR database)' );
$sql = 'search_test_id IN (SELECT search_test_id FROM search_test_index WHERE keyword = ?) AND search_test_id IN (SELECT search_test_id FROM search_test_index WHERE keyword = ? OR keyword = ?)' ;
2007-07-27 20:19:19 +00:00
2007-07-27 19:03:48 +00:00
$this -> assertEqual ( $ret , $sql );
}
2007-08-01 23:41:51 +00:00
2007-07-30 15:54:50 +00:00
public function testParseClauseSupportsMixingOfOperatorsAndDeeplyNestedParenthesis2 ()
{
$q = new Doctrine_Search_Query ( 'SearchTestIndex' );
$ret = $q -> parseClause ( 'rdbms (((doctrine OR orm) AND dbal) OR database)' );
2007-08-01 23:41:51 +00:00
$sql = 'search_test_id IN (SELECT search_test_id FROM search_test_index WHERE keyword = ?) AND ((search_test_id IN (SELECT search_test_id FROM search_test_index WHERE keyword = ? OR keyword = ?) AND search_test_id IN (SELECT search_test_id FROM search_test_index WHERE keyword = ?)) OR keyword = ?)' ;
2007-07-27 19:03:48 +00:00
2007-07-30 15:54:50 +00:00
$this -> assertEqual ( $ret , $sql );
}
2007-07-30 19:34:05 +00:00
2007-07-30 19:01:59 +00:00
public function testParseClauseSupportsNegationOperator ()
{
$q = new Doctrine_Search_Query ( 'SearchTestIndex' );
$ret = $q -> parseClause ( 'rdbms -doctrine' );
2007-08-01 23:41:51 +00:00
$sql = 'search_test_id IN (SELECT search_test_id FROM search_test_index WHERE keyword = ?) AND '
. 'search_test_id NOT IN (SELECT search_test_id FROM search_test_index WHERE keyword = ?)' ;
2007-07-30 19:01:59 +00:00
$this -> assertEqual ( $ret , $sql );
}
2007-08-01 23:41:51 +00:00
2007-07-30 19:01:59 +00:00
public function testParseClauseOrOperator2 ()
{
$q = new Doctrine_Search_Query ( 'SearchTestIndex' );
$ret = $q -> parseClause ( 'rdbms doctrine OR database' );
2007-08-01 23:41:51 +00:00
$sql = 'search_test_id IN (SELECT search_test_id FROM search_test_index WHERE keyword = ?) AND '
. 'search_test_id IN (SELECT search_test_id FROM search_test_index WHERE keyword = ?) '
2007-07-30 19:01:59 +00:00
. 'OR keyword = ?' ;
$this -> assertEqual ( $ret , $sql );
}
2007-08-01 23:41:51 +00:00
2007-07-30 19:01:59 +00:00
public function testParseClauseSupportsNegationOperatorWithOrOperator ()
{
$q = new Doctrine_Search_Query ( 'SearchTestIndex' );
$ret = $q -> parseClause ( 'rdbms -doctrine OR database' );
2007-08-01 23:41:51 +00:00
$sql = 'search_test_id IN (SELECT search_test_id FROM search_test_index WHERE keyword = ?) AND '
. 'search_test_id NOT IN (SELECT search_test_id FROM search_test_index WHERE keyword = ?) '
2007-07-30 19:01:59 +00:00
. 'OR keyword = ?' ;
$this -> assertEqual ( $ret , $sql );
}
2007-08-01 23:41:51 +00:00
2007-07-27 19:03:48 +00:00
public function testSearchSupportsAndOperator ()
{
$q = new Doctrine_Search_Query ( 'SearchTestIndex' );
$q -> search ( 'doctrine AND orm' );
$sql = 'SELECT COUNT(keyword) AS relevance, search_test_id '
. 'FROM search_test_index '
2007-08-01 23:41:51 +00:00
. 'WHERE search_test_id IN (SELECT search_test_id FROM search_test_index WHERE keyword = ?) '
. 'AND search_test_id IN (SELECT search_test_id FROM search_test_index WHERE keyword = ?) '
2007-07-27 19:03:48 +00:00
. 'GROUP BY search_test_id ORDER BY relevance' ;
$this -> assertEqual ( $q -> getSql (), $sql );
}
2007-08-01 23:41:51 +00:00
2007-07-27 19:03:48 +00:00
public function testSearchSupportsOrOperator ()
{
$q = new Doctrine_Search_Query ( 'SearchTestIndex' );
$q -> search ( 'doctrine OR orm' );
$sql = 'SELECT COUNT(keyword) AS relevance, search_test_id '
. 'FROM search_test_index '
. 'WHERE keyword = ? OR keyword = ? '
. 'GROUP BY search_test_id ORDER BY relevance' ;
$this -> assertEqual ( $q -> getSql (), $sql );
}
2007-07-30 19:01:59 +00:00
public function testQuerySupportsSingleWordSearch ()
2007-07-27 19:03:48 +00:00
{
$q = new Doctrine_Search_Query ( 'SearchTestIndex' );
2007-07-30 19:01:59 +00:00
$q -> search ( 'doctrine' );
2007-07-27 19:03:48 +00:00
$sql = 'SELECT COUNT(keyword) AS relevance, search_test_id '
2007-07-30 19:01:59 +00:00
. 'FROM search_test_index WHERE keyword = ? GROUP BY search_test_id ORDER BY relevance' ;
2007-07-27 19:03:48 +00:00
$this -> assertEqual ( $q -> getSql (), $sql );
}
2007-07-30 19:34:05 +00:00
2007-07-30 19:01:59 +00:00
public function testSearchSupportsMixingOfOperators ()
2007-07-12 21:50:08 +00:00
{
2007-07-26 19:06:42 +00:00
$q = new Doctrine_Search_Query ( 'SearchTestIndex' );
2007-07-30 19:01:59 +00:00
$q -> search ( '(doctrine OR orm) AND dbal' );
2007-07-26 23:44:18 +00:00
$sql = 'SELECT COUNT(keyword) AS relevance, search_test_id '
2007-07-30 19:01:59 +00:00
. 'FROM search_test_index '
2007-08-01 23:41:51 +00:00
. 'WHERE search_test_id IN (SELECT search_test_id FROM search_test_index WHERE keyword = ? OR keyword = ?) '
. 'AND search_test_id IN (SELECT search_test_id FROM search_test_index WHERE keyword = ?) '
2007-07-30 19:01:59 +00:00
. 'GROUP BY search_test_id ORDER BY relevance' ;
2007-07-26 23:44:18 +00:00
$this -> assertEqual ( $q -> getSql (), $sql );
}
public function testSearchSupportsSingleTermWithQuotes ()
{
$q = new Doctrine_Search_Query ( 'SearchTestIndex' );
$q -> search ( " 'doctrine orm' " );
2007-07-30 19:01:59 +00:00
2007-07-26 23:44:18 +00:00
$sql = 'SELECT COUNT(keyword) AS relevance, search_test_id '
. 'FROM search_test_index WHERE keyword = ? '
. 'AND (position + 1) = (SELECT position FROM search_test_index WHERE keyword = ?) '
. 'GROUP BY search_test_id ORDER BY relevance' ;
$this -> assertEqual ( $q -> getSql (), $sql );
}
2007-07-30 19:01:59 +00:00
2007-07-26 23:44:18 +00:00
public function testSearchSupportsSingleLongTermWithQuotes ()
{
$q = new Doctrine_Search_Query ( 'SearchTestIndex' );
$q -> search ( " 'doctrine orm dbal' " );
2007-07-30 19:01:59 +00:00
2007-07-26 19:06:42 +00:00
$sql = 'SELECT COUNT(keyword) AS relevance, search_test_id '
2007-07-26 23:44:18 +00:00
. 'FROM search_test_index WHERE keyword = ? '
. 'AND (position + 1) = (SELECT position FROM search_test_index WHERE keyword = ?) '
. 'AND (position + 2) = (SELECT position FROM search_test_index WHERE keyword = ?) '
. 'GROUP BY search_test_id ORDER BY relevance' ;
2007-08-02 12:07:56 +00:00
$this -> assertEqual ( $q -> getParams (), array ( 'doctrine' , 'orm' , 'dbal' ));
2007-07-26 19:06:42 +00:00
$this -> assertEqual ( $q -> getSql (), $sql );
2007-07-12 21:50:08 +00:00
}
2007-07-26 23:44:18 +00:00
2007-07-26 19:06:42 +00:00
public function testQuerySupportsMultiWordSearch ()
2007-07-12 21:50:08 +00:00
{
2007-07-26 19:06:42 +00:00
$q = new Doctrine_Search_Query ( 'SearchTestIndex' );
$q -> search ( 'doctrine orm' );
2007-07-12 21:50:08 +00:00
2007-07-26 19:06:42 +00:00
$sql = 'SELECT COUNT(keyword) AS relevance, search_test_id '
. 'FROM search_test_index '
2007-08-01 23:41:51 +00:00
. 'WHERE search_test_id IN (SELECT search_test_id FROM search_test_index WHERE keyword = ?) '
. 'AND search_test_id IN (SELECT search_test_id FROM search_test_index WHERE keyword = ?) '
2007-07-26 23:44:18 +00:00
. 'GROUP BY search_test_id ORDER BY relevance' ;
2007-07-12 21:50:08 +00:00
2007-07-26 19:06:42 +00:00
$this -> assertEqual ( $q -> getSql (), $sql );
2007-07-12 21:50:08 +00:00
}
2007-07-26 23:44:18 +00:00
2007-08-02 12:01:22 +00:00
public function testQuerySupportsMultiWordSearchAndSingleLetterWildcards ()
{
$q = new Doctrine_Search_Query ( 'SearchTestIndex' );
$q -> search ( 'doct?ine orm' );
$sql = 'SELECT COUNT(keyword) AS relevance, search_test_id '
. 'FROM search_test_index '
. 'WHERE search_test_id IN (SELECT search_test_id FROM search_test_index WHERE keyword LIKE ?) '
. 'AND search_test_id IN (SELECT search_test_id FROM search_test_index WHERE keyword = ?) '
. 'GROUP BY search_test_id ORDER BY relevance' ;
$this -> assertEqual ( $q -> getParams (), array ( 'doct?ine' , 'orm' ));
$this -> assertEqual ( $q -> getSql (), $sql );
}
public function testQuerySupportsMultiWordSearchAndMultiLetterWildcards ()
{
$q = new Doctrine_Search_Query ( 'SearchTestIndex' );
$q -> search ( 'doc* orm' );
$sql = 'SELECT COUNT(keyword) AS relevance, search_test_id '
. 'FROM search_test_index '
. 'WHERE search_test_id IN (SELECT search_test_id FROM search_test_index WHERE keyword LIKE ?) '
. 'AND search_test_id IN (SELECT search_test_id FROM search_test_index WHERE keyword = ?) '
. 'GROUP BY search_test_id ORDER BY relevance' ;
$this -> assertEqual ( $q -> getParams (), array ( 'doc%' , 'orm' ));
$this -> assertEqual ( $q -> getSql (), $sql );
}
2007-07-26 23:44:18 +00:00
public function testSearchSupportsMultipleTermsWithQuotes ()
2007-07-12 21:50:08 +00:00
{
2007-07-26 19:06:42 +00:00
$q = new Doctrine_Search_Query ( 'SearchTestIndex' );
2007-07-26 23:44:18 +00:00
$q -> search ( " doctrine 'orm database' " );
2007-07-26 19:06:42 +00:00
$sql = 'SELECT COUNT(keyword) AS relevance, search_test_id '
. 'FROM search_test_index '
2007-08-01 23:41:51 +00:00
. 'WHERE search_test_id IN (SELECT search_test_id FROM search_test_index WHERE keyword = ?) '
. 'AND search_test_id IN (SELECT search_test_id FROM search_test_index WHERE keyword = ? '
. 'AND (position + 1) = (SELECT position FROM search_test_index WHERE keyword = ?)) '
2007-07-26 23:44:18 +00:00
. 'GROUP BY search_test_id ORDER BY relevance' ;
2007-07-12 21:50:08 +00:00
2007-08-02 12:07:56 +00:00
$this -> assertEqual ( $q -> getParams (), array ( 'doctrine' , 'orm' , 'database' ));
2007-07-26 19:06:42 +00:00
$this -> assertEqual ( $q -> getSql (), $sql );
}
2007-07-30 19:01:59 +00:00
2007-07-26 23:44:18 +00:00
public function testSearchReturnsFalseForEmptyStrings ()
{
$q = new Doctrine_Search_Query ( 'SearchTestIndex' );
$result = $q -> search ( ' ' );
$this -> assertFalse ( $result );
2007-07-12 21:50:08 +00:00
}
2007-08-02 00:05:24 +00:00
2007-07-12 21:50:08 +00:00
}