New Feature: save searches (and display a searchhistory box)

git-svn-id: https://semanticscuttle.svn.sourceforge.net/svnroot/semanticscuttle/trunk@80 b3834d28-1941-0410-a4f8-b48e95affb8f
This commit is contained in:
mensonge 2008-03-14 10:32:00 +00:00
parent 6ab15b1c29
commit 219888d489
11 changed files with 313 additions and 49 deletions

View file

@ -95,6 +95,10 @@ $dbname = 'scuttle';
# #
# enableWebsiteThumbnails : true or false. According to artviper.net license, buy a license if you gain profit with your pages. (see http://www.websitethumbnail.de/) # enableWebsiteThumbnails : true or false. According to artviper.net license, buy a license if you gain profit with your pages. (see http://www.websitethumbnail.de/)
# #
# sizeSearchHistory : the number of users' searches that are saved
# 10 [Default]
# -1 Unlimited
#
###################################################################### ######################################################################
$sitename = 'SemanticScuttle'; $sitename = 'SemanticScuttle';
@ -137,6 +141,8 @@ $enableCommonBookmarkDescription = true;
$enableWebsiteThumbnails = true; // see above, if you gain profit with your pages $enableWebsiteThumbnails = true; // see above, if you gain profit with your pages
$sizeSearchHistory = 10;
include_once('debug.inc.php'); include_once('debug.inc.php');
?> ?>

View file

@ -67,7 +67,7 @@ $dtend = date('Y-m-d H:i:s', strtotime('tomorrow'));
$tplVars['page'] = $page; $tplVars['page'] = $page;
$tplVars['start'] = $start; $tplVars['start'] = $start;
$tplVars['popCount'] = 30; $tplVars['popCount'] = 30;
$tplVars['sidebar_blocks'] = array('users', 'linked', 'recent'); $tplVars['sidebar_blocks'] = array('search', 'users', 'linked', 'recent');
$tplVars['range'] = 'all'; $tplVars['range'] = 'all';
$tplVars['pagetitle'] = T_('Store, share and tag your favourite links'); $tplVars['pagetitle'] = T_('Store, share and tag your favourite links');
$tplVars['subtitle'] = T_('Recent Bookmarks'); $tplVars['subtitle'] = T_('Recent Bookmarks');

View file

@ -8,8 +8,8 @@ msgid ""
msgstr "" msgstr ""
"Project-Id-Version: Scuttle\n" "Project-Id-Version: Scuttle\n"
"Report-Msgid-Bugs-To: \n" "Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2008-03-12 18:05+0100\n" "POT-Creation-Date: 2008-03-14 11:27+0100\n"
"PO-Revision-Date: 2008-03-12 18:09+0100\n" "PO-Revision-Date: 2008-03-14 11:29+0100\n"
"Last-Translator: BenjaminHKB <benjamin.huynh-kim-bang@loria.fr>\n" "Last-Translator: BenjaminHKB <benjamin.huynh-kim-bang@loria.fr>\n"
"Language-Team: fr-FR <toony.sf@chezouam.net>\n" "Language-Team: fr-FR <toony.sf@chezouam.net>\n"
"MIME-Version: 1.0\n" "MIME-Version: 1.0\n"
@ -27,7 +27,7 @@ msgstr "À propos"
#: ../../../ajaxDelete.php:30 #: ../../../ajaxDelete.php:30
msgid "You are not allowed to delete this bookmark" msgid "You are not allowed to delete this bookmark"
msgstr "Vous ne pouvez pas supprimer ce signet." msgstr "Vous n'êtes pas autorisés à supprimer ce signet"
#: ../../../ajaxDelete.php:34 #: ../../../ajaxDelete.php:34
#: ../../../edit.php:78 #: ../../../edit.php:78
@ -43,7 +43,7 @@ msgstr "Tous les tags"
#: ../../../populartags.php:58 #: ../../../populartags.php:58
#: ../../../profile.php:44 #: ../../../profile.php:44
#: ../../../rss.php:62 #: ../../../rss.php:62
#: ../../../search.php:87 #: ../../../search.php:88
#: ../../../watch.php:34 #: ../../../watch.php:34
#: ../../../watchlist.php:61 #: ../../../watchlist.php:61
#, php-format #, php-format
@ -419,12 +419,12 @@ msgstr "tous les signets"
msgid "for" msgid "for"
msgstr "pour" msgstr "pour"
#: ../../../search.php:58 #: ../../../search.php:59
#: ../../../search.php:104 #: ../../../search.php:108
msgid "Search Bookmarks" msgid "Search Bookmarks"
msgstr "Recherche de signets" msgstr "Recherche de signets"
#: ../../../search.php:64 #: ../../../search.php:65
msgid "Search Results" msgid "Search Results"
msgstr "Résultats de recherche" msgstr "Résultats de recherche"
@ -463,9 +463,8 @@ msgid "Tag common description updated"
msgstr "Editer la description commune du tag" msgstr "Editer la description commune du tag"
#: ../../../tagcommondescriptionedit.php:48 #: ../../../tagcommondescriptionedit.php:48
#, fuzzy
msgid "Failed to update the tag common description" msgid "Failed to update the tag common description"
msgstr "Impossible d'effacer le tag" msgstr "Impossible de mettre à jour la description commune du tag"
#: ../../../tagcommondescriptionedit.php:55 #: ../../../tagcommondescriptionedit.php:55
#: ../../../templates/sidebar.block.tagactions.php:25 #: ../../../templates/sidebar.block.tagactions.php:25
@ -652,32 +651,32 @@ msgstr " et les autres %s"
msgid "Copy" msgid "Copy"
msgstr "Copier" msgstr "Copier"
#: ../../../templates/bookmarks.tpl.php:201 #: ../../../templates/bookmarks.tpl.php:202
#: ../../../templates/bookmarks.tpl.php:207 #: ../../../templates/bookmarks.tpl.php:208
msgid "First" msgid "First"
msgstr "Première" msgstr "Première"
#: ../../../templates/bookmarks.tpl.php:202 #: ../../../templates/bookmarks.tpl.php:203
#: ../../../templates/bookmarks.tpl.php:208 #: ../../../templates/bookmarks.tpl.php:209
msgid "Previous" msgid "Previous"
msgstr "Précédent" msgstr "Précédent"
#: ../../../templates/bookmarks.tpl.php:215 #: ../../../templates/bookmarks.tpl.php:216
#: ../../../templates/bookmarks.tpl.php:218 #: ../../../templates/bookmarks.tpl.php:219
msgid "Next" msgid "Next"
msgstr "Suivant" msgstr "Suivant"
#: ../../../templates/bookmarks.tpl.php:216 #: ../../../templates/bookmarks.tpl.php:217
#: ../../../templates/bookmarks.tpl.php:219 #: ../../../templates/bookmarks.tpl.php:220
msgid "Last" msgid "Last"
msgstr "Dernière" msgstr "Dernière"
#: ../../../templates/bookmarks.tpl.php:221 #: ../../../templates/bookmarks.tpl.php:222
#, php-format #, php-format
msgid "Page %d of %d" msgid "Page %d of %d"
msgstr "Page %d de %d" msgstr "Page %d de %d"
#: ../../../templates/bookmarks.tpl.php:225 #: ../../../templates/bookmarks.tpl.php:226
msgid "No bookmarks available" msgid "No bookmarks available"
msgstr "Pas de signets disponibles." msgstr "Pas de signets disponibles."
@ -942,27 +941,27 @@ msgstr "Enregistrez-vous ici pour créer un compte gratuit %s. Toutes les inform
msgid "Antispam question" msgid "Antispam question"
msgstr "Question antispam" msgstr "Question antispam"
#: ../../../templates/sidebar.block.linked.php:16 #: ../../../templates/sidebar.block.linked.php:17
msgid "Edit link" msgid "Edit link"
msgstr "Editer un lien" msgstr "Editer un lien"
#: ../../../templates/sidebar.block.linked.php:40 #: ../../../templates/sidebar.block.linked.php:44
msgid "Synonyms:" msgid "Synonyms:"
msgstr "Synonymes :" msgstr "Synonymes :"
#: ../../../templates/sidebar.block.linked.php:101 #: ../../../templates/sidebar.block.linked.php:105
msgid "Linked Tags" msgid "Linked Tags"
msgstr "Tags structurés" msgstr "Tags structurés"
#: ../../../templates/sidebar.block.linked.php:104 #: ../../../templates/sidebar.block.linked.php:108
msgid "plus" msgid "plus"
msgstr "plus" msgstr "plus"
#: ../../../templates/sidebar.block.linked.php:122 #: ../../../templates/sidebar.block.linked.php:126
msgid "Add new link" msgid "Add new link"
msgstr "Créer un lien" msgstr "Créer un lien"
#: ../../../templates/sidebar.block.linked.php:123 #: ../../../templates/sidebar.block.linked.php:127
msgid "Delete link" msgid "Delete link"
msgstr "Supprimer un lien" msgstr "Supprimer un lien"
@ -974,6 +973,14 @@ msgstr "Tags récents"
msgid "Related Tags" msgid "Related Tags"
msgstr "Tags en relation" msgstr "Tags en relation"
#: ../../../templates/sidebar.block.search.php:16
msgid "Last Searches"
msgstr "Dernières recherches"
#: ../../../templates/sidebar.block.search.php:25
msgid "Number of bookmarks for this query"
msgstr "Nombre de signets pour cette recherche"
#: ../../../templates/sidebar.block.tagactions.php:17 #: ../../../templates/sidebar.block.tagactions.php:17
#: ../../../templates/sidebar.block.watchstatus.php:17 #: ../../../templates/sidebar.block.watchstatus.php:17
#, fuzzy #, fuzzy

View file

@ -8,7 +8,7 @@ msgid ""
msgstr "" msgstr ""
"Project-Id-Version: PACKAGE VERSION\n" "Project-Id-Version: PACKAGE VERSION\n"
"Report-Msgid-Bugs-To: \n" "Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2008-03-12 18:05+0100\n" "POT-Creation-Date: 2008-03-14 11:27+0100\n"
"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n" "PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
"Last-Translator: FULL NAME <EMAIL@ADDRESS>\n" "Last-Translator: FULL NAME <EMAIL@ADDRESS>\n"
"Language-Team: LANGUAGE <LL@li.org>\n" "Language-Team: LANGUAGE <LL@li.org>\n"
@ -36,7 +36,7 @@ msgstr ""
#: ../../../alltags.php:57 ../../../bookmarks.php:72 #: ../../../alltags.php:57 ../../../bookmarks.php:72
#: ../../../populartags.php:58 ../../../profile.php:44 ../../../rss.php:62 #: ../../../populartags.php:58 ../../../profile.php:44 ../../../rss.php:62
#: ../../../search.php:87 ../../../watch.php:34 ../../../watchlist.php:61 #: ../../../search.php:88 ../../../watch.php:34 ../../../watchlist.php:61
#, php-format #, php-format
msgid "User with username %s was not found" msgid "User with username %s was not found"
msgstr "" msgstr ""
@ -397,11 +397,11 @@ msgstr ""
msgid "for" msgid "for"
msgstr "" msgstr ""
#: ../../../search.php:58 ../../../search.php:104 #: ../../../search.php:59 ../../../search.php:108
msgid "Search Bookmarks" msgid "Search Bookmarks"
msgstr "" msgstr ""
#: ../../../search.php:64 #: ../../../search.php:65
msgid "Search Results" msgid "Search Results"
msgstr "" msgstr ""
@ -633,32 +633,32 @@ msgstr ""
msgid "Copy" msgid "Copy"
msgstr "" msgstr ""
#: ../../../templates/bookmarks.tpl.php:201 #: ../../../templates/bookmarks.tpl.php:202
#: ../../../templates/bookmarks.tpl.php:207 #: ../../../templates/bookmarks.tpl.php:208
msgid "First" msgid "First"
msgstr "" msgstr ""
#: ../../../templates/bookmarks.tpl.php:202 #: ../../../templates/bookmarks.tpl.php:203
#: ../../../templates/bookmarks.tpl.php:208 #: ../../../templates/bookmarks.tpl.php:209
msgid "Previous" msgid "Previous"
msgstr "" msgstr ""
#: ../../../templates/bookmarks.tpl.php:215
#: ../../../templates/bookmarks.tpl.php:218
msgid "Next"
msgstr ""
#: ../../../templates/bookmarks.tpl.php:216 #: ../../../templates/bookmarks.tpl.php:216
#: ../../../templates/bookmarks.tpl.php:219 #: ../../../templates/bookmarks.tpl.php:219
msgid "Next"
msgstr ""
#: ../../../templates/bookmarks.tpl.php:217
#: ../../../templates/bookmarks.tpl.php:220
msgid "Last" msgid "Last"
msgstr "" msgstr ""
#: ../../../templates/bookmarks.tpl.php:221 #: ../../../templates/bookmarks.tpl.php:222
#, php-format #, php-format
msgid "Page %d of %d" msgid "Page %d of %d"
msgstr "" msgstr ""
#: ../../../templates/bookmarks.tpl.php:225 #: ../../../templates/bookmarks.tpl.php:226
msgid "No bookmarks available" msgid "No bookmarks available"
msgstr "" msgstr ""
@ -938,27 +938,27 @@ msgstr ""
msgid "Antispam question" msgid "Antispam question"
msgstr "" msgstr ""
#: ../../../templates/sidebar.block.linked.php:16 #: ../../../templates/sidebar.block.linked.php:17
msgid "Edit link" msgid "Edit link"
msgstr "" msgstr ""
#: ../../../templates/sidebar.block.linked.php:40 #: ../../../templates/sidebar.block.linked.php:44
msgid "Synonyms:" msgid "Synonyms:"
msgstr "" msgstr ""
#: ../../../templates/sidebar.block.linked.php:101 #: ../../../templates/sidebar.block.linked.php:105
msgid "Linked Tags" msgid "Linked Tags"
msgstr "" msgstr ""
#: ../../../templates/sidebar.block.linked.php:104 #: ../../../templates/sidebar.block.linked.php:108
msgid "plus" msgid "plus"
msgstr "" msgstr ""
#: ../../../templates/sidebar.block.linked.php:122 #: ../../../templates/sidebar.block.linked.php:126
msgid "Add new link" msgid "Add new link"
msgstr "" msgstr ""
#: ../../../templates/sidebar.block.linked.php:123 #: ../../../templates/sidebar.block.linked.php:127
msgid "Delete link" msgid "Delete link"
msgstr "" msgstr ""
@ -970,6 +970,14 @@ msgstr ""
msgid "Related Tags" msgid "Related Tags"
msgstr "" msgstr ""
#: ../../../templates/sidebar.block.search.php:16
msgid "Last Searches"
msgstr ""
#: ../../../templates/sidebar.block.search.php:25
msgid "Number of bookmarks for this query"
msgstr ""
#: ../../../templates/sidebar.block.tagactions.php:17 #: ../../../templates/sidebar.block.tagactions.php:17
#: ../../../templates/sidebar.block.watchstatus.php:17 #: ../../../templates/sidebar.block.watchstatus.php:17
msgid "Actions" msgid "Actions"

View file

@ -31,6 +31,7 @@ if (isset($_POST['terms'])) {
$bookmarkservice =& ServiceFactory::getServiceInstance('BookmarkService'); $bookmarkservice =& ServiceFactory::getServiceInstance('BookmarkService');
$templateservice =& ServiceFactory::getServiceInstance('TemplateService'); $templateservice =& ServiceFactory::getServiceInstance('TemplateService');
$userservice =& ServiceFactory::getServiceInstance('UserService'); $userservice =& ServiceFactory::getServiceInstance('UserService');
$searchhistoryservice =& ServiceFactory::getServiceInstance('SearchHistoryService');
$logged_on_userid = $userservice->getCurrentUserId(); $logged_on_userid = $userservice->getCurrentUserId();
list($url, $range, $terms, $page) = explode('/', $_SERVER['PATH_INFO']); list($url, $range, $terms, $page) = explode('/', $_SERVER['PATH_INFO']);
@ -95,10 +96,13 @@ if (isset($_POST['terms'])) {
} }
$bookmarks =& $bookmarkservice->getBookmarks($start, $perpage, $s_user, NULL, $terms, getSortOrder(), $s_watchlist, $s_start, $s_end); $bookmarks =& $bookmarkservice->getBookmarks($start, $perpage, $s_user, NULL, $terms, getSortOrder(), $s_watchlist, $s_start, $s_end);
// Save search
$searchhistoryservice->addSearch($terms, $range, $bookmarks['total'], $logged_on_userid);
$tplVars['page'] = $page; $tplVars['page'] = $page;
$tplVars['start'] = $start; $tplVars['start'] = $start;
$tplVars['popCount'] = 25; $tplVars['popCount'] = 25;
$tplVars['sidebar_blocks'] = array('recent'); $tplVars['sidebar_blocks'] = array('search', 'recent');
$tplVars['range'] = $range; $tplVars['range'] = $range;
$tplVars['terms'] = $terms; $tplVars['terms'] = $terms;
$tplVars['pagetitle'] = T_('Search Bookmarks'); $tplVars['pagetitle'] = T_('Search Bookmarks');

View file

@ -0,0 +1,108 @@
<?php
class SearchHistoryService {
var $db;
var $tablename;
var $sizeSearchHistory;
function &getInstance(&$db) {
static $instance;
if (!isset($instance))
$instance =& new SearchHistoryService($db);
return $instance;
}
function SearchHistoryService(& $db) {
$this->db =& $db;
$this->tablename = $GLOBALS['tableprefix'] .'searchhistory';
if(isset($GLOBALS['sizeSearchHistory'])) {
$this->sizeSearchHistory = $GLOBALS['sizeSearchHistory'];
} else {
$this->sizeSearchHistory = 10;
}
}
function addSearch($terms, $range, $nbResults, $uId=0) {
if(strlen($terms) == 0) {
return false;
}
$datetime = gmdate('Y-m-d H:i:s', time());
//Insert values
$values = array('shTerms'=>$terms, 'shRange'=>$range, 'shDatetime'=>$datetime, 'shNbResults'=>$nbResults, 'uId'=>$uId);
$sql = 'INSERT INTO '. $this->getTableName() .' '. $this->db->sql_build_array('INSERT', $values);
$this->db->sql_transaction('begin');
if (!($dbresult = & $this->db->sql_query($sql))) {
$this->db->sql_transaction('rollback');
message_die(GENERAL_ERROR, 'Could not insert search history', '', __LINE__, __FILE__, $sql, $this->db);
return false;
}
if($this->sizeSearchHistory != -1 &&
$this->countSearches() > $this->sizeSearchHistory) {
$this->deleteOldestSearch();
}
}
function getAllSearches($range = NULL, $uId = NULL, $nb = NULL, $start = NULL, $distinct = false) {
$sql = 'SELECT DISTINCT(shTerms), shId, shRange, shNbResults, shDatetime, uId';
$sql.= ' FROM '. $this->getTableName();
$sql.= ' WHERE 1=1';
if($range != NULL) {
$sql.= ' AND shRange = "'.$range.'"';
} else {
$sql.= ' AND shRange = "all"';
}
if($uId != NULL) {
$sql.= ' AND uId = '.$uId;
}
if($distinct) {
$sql.= ' GROUP BY shTerms';
}
$sql.= ' ORDER BY shId DESC';
if (!($dbresult = & $this->db->sql_query_limit($sql, $nb, $start))) {
message_die(GENERAL_ERROR, 'Could not get searches', '', __LINE__, __FILE__, $sql, $this->db);
return false;
}
$searches = array();
while ($row = & $this->db->sql_fetchrow($dbresult)) {
$searches[] = $row;
}
return $searches;
}
function countSearches() {
$sql = 'SELECT COUNT(*) AS `total` FROM '. $this->getTableName();
if (!($result = & $this->db->sql_query($sql)) || (!($row = & $this->db->sql_fetchrow($result)))) {
message_die(GENERAL_ERROR, 'Could not get total searches', '', __LINE__, __FILE__, $sql, $this->db);
return false;
}
return $row['total'];
}
/* This function allows to limit the number of saved searches
by deleting the oldest one */
function deleteOldestSearch() {
$sql = 'DELETE FROM '.$this->getTableName();
$sql.= ' ORDER BY shId ASC LIMIT 1'; // warning: here the limit is important
$this->db->sql_transaction('begin');
if (!($dbresult = & $this->db->sql_query($sql))) {
$this->db->sql_transaction('rollback');
message_die(GENERAL_ERROR, 'Could not delete bookmarks', '', __LINE__, __FILE__, $query, $this->db);
return false;
}
}
function deleteAll() {
$query = 'TRUNCATE TABLE `'. $this->getTableName() .'`';
$this->db->sql_query($query);
}
// Properties
function getTableName() { return $this->tablename; }
function setTableName($value) { $this->tablename = $value; }
}
?>

View file

@ -121,3 +121,19 @@ CREATE TABLE `sc_commondescription` (
UNIQUE KEY `sc_commondescription_tag_datetime` (`tag`,`cdDatetime`), UNIQUE KEY `sc_commondescription_tag_datetime` (`tag`,`cdDatetime`),
UNIQUE KEY `sc_commondescription_bookmark_datetime` (`bHash`,`cdDatetime`) UNIQUE KEY `sc_commondescription_bookmark_datetime` (`bHash`,`cdDatetime`)
); );
-- --------------------------------------------------------
--
-- Table structure for table `sc_searchhistory`
--
CREATE TABLE `sc_searchhistory` (
`shId` int(11) NOT NULL auto_increment,
`shTerms` varchar(255) NOT NULL default '',
`shRange` varchar(32) NOT NULL default '',
`shDatetime` datetime NOT NULL default '0000-00-00 00:00:00',
`shNbResults` int(6) NOT NULL default '0',
`uId` int(11) NOT NULL default '0',
PRIMARY KEY (`shId`)
);

View file

@ -0,0 +1,35 @@
<?php
$tagservice =& ServiceFactory::getServiceInstance('TagService');
$userservice =& ServiceFactory::getServiceInstance('UserService');
$searchhistoryservice =& ServiceFactory::getServiceInstance('SearchHistoryService');
$logged_on_userid = $userservice->getCurrentUserId();
if ($logged_on_userid === false) {
$logged_on_userid = NULL;
}
$lastSearches = $searchhistoryservice->getAllSearches('all', NULL, 3, NULL, true);
if ($lastSearches && count($lastSearches) > 0) {
?>
<h2><?php echo T_('Last Searches'); ?></h2>
<div id="searches">
<table>
<?php
foreach ($lastSearches as $row) {
echo '<tr><td>';
echo '<a href="'.createURL('search', $range.'/'.$row['shTerms']).'">';
echo $row['shTerms'];
echo '</a>';
echo ' <span title="'.T_('Number of bookmarks for this query').'">('.$row['shNbResults'].')</span>';
echo '</td></tr>';
}
//echo '<tr><td><a href="'.createURL('users').'">...</a></td></tr>';
?>
</table>
</div>
<?php
}
?>

View file

@ -4,4 +4,4 @@ Then
To launch the tests, put in a console situated in the root of the SEMANTICSCUTTLE project (where is the SEMANTICSCUTTLE config file): To launch the tests, put in a console situated in the root of the SEMANTICSCUTTLE project (where is the SEMANTICSCUTTLE config file):
phpunit BookmarksTest ./tests/bookmarksTest.php ; phpunit CommonDescriptionTest tests/commonDescriptionTest.php ; phpunit Tag2TagTest tests/tag2TagTest.php phpunit BookmarksTest ./tests/bookmarksTest.php ; phpunit CommonDescriptionTest tests/commonDescriptionTest.php ; phpunit Tag2TagTest tests/tag2TagTest.php ; phpunit SearchTest tests/searchTest.php

80
tests/searchTest.php Normal file
View file

@ -0,0 +1,80 @@
<?php
require_once 'PHPUnit/Framework.php';
/*
To launch this test, type the following line into a shell
at the root of the scuttlePlus directory :
phpunit SearchTest tests/searchTest.php
*/
class SearchTest extends PHPUnit_Framework_TestCase
{
protected $us;
protected $bs;
protected $ts;
protected $tts;
protected $shs;
protected function setUp()
{
global $dbhost, $dbuser, $dbpass, $dbname, $dbport, $dbpersist, $dbtype, $tableprefix;
require_once('./header.inc.php');
$this->us =& ServiceFactory::getServiceInstance('UserService');
$this->bs =& ServiceFactory::getServiceInstance('BookmarkService');
$this->bs->deleteAll();
$this->ts =& ServiceFactory::getServiceInstance('TagService');
$this->ts->deleteAll();
$this->tts =& ServiceFactory::getServiceInstance('Tag2TagService');
$this->tts->deleteAll();
$this->tsts =& ServiceFactory::getServiceInstance('TagStatService');
$this->tsts->deleteAll();
$this->shs =& ServiceFactory::getServiceInstance('SearchHistoryService');
$this->shs->deleteAll();
}
public function testSearchHistory()
{
$shs = $this->shs;
$terms = 'bbqsdkbb;,:,:q;,qddds&é"\'\\\\\(-è_çà)';
$terms2 = '~#{|`]';
$range = 'all';
$nbResults = 10908;
$uId = 10;
$shs->addSearch($terms, $range, $nbResults, $uId);
$shs->addSearch($terms2, $range, $nbResults, $uId);
$shs->addSearch('', $range, $nbResults, $uId); // A void search must not be saved
$searches = $shs->getAllSearches();
$this->assertSame(2, count($searches));
$searches = $shs->getAllSearches($range, $uId);
$this->assertEquals(2, count($searches));
$searches = $shs->getAllSearches($range, 20); // fake userid
$this->assertEquals(0, count($searches));
$searches = $shs->getAllSearches($range, $uId, 1);
$this->assertEquals(1, count($searches));
$searches = $shs->getAllSearches($range, null, 1, 1);
$this->assertEquals(1, count($searches));
//test content of results
$searches = $shs->getAllSearches();
$this->assertSame($terms2, $searches[0]['shTerms']);
$this->assertSame($range, $searches[0]['shRange']);
$this->assertEquals($nbResults, $searches[0]['shNbResults']);
$this->assertEquals($uId, $searches[0]['uId']);
$this->assertSame($terms, $searches[1]['shTerms']);
$this->assertSame($range, $searches[1]['shRange']);
$this->assertEquals($nbResults, $searches[1]['shNbResults']);
$this->assertEquals($uId, $searches[1]['uId']);
//test distinct parameter
$shs->addSearch($terms, $range, $nbResults, 30); // we repeat a search (same terms)
$searches = $shs->getAllSearches();
$this->assertSame(3, count($searches));
$searches = $shs->getAllSearches(NULL, NULL, NULL, NULL, true);
$this->assertSame(2, count($searches));
}
}
?>