. */ /** * Doctrine_Search_Query_TestCase * * @package Doctrine * @author Konsta Vesterinen * @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'); 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(); } public function testParseClauseSupportsAndOperator() { $q = new Doctrine_Search_Query('SearchTestIndex'); $ret = $q->parseClause('doctrine AND orm'); $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 = ?)'; $this->assertEqual($ret, $sql); } public function testParseClauseSupportsMixingOfOperatorsAndParenthesis() { $q = new Doctrine_Search_Query('SearchTestIndex'); $ret = $q->parseClause('((doctrine OR orm) AND dbal) OR database'); $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 = ?'; $this->assertEqual($ret, $sql); } public function testParseClauseSupportsMixingOfOperators3() { $q = new Doctrine_Search_Query('SearchTestIndex'); $ret = $q->parseClause('doctrine OR orm AND dbal'); $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 = ?)'; $this->assertEqual($ret, $sql); } public function testParseClauseSupportsMixingOfOperators() { $q = new Doctrine_Search_Query('SearchTestIndex'); $ret = $q->parseClause('(doctrine OR orm) AND dbal'); $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 = ?)'; $this->assertEqual($ret, $sql); } public function testParseClauseSupportsMixingOfOperators2() { $q = new Doctrine_Search_Query('SearchTestIndex'); $ret = $q->parseClause('(doctrine OR orm) dbal'); $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 = ?)'; $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'); $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 = ?)'; $this->assertEqual($ret, $sql); } public function testParseClauseSupportsMixingOfOperatorsAndDeeplyNestedParenthesis2() { $q = new Doctrine_Search_Query('SearchTestIndex'); $ret = $q->parseClause('rdbms (((doctrine OR orm) AND 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 = ?) AND search_test_id IN (SELECT search_test_id FROM search_test_index WHERE keyword = ?)) OR keyword = ?)'; $this->assertEqual($ret, $sql); } public function testParseClauseSupportsNegationOperator() { $q = new Doctrine_Search_Query('SearchTestIndex'); $ret = $q->parseClause('rdbms -doctrine'); $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 = ?)'; $this->assertEqual($ret, $sql); } public function testParseClauseOrOperator2() { $q = new Doctrine_Search_Query('SearchTestIndex'); $ret = $q->parseClause('rdbms doctrine 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 = ?'; $this->assertEqual($ret, $sql); } public function testParseClauseSupportsNegationOperatorWithOrOperator() { $q = new Doctrine_Search_Query('SearchTestIndex'); $ret = $q->parseClause('rdbms -doctrine OR database'); $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 = ?) ' . 'OR keyword = ?'; $this->assertEqual($ret, $sql); } 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 ' . '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 = ?) ' . 'GROUP BY search_test_id ORDER BY relevance'; $this->assertEqual($q->getSql(), $sql); } 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); } public function testQuerySupportsSingleWordSearch() { $q = new Doctrine_Search_Query('SearchTestIndex'); $q->search('doctrine'); $sql = 'SELECT COUNT(keyword) AS relevance, search_test_id ' . 'FROM search_test_index WHERE keyword = ? GROUP BY search_test_id ORDER BY relevance'; $this->assertEqual($q->getSql(), $sql); } public function testSearchSupportsMixingOfOperators() { $q = new Doctrine_Search_Query('SearchTestIndex'); $q->search('(doctrine OR orm) AND dbal'); $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 = ? OR keyword = ?) ' . '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->getSql(), $sql); } public function testSearchSupportsSingleTermWithQuotes() { $q = new Doctrine_Search_Query('SearchTestIndex'); $q->search("'doctrine orm'"); $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); } public function testSearchSupportsSingleLongTermWithQuotes() { $q = new Doctrine_Search_Query('SearchTestIndex'); $q->search("'doctrine orm dbal'"); $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 = ?) ' . 'AND (position + 2) = (SELECT position FROM search_test_index WHERE keyword = ?) ' . 'GROUP BY search_test_id ORDER BY relevance'; $this->assertEqual($q->getSql(), $sql); } public function testQuerySupportsMultiWordSearch() { $q = new Doctrine_Search_Query('SearchTestIndex'); $q->search('doctrine 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 = ?) ' . '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->getSql(), $sql); } public function testSearchSupportsMultipleTermsWithQuotes() { $q = new Doctrine_Search_Query('SearchTestIndex'); $q->search("doctrine 'orm database'"); $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 = ?) ' . '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 = ?)) ' . 'GROUP BY search_test_id ORDER BY relevance'; $this->assertEqual($q->getSql(), $sql); } public function testSearchReturnsFalseForEmptyStrings() { $q = new Doctrine_Search_Query('SearchTestIndex'); $result = $q->search(' '); $this->assertFalse($result); } }