Commit 83249bb5 authored by Bas de Nooijer's avatar Bas de Nooijer

Merge pull request #361 from basdenooijer/develop

Refactored unittest
parents 2bb12fb1 7f1f9fac
...@@ -45,46 +45,67 @@ class SpellcheckTest extends \PHPUnit_Framework_TestCase ...@@ -45,46 +45,67 @@ class SpellcheckTest extends \PHPUnit_Framework_TestCase
$this->parser = new Parser(); $this->parser = new Parser();
} }
public function testParseExtended() /**
* @dataProvider providerParseExtended
*/
public function testParseExtended($data)
{ {
$data = array(); $result = $this->parser->parse($this->query, null, $data);
$data['solr4'] = array(
$suggestions = $result->getSuggestions();
$this->assertEquals(false, $result->getCorrectlySpelled());
$this->assertEquals('dell', $suggestions[0]->getWord());
$this->assertEquals('ultrasharp', $suggestions[1]->getWord());
$this->assertEquals(6, $suggestions[1]->getStartOffset());
$this->assertEquals('ultrasharp', $suggestions[2]->getWord());
$this->assertEquals(16, $suggestions[2]->getStartOffset());
$this->assertEquals('dell ultrasharp', $result->getCollation()->getQuery());
$collations = $result->getCollations();
$this->assertEquals('dell ultrasharp', $collations[0]->getQuery());
$this->assertEquals('dell ultrasharp new', $collations[1]->getQuery());
}
public function providerParseExtended()
{
return array(
'solr4' => array(
'data' => array(
'spellcheck' => array( 'spellcheck' => array(
'suggestions' => array( 'suggestions' => array(
'delll', 'delll',
array ( array(
'numFound' => 1, 'numFound' => 1,
'startOffset' => 0, 'startOffset' => 0,
'endOffset' => 5, 'endOffset' => 5,
'origFreq' => 0, 'origFreq' => 0,
'suggestion' => array ( 'suggestion' => array(
0 => array ( 0 => array(
'word' => 'dell', 'word' => 'dell',
'freq' => 1, 'freq' => 1,
), ),
), ),
), ),
'ultrashar', 'ultrashar',
array ( array(
'numFound' => 1, 'numFound' => 1,
'startOffset' => 6, 'startOffset' => 6,
'endOffset' => 15, 'endOffset' => 15,
'origFreq' => 0, 'origFreq' => 0,
'suggestion' => array ( 'suggestion' => array(
0 => array ( 0 => array(
'word' => 'ultrasharp', 'word' => 'ultrasharp',
'freq' => 1, 'freq' => 1,
), ),
), ),
), ),
'ultrashar', 'ultrashar',
array ( array(
'numFound' => 1, 'numFound' => 1,
'startOffset' => 16, 'startOffset' => 16,
'endOffset' => 25, 'endOffset' => 25,
'origFreq' => 0, 'origFreq' => 0,
'suggestion' => array ( 'suggestion' => array(
0 => array ( 0 => array(
'word' => 'ultrasharp', 'word' => 'ultrasharp',
'freq' => 1, 'freq' => 1,
), ),
...@@ -93,13 +114,13 @@ class SpellcheckTest extends \PHPUnit_Framework_TestCase ...@@ -93,13 +114,13 @@ class SpellcheckTest extends \PHPUnit_Framework_TestCase
'correctlySpelled', 'correctlySpelled',
false, false,
'collation', 'collation',
array ( array(
0 => 'collationQuery', 0 => 'collationQuery',
1 => 'dell ultrasharp', 1 => 'dell ultrasharp',
2 => 'hits', 2 => 'hits',
3 => 0, 3 => 0,
4 => 'misspellingsAndCorrections', 4 => 'misspellingsAndCorrections',
5 => array ( 5 => array(
0 => 'delll', 0 => 'delll',
1 => 'dell', 1 => 'dell',
2 => 'ultrashar', 2 => 'ultrashar',
...@@ -107,13 +128,13 @@ class SpellcheckTest extends \PHPUnit_Framework_TestCase ...@@ -107,13 +128,13 @@ class SpellcheckTest extends \PHPUnit_Framework_TestCase
), ),
), ),
'collation', 'collation',
array ( array(
0 => 'collationQuery', 0 => 'collationQuery',
1 => 'dell ultrasharp new', 1 => 'dell ultrasharp new',
2 => 'hits', 2 => 'hits',
3 => 0, 3 => 0,
4 => 'misspellingsAndCorrections', 4 => 'misspellingsAndCorrections',
5 => array ( 5 => array(
0 => 'delll', 0 => 'delll',
1 => 'dell', 1 => 'dell',
2 => 'ultrashar', 2 => 'ultrashar',
...@@ -122,45 +143,46 @@ class SpellcheckTest extends \PHPUnit_Framework_TestCase ...@@ -122,45 +143,46 @@ class SpellcheckTest extends \PHPUnit_Framework_TestCase
), ),
) )
) )
); )
),
$data['solr5'] = array( 'solr5' => array(
'data' => array(
'spellcheck' => array( 'spellcheck' => array(
'suggestions' => array( 'suggestions' => array(
'delll', 'delll',
array ( array(
'numFound' => 1, 'numFound' => 1,
'startOffset' => 0, 'startOffset' => 0,
'endOffset' => 5, 'endOffset' => 5,
'origFreq' => 0, 'origFreq' => 0,
'suggestion' => array ( 'suggestion' => array(
0 => array ( 0 => array(
'word' => 'dell', 'word' => 'dell',
'freq' => 1, 'freq' => 1,
), ),
), ),
), ),
'ultrashar', 'ultrashar',
array ( array(
'numFound' => 1, 'numFound' => 1,
'startOffset' => 6, 'startOffset' => 6,
'endOffset' => 15, 'endOffset' => 15,
'origFreq' => 0, 'origFreq' => 0,
'suggestion' => array ( 'suggestion' => array(
0 => array ( 0 => array(
'word' => 'ultrasharp', 'word' => 'ultrasharp',
'freq' => 1, 'freq' => 1,
), ),
), ),
), ),
'ultrashar', 'ultrashar',
array ( array(
'numFound' => 1, 'numFound' => 1,
'startOffset' => 16, 'startOffset' => 16,
'endOffset' => 25, 'endOffset' => 25,
'origFreq' => 0, 'origFreq' => 0,
'suggestion' => array ( 'suggestion' => array(
0 => array ( 0 => array(
'word' => 'ultrasharp', 'word' => 'ultrasharp',
'freq' => 1, 'freq' => 1,
), ),
...@@ -171,13 +193,13 @@ class SpellcheckTest extends \PHPUnit_Framework_TestCase ...@@ -171,13 +193,13 @@ class SpellcheckTest extends \PHPUnit_Framework_TestCase
false, false,
'collations' => array( 'collations' => array(
'collation', 'collation',
array ( array(
0 => 'collationQuery', 0 => 'collationQuery',
1 => 'dell ultrasharp', 1 => 'dell ultrasharp',
2 => 'hits', 2 => 'hits',
3 => 0, 3 => 0,
4 => 'misspellingsAndCorrections', 4 => 'misspellingsAndCorrections',
5 => array ( 5 => array(
0 => 'delll', 0 => 'delll',
1 => 'dell', 1 => 'dell',
2 => 'ultrashar', 2 => 'ultrashar',
...@@ -185,13 +207,13 @@ class SpellcheckTest extends \PHPUnit_Framework_TestCase ...@@ -185,13 +207,13 @@ class SpellcheckTest extends \PHPUnit_Framework_TestCase
), ),
), ),
'collation', 'collation',
array ( array(
0 => 'collationQuery', 0 => 'collationQuery',
1 => 'dell ultrasharp new', 1 => 'dell ultrasharp new',
2 => 'hits', 2 => 'hits',
3 => 0, 3 => 0,
4 => 'misspellingsAndCorrections', 4 => 'misspellingsAndCorrections',
5 => array ( 5 => array(
0 => 'delll', 0 => 'delll',
1 => 'dell', 1 => 'dell',
2 => 'ultrashar', 2 => 'ultrashar',
...@@ -200,50 +222,53 @@ class SpellcheckTest extends \PHPUnit_Framework_TestCase ...@@ -200,50 +222,53 @@ class SpellcheckTest extends \PHPUnit_Framework_TestCase
), ),
) )
) )
)
)
); );
}
foreach ($data as $testData) { /**
* @dataProvider providerParse
$result = $this->parser->parse($this->query, null, $testData); */
public function testParse($data)
{
$result = $this->parser->parse($this->query, null, $data);
$suggestions = $result->getSuggestions(); $suggestions = $result->getSuggestions();
$this->assertEquals(false, $result->getCorrectlySpelled()); $this->assertEquals(false, $result->getCorrectlySpelled());
$this->assertEquals('dell', $suggestions[0]->getWord()); $this->assertEquals('dell', $suggestions[0]->getWord());
$this->assertEquals('ultrasharp', $suggestions[1]->getWord());
$this->assertEquals(6, $suggestions[1]->getStartOffset());
$this->assertEquals('ultrasharp', $suggestions[2]->getWord());
$this->assertEquals(16, $suggestions[2]->getStartOffset());
$this->assertEquals('dell ultrasharp', $result->getCollation()->getQuery()); $this->assertEquals('dell ultrasharp', $result->getCollation()->getQuery());
$collations = $result->getCollations(); $collations = $result->getCollations();
$this->assertEquals('dell ultrasharp', $collations[0]->getQuery()); $this->assertEquals('dell ultrasharp', $collations[0]->getQuery());
$this->assertEquals('dell ultrasharp new', $collations[1]->getQuery()); $this->assertEquals('dell ultrasharp new', $collations[1]->getQuery());
}
} }
public function testParse() public function providerParse()
{ {
$data = array(); return array(
$data['solr4'] = array( 'solr4' => array(
'data' => array(
'spellcheck' => array( 'spellcheck' => array(
'suggestions' => array( 'suggestions' => array(
0 => 'delll', 0 => 'delll',
1 => array ( 1 => array(
'numFound' => 1, 'numFound' => 1,
'startOffset' => 0, 'startOffset' => 0,
'endOffset' => 5, 'endOffset' => 5,
'origFreq' => 0, 'origFreq' => 0,
'suggestion' => array ( 'suggestion' => array(
0 => 'dell', 0 => 'dell',
), ),
), ),
2 => 'ultrashar', 2 => 'ultrashar',
3 => array ( 3 => array(
'numFound' => 1, 'numFound' => 1,
'startOffset' => 6, 'startOffset' => 6,
'endOffset' => 15, 'endOffset' => 15,
'origFreq' => 0, 'origFreq' => 0,
'suggestion' => array ( 'suggestion' => array(
0 => array ( 0 => array(
'word' => 'ultrasharp', 'word' => 'ultrasharp',
'freq' => 1, 'freq' => 1,
), ),
...@@ -257,29 +282,30 @@ class SpellcheckTest extends \PHPUnit_Framework_TestCase ...@@ -257,29 +282,30 @@ class SpellcheckTest extends \PHPUnit_Framework_TestCase
9 => 'dell ultrasharp new', 9 => 'dell ultrasharp new',
) )
) )
); )
),
$data['solr5'] = array( 'solr5' => array(
'data' => array(
'spellcheck' => array( 'spellcheck' => array(
'suggestions' => array( 'suggestions' => array(
0 => 'delll', 0 => 'delll',
1 => array ( 1 => array(
'numFound' => 1, 'numFound' => 1,
'startOffset' => 0, 'startOffset' => 0,
'endOffset' => 5, 'endOffset' => 5,
'origFreq' => 0, 'origFreq' => 0,
'suggestion' => array ( 'suggestion' => array(
0 => 'dell', 0 => 'dell',
), ),
), ),
2 => 'ultrashar', 2 => 'ultrashar',
3 => array ( 3 => array(
'numFound' => 1, 'numFound' => 1,
'startOffset' => 6, 'startOffset' => 6,
'endOffset' => 15, 'endOffset' => 15,
'origFreq' => 0, 'origFreq' => 0,
'suggestion' => array ( 'suggestion' => array(
0 => array ( 0 => array(
'word' => 'ultrasharp', 'word' => 'ultrasharp',
'freq' => 1, 'freq' => 1,
), ),
...@@ -295,50 +321,53 @@ class SpellcheckTest extends \PHPUnit_Framework_TestCase ...@@ -295,50 +321,53 @@ class SpellcheckTest extends \PHPUnit_Framework_TestCase
'dell ultrasharp new', 'dell ultrasharp new',
) )
) )
)
)
); );
}
foreach ($data as $testData) { /**
* @dataProvider providerParseSingleCollation
$result = $this->parser->parse($this->query, null, $testData); */
public function testParseSingleCollation($data)
$suggestions = $result->getSuggestions(); {
$this->assertEquals(false, $result->getCorrectlySpelled()); $result = $this->parser->parse($this->query, null, $data);
$this->assertEquals('dell', $suggestions[0]->getWord());
$this->assertEquals('dell ultrasharp', $result->getCollation()->getQuery());
$collations = $result->getCollations(); $collations = $result->getCollations();
$this->assertEquals('dell ultrasharp', $collations[0]->getQuery()); $this->assertEquals('dell ultrasharp', $collations[0]->getQuery());
$this->assertEquals('dell ultrasharp new', $collations[1]->getQuery());
} $words = $result->getSuggestion(1)->getWords();
$this->assertEquals(array('word' => 'ultrasharpy', 'freq' => 1), $words[1]);
} }
public function testParseSingleCollation() public function providerParseSingleCollation()
{ {
$data = array(); return array(
$data['solr4'] = array( 'solr4' => array(
'data' => array(
'spellcheck' => array( 'spellcheck' => array(
'suggestions' => array( 'suggestions' => array(
0 => 'delll', 0 => 'delll',
1 => array ( 1 => array(
'numFound' => 1, 'numFound' => 1,
'startOffset' => 0, 'startOffset' => 0,
'endOffset' => 5, 'endOffset' => 5,
'origFreq' => 0, 'origFreq' => 0,
'suggestion' => array ( 'suggestion' => array(
0 => 'dell', 0 => 'dell',
), ),
), ),
2 => 'ultrashar', 2 => 'ultrashar',
3 => array ( 3 => array(
'numFound' => 1, 'numFound' => 1,
'startOffset' => 6, 'startOffset' => 6,
'endOffset' => 15, 'endOffset' => 15,
'origFreq' => 0, 'origFreq' => 0,
'suggestion' => array ( 'suggestion' => array(
0 => array ( 0 => array(
'word' => 'ultrasharp', 'word' => 'ultrasharp',
'freq' => 2, 'freq' => 2,
), ),
1 => array ( 1 => array(
'word' => 'ultrasharpy', 'word' => 'ultrasharpy',
'freq' => 1, 'freq' => 1,
), ),
...@@ -350,33 +379,34 @@ class SpellcheckTest extends \PHPUnit_Framework_TestCase ...@@ -350,33 +379,34 @@ class SpellcheckTest extends \PHPUnit_Framework_TestCase
7 => 'dell ultrasharp', 7 => 'dell ultrasharp',
) )
) )
); )
),
$data['solr5'] = array( 'solr5' => array(
'data' => array(
'spellcheck' => array( 'spellcheck' => array(
'suggestions' => array( 'suggestions' => array(
0 => 'delll', 0 => 'delll',
1 => array ( 1 => array(
'numFound' => 1, 'numFound' => 1,
'startOffset' => 0, 'startOffset' => 0,
'endOffset' => 5, 'endOffset' => 5,
'origFreq' => 0, 'origFreq' => 0,
'suggestion' => array ( 'suggestion' => array(
0 => 'dell', 0 => 'dell',
), ),
), ),
2 => 'ultrashar', 2 => 'ultrashar',
3 => array ( 3 => array(
'numFound' => 1, 'numFound' => 1,
'startOffset' => 6, 'startOffset' => 6,
'endOffset' => 15, 'endOffset' => 15,
'origFreq' => 0, 'origFreq' => 0,
'suggestion' => array ( 'suggestion' => array(
0 => array ( 0 => array(
'word' => 'ultrasharp', 'word' => 'ultrasharp',
'freq' => 2, 'freq' => 2,
), ),
1 => array ( 1 => array(
'word' => 'ultrasharpy', 'word' => 'ultrasharpy',
'freq' => 1, 'freq' => 1,
), ),
...@@ -390,17 +420,9 @@ class SpellcheckTest extends \PHPUnit_Framework_TestCase ...@@ -390,17 +420,9 @@ class SpellcheckTest extends \PHPUnit_Framework_TestCase
'dell ultrasharp' 'dell ultrasharp'
) )
) )
)
)
); );
foreach ($data as $testData) {
$result = $this->parser->parse($this->query, null, $testData);
$collations = $result->getCollations();
$this->assertEquals('dell ultrasharp', $collations[0]->getQuery());
$words = $result->getSuggestion(1)->getWords();
$this->assertEquals(array('word' => 'ultrasharpy', 'freq' => 1), $words[1]);
}
} }
public function testParseNoData() public function testParseNoData()
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment