add some new tests
git-svn-id: https://semanticscuttle.svn.sourceforge.net/svnroot/semanticscuttle/trunk@754 b3834d28-1941-0410-a4f8-b48e95affb8f
This commit is contained in:
parent
5c65da5bff
commit
93e5201658
1 changed files with 122 additions and 46 deletions
|
@ -55,63 +55,139 @@ class SearchHistoryTest extends TestBase
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set up all services
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
protected function setUp()
|
protected function setUp()
|
||||||
{
|
{
|
||||||
$this->us =SemanticScuttle_Service_Factory::get('User');
|
$this->us = SemanticScuttle_Service_Factory::get('User');
|
||||||
$this->bs =SemanticScuttle_Service_Factory::get('Bookmark');
|
$this->bs = SemanticScuttle_Service_Factory::get('Bookmark');
|
||||||
$this->bs->deleteAll();
|
$this->bs->deleteAll();
|
||||||
$this->b2ts =SemanticScuttle_Service_Factory::get('Bookmark2Tag');
|
|
||||||
$this->b2ts->deleteAll();
|
$this->b2ts =SemanticScuttle_Service_Factory::get('Bookmark2Tag');
|
||||||
$this->tts =SemanticScuttle_Service_Factory::get('Tag2Tag');
|
$this->b2ts->deleteAll();
|
||||||
$this->tts->deleteAll();
|
|
||||||
$this->tsts =SemanticScuttle_Service_Factory::get('TagStat');
|
$this->tts = SemanticScuttle_Service_Factory::get('Tag2Tag');
|
||||||
$this->tsts->deleteAll();
|
$this->tts->deleteAll();
|
||||||
$this->shs =SemanticScuttle_Service_Factory::get('SearchHistory');
|
|
||||||
$this->shs->deleteAll();
|
$this->tsts = SemanticScuttle_Service_Factory::get('TagStat');
|
||||||
|
$this->tsts->deleteAll();
|
||||||
|
|
||||||
|
$this->shs = SemanticScuttle_Service_Factory::get('SearchHistory');
|
||||||
|
$this->shs->deleteAll();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Tests if adding searches to the database works
|
||||||
|
*/
|
||||||
|
public function testAddSearch()
|
||||||
|
{
|
||||||
|
$this->assertEquals(0, $this->shs->countSearches());
|
||||||
|
|
||||||
|
$this->assertTrue(
|
||||||
|
$this->shs->addSearch('testsearchterm', 'all', 0)
|
||||||
|
);
|
||||||
|
$this->assertEquals(1, $this->shs->countSearches());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Tests if adding a search without terms should fail
|
||||||
|
*/
|
||||||
|
public function testAddSearchNoTerms()
|
||||||
|
{
|
||||||
|
$this->assertEquals(0, $this->shs->countSearches());
|
||||||
|
|
||||||
|
$this->assertFalse(
|
||||||
|
$this->shs->addSearch('', 'all', 0)
|
||||||
|
);
|
||||||
|
$this->assertEquals(0, $this->shs->countSearches());
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testSearchHistory()
|
public function testSearchHistory()
|
||||||
{
|
{
|
||||||
$shs = $this->shs;
|
$shs = $this->shs;
|
||||||
|
|
||||||
$terms = 'bbqsdkbb;,:,:q;,qddds&é"\'\\\\\(-è_çà)';
|
$terms = 'bbqsdkbb;,:,:q;,qddds&é"\'\\\\\(-è_çà)';
|
||||||
$terms2 = '~#{|`]';
|
$terms2 = '~#{|`]';
|
||||||
$range = 'all';
|
$range = 'all';
|
||||||
$nbResults = 10908;
|
$nbResults = 10908;
|
||||||
$uId = 10;
|
$uId = 10;
|
||||||
|
|
||||||
$shs->addSearch($terms, $range, $nbResults, $uId);
|
$shs->addSearch($terms, $range, $nbResults, $uId);
|
||||||
$shs->addSearch($terms2, $range, $nbResults, $uId);
|
$shs->addSearch($terms2, $range, $nbResults, $uId);
|
||||||
$shs->addSearch('', $range, $nbResults, $uId); // A void search must not be saved
|
$shs->addSearch('', $range, $nbResults, $uId); // A void search must not be saved
|
||||||
|
|
||||||
$searches = $shs->getAllSearches();
|
$searches = $shs->getAllSearches();
|
||||||
$this->assertSame(2, count($searches));
|
$this->assertSame(2, count($searches));
|
||||||
$searches = $shs->getAllSearches($range, $uId);
|
$searches = $shs->getAllSearches($range, $uId);
|
||||||
$this->assertEquals(2, count($searches));
|
$this->assertEquals(2, count($searches));
|
||||||
$searches = $shs->getAllSearches($range, 20); // fake userid
|
$searches = $shs->getAllSearches($range, 20); // fake userid
|
||||||
$this->assertEquals(0, count($searches));
|
$this->assertEquals(0, count($searches));
|
||||||
$searches = $shs->getAllSearches($range, $uId, 1);
|
$searches = $shs->getAllSearches($range, $uId, 1);
|
||||||
$this->assertEquals(1, count($searches));
|
$this->assertEquals(1, count($searches));
|
||||||
$searches = $shs->getAllSearches($range, null, 1, 1);
|
$searches = $shs->getAllSearches($range, null, 1, 1);
|
||||||
$this->assertEquals(1, count($searches));
|
$this->assertEquals(1, count($searches));
|
||||||
|
|
||||||
//test content of results
|
//test content of results
|
||||||
$searches = $shs->getAllSearches();
|
$searches = $shs->getAllSearches();
|
||||||
$this->assertSame($terms2, $searches[0]['shTerms']);
|
$this->assertSame($terms2, $searches[0]['shTerms']);
|
||||||
$this->assertSame($range, $searches[0]['shRange']);
|
$this->assertSame($range, $searches[0]['shRange']);
|
||||||
$this->assertEquals($nbResults, $searches[0]['shNbResults']);
|
$this->assertEquals($nbResults, $searches[0]['shNbResults']);
|
||||||
$this->assertEquals($uId, $searches[0]['uId']);
|
$this->assertEquals($uId, $searches[0]['uId']);
|
||||||
$this->assertSame($terms, $searches[1]['shTerms']);
|
$this->assertSame($terms, $searches[1]['shTerms']);
|
||||||
$this->assertSame($range, $searches[1]['shRange']);
|
$this->assertSame($range, $searches[1]['shRange']);
|
||||||
$this->assertEquals($nbResults, $searches[1]['shNbResults']);
|
$this->assertEquals($nbResults, $searches[1]['shNbResults']);
|
||||||
$this->assertEquals($uId, $searches[1]['uId']);
|
$this->assertEquals($uId, $searches[1]['uId']);
|
||||||
|
|
||||||
//test distinct parameter
|
//test distinct parameter
|
||||||
$shs->addSearch($terms, $range, $nbResults, 30); // we repeat a search (same terms)
|
$shs->addSearch(
|
||||||
$searches = $shs->getAllSearches();
|
$terms, $range, $nbResults, 30
|
||||||
$this->assertSame(3, count($searches));
|
); // we repeat a search (same terms)
|
||||||
$searches = $shs->getAllSearches(NULL, NULL, NULL, NULL, true);
|
$searches = $shs->getAllSearches();
|
||||||
$this->assertSame(2, count($searches));
|
$this->assertSame(3, count($searches));
|
||||||
|
$searches = $shs->getAllSearches(null, null, null, null, true);
|
||||||
|
$this->assertSame(2, count($searches));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Deleting the oldest search without any historical searches
|
||||||
|
*/
|
||||||
|
public function testDeleteOldestSearchNone()
|
||||||
|
{
|
||||||
|
$this->assertEquals(0, $this->shs->countSearches());
|
||||||
|
$this->assertTrue($this->shs->deleteOldestSearch());
|
||||||
|
$this->assertEquals(0, $this->shs->countSearches());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test deleting the oldest search
|
||||||
|
*/
|
||||||
|
public function testDeleteOldestSearchSome()
|
||||||
|
{
|
||||||
|
$this->assertEquals(0, $this->shs->countSearches());
|
||||||
|
$this->shs->addSearch('testsearchterm1', 'all', 0);
|
||||||
|
$this->shs->addSearch('testsearchterm2', 'all', 0);
|
||||||
|
|
||||||
|
$rows = $this->shs->getAllSearches();
|
||||||
|
$this->assertEquals(2, count($rows));
|
||||||
|
|
||||||
|
$highestId = -1;
|
||||||
|
foreach ($rows as $row) {
|
||||||
|
if ($row['shId'] > $highestId) {
|
||||||
|
$highestId = $row['shId'];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->shs->deleteOldestSearch();
|
||||||
|
|
||||||
|
$rows = $this->shs->getAllSearches();
|
||||||
|
$this->assertEquals(1, count($rows));
|
||||||
|
$this->assertEquals(
|
||||||
|
$highestId,
|
||||||
|
$rows[0]['shId']
|
||||||
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue