test if deleting bookmarks works. to do this, we need a new testbase method to create users, plus we need to return the uid when creating a new user. registration process needs to be adopted to that.

git-svn-id: https://semanticscuttle.svn.sourceforge.net/svnroot/semanticscuttle/trunk@417 b3834d28-1941-0410-a4f8-b48e95affb8f
This commit is contained in:
cweiske 2009-10-25 19:32:48 +00:00
parent b38d876fad
commit 09fffebffe
5 changed files with 170 additions and 70 deletions

View file

@ -212,9 +212,9 @@ class SemanticScuttle_Service_Bookmark extends SemanticScuttle_DbService
*/ */
public function addBookmark( public function addBookmark(
$address, $title, $description, $privateNote, $status, $categories, $address, $title, $description, $privateNote, $status, $categories,
$date = null, $fromApi = false, $fromImport = false, $sId = -1 $date = null, $fromApi = false, $fromImport = false, $sId = null
) { ) {
if ($sId == -1) { if ($sId === null) {
$userservice = SemanticScuttle_Service_Factory::get('User'); $userservice = SemanticScuttle_Service_Factory::get('User');
$sId = $userservice->getCurrentUserId(); $sId = $userservice->getCurrentUserId();
} }
@ -436,16 +436,17 @@ class SemanticScuttle_Service_Bookmark extends SemanticScuttle_DbService
$terms = null, $sortOrder = null, $watched = null, $terms = null, $sortOrder = null, $watched = null,
$startdate = null, $enddate = null, $hash = null $startdate = null, $enddate = null, $hash = null
) { ) {
$userservice =SemanticScuttle_Service_Factory::get('User'); $userservice = SemanticScuttle_Service_Factory::get('User');
$b2tservice =SemanticScuttle_Service_Factory::get('Bookmark2Tag'); $b2tservice = SemanticScuttle_Service_Factory::get('Bookmark2Tag');
$tag2tagservice =SemanticScuttle_Service_Factory::get('Tag2Tag'); $tag2tagservice = SemanticScuttle_Service_Factory::get('Tag2Tag');
$sId = $userservice->getCurrentUserId(); $sId = $userservice->getCurrentUserId();
if ($userservice->isLoggedOn()) { if ($userservice->isLoggedOn()) {
// All public bookmarks, user's own bookmarks and any shared with user // All public bookmarks, user's own bookmarks
// and any shared with user
$privacy = ' AND ((B.bStatus = 0) OR (B.uId = '. $sId .')'; $privacy = ' AND ((B.bStatus = 0) OR (B.uId = '. $sId .')';
$watchnames = $userservice->getWatchNames($sId, true); $watchnames = $userservice->getWatchNames($sId, true);
foreach($watchnames as $watchuser) { foreach ($watchnames as $watchuser) {
$privacy .= ' OR (U.username = "'. $watchuser .'" AND B.bStatus = 1)'; $privacy .= ' OR (U.username = "'. $watchuser .'" AND B.bStatus = 1)';
} }
$privacy .= ')'; $privacy .= ')';

View file

@ -400,24 +400,47 @@ class SemanticScuttle_Service_User extends SemanticScuttle_DbService
return true; return true;
} }
function addUser($username, $password, $email) { /**
* Create a new user in database.
* No checks are done in here - you ought to have checked
* everything before calling this method!
*
* @param string $username Username to use
* @param string $password Password to use
* @param string $email Email to use
*
* @return mixed Integer user ID if all is well,
* boolean false if an error occured
*/
public function addUser($username, $password, $email)
{
// Set up the SQL UPDATE statement. // Set up the SQL UPDATE statement.
$datetime = gmdate('Y-m-d H:i:s', time()); $datetime = gmdate('Y-m-d H:i:s', time());
$password = $this->sanitisePassword($password); $password = $this->sanitisePassword($password);
$values = array('username' => $username, 'password' => $password, 'email' => $email, 'uDatetime' => $datetime, 'uModified' => $datetime); $values = array(
$sql = 'INSERT INTO '. $this->getTableName() .' '. $this->db->sql_build_array('INSERT', $values); 'username' => $username,
'password' => $password,
'email' => $email,
'uDatetime' => $datetime,
'uModified' => $datetime
);
$sql = 'INSERT INTO '. $this->getTableName()
. ' '. $this->db->sql_build_array('INSERT', $values);
// Execute the statement. // Execute the statement.
$this->db->sql_transaction('begin'); $this->db->sql_transaction('begin');
if (!($dbresult = & $this->db->sql_query($sql))) { if (!($dbresult = & $this->db->sql_query($sql))) {
$this->db->sql_transaction('rollback'); $this->db->sql_transaction('rollback');
message_die(GENERAL_ERROR, 'Could not insert user', '', __LINE__, __FILE__, $sql, $this->db); message_die(
GENERAL_ERROR, 'Could not insert user',
'', __LINE__, __FILE__, $sql, $this->db
);
return false; return false;
} }
$uId = $this->db->sql_nextid($dbresult);
$this->db->sql_transaction('commit'); $this->db->sql_transaction('commit');
// Everything worked out, so return true. return $uId;
return true;
} }
function updateUser($uId, $password, $name, $email, $homepage, $uContent) { function updateUser($uId, $password, $name, $email, $homepage, $uContent) {
@ -564,7 +587,7 @@ class SemanticScuttle_Service_User extends SemanticScuttle_DbService
* *
* @see updateSessionStability() * @see updateSessionStability()
*/ */
publi function isSessionStable() public function isSessionStable()
{ {
return $_SESSION['sessionStable'] == 1; return $_SESSION['sessionStable'] == 1;
} }

View file

@ -28,10 +28,10 @@ if (!defined('PHPUnit_MAIN_METHOD')) {
*/ */
class BookmarkTest extends TestBase class BookmarkTest extends TestBase
{ {
protected $us; protected $us;
protected $bs; protected $bs;
protected $ts; protected $ts;
protected $tts; protected $tts;
@ -50,83 +50,132 @@ class BookmarkTest extends TestBase
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= SemanticScuttle_Service_Factory::get('Bookmark2Tag');
$this->b2ts->deleteAll(); $this->b2ts->deleteAll();
$this->tts =SemanticScuttle_Service_Factory::get('Tag2Tag'); $this->tts = SemanticScuttle_Service_Factory::get('Tag2Tag');
$this->tts->deleteAll(); $this->tts->deleteAll();
$this->tsts =SemanticScuttle_Service_Factory::get('TagStat'); $this->tsts = SemanticScuttle_Service_Factory::get('TagStat');
$this->tsts->deleteAll(); $this->tsts->deleteAll();
} $this->vs = SemanticScuttle_Service_Factory::get('Vote');
$this->vs->deleteAll();
}
public function testHardCharactersInBookmarks() public function testHardCharactersInBookmarks()
{ {
$bs = $this->bs; $bs = $this->bs;
$title = "title&é\"'(-è_çà)="; $title = "title&é\"'(-è_çà)=";
$desc = "description#{[|`\^@]}³<> ¹¡÷׿&é\"'(-è\\_çà)="; $desc = "description#{[|`\^@]}³<> ¹¡÷׿&é\"'(-è\\_çà)=";
$tag1 = "#{|`^@]³¹¡¿<&é\"'(-è\\_çà)"; $tag1 = "#{|`^@]³¹¡¿<&é\"'(-è\\_çà)";
$tag2 = "\"'(-è.[?./§!_çà)"; $tag2 = "\"'(-è.[?./§!_çà)";
$bs->addBookmark( $bs->addBookmark(
'http://site1.com', $title, $desc, 'note', 'http://site1.com', $title, $desc, 'note',
0, array($tag1, $tag2), 0, array($tag1, $tag2),
null, false, false, 1 null, false, false, 1
); );
$bookmarks = $bs->getBookmarks(0, 1); $bookmarks = $bs->getBookmarks(0, 1);
$b0 = $bookmarks['bookmarks'][0]; $b0 = $bookmarks['bookmarks'][0];
$this->assertEquals($title, $b0['bTitle']); $this->assertEquals($title, $b0['bTitle']);
$this->assertEquals($desc, $b0['bDescription']); $this->assertEquals($desc, $b0['bDescription']);
$this->assertEquals( $this->assertEquals(
str_replace(array('"', '\'', '/'), "_", $tag1), str_replace(array('"', '\'', '/'), "_", $tag1),
$b0['tags'][0] $b0['tags'][0]
); );
$this->assertEquals( $this->assertEquals(
str_replace(array('"', '\'', '/'), "_", $tag2), str_replace(array('"', '\'', '/'), "_", $tag2),
$b0['tags'][1] $b0['tags'][1]
); );
} }
public function testUnificationOfBookmarks() public function testUnificationOfBookmarks()
{ {
$bs = $this->bs; $bs = $this->bs;
$bs->addBookmark( $bs->addBookmark(
'http://site1.com', "title", "description", 'note', 'http://site1.com', "title", "description", 'note',
0, array('tag1'), null, false, false, 0, array('tag1'), null, false, false,
1 1
); );
$bs->addBookmark( $bs->addBookmark(
"http://site1.com", "title2", "description2", 'note', "http://site1.com", "title2", "description2", 'note',
0, array('tag2'), null, false, false, 0, array('tag2'), null, false, false,
2 2
); );
$bookmarks = $bs->getBookmarks(); $bookmarks = $bs->getBookmarks();
$this->assertEquals(1, $bookmarks['total']); $this->assertEquals(1, $bookmarks['total']);
} }
/*public function testSearchingBookmarksAccentsInsensible() /*public function testSearchingBookmarksAccentsInsensible()
{ {
$bs = $this->bs; $bs = $this->bs;
$bs->addBookmark("http://site1.com", "title", "éèüaàê", "status", array('tag1'), null, false, false, 1); $bs->addBookmark("http://site1.com", "title", "éèüaàê", "status", array('tag1'), null, false, false, 1);
$bookmarks =& $bs->getBookmarks(0, NULL, NULL, NULL, $terms = "eeaae"); //void $bookmarks =& $bs->getBookmarks(0, NULL, NULL, NULL, $terms = "eeaae"); //void
$this->assertEquals(0, $bookmarks['total']); $this->assertEquals(0, $bookmarks['total']);
$bookmarks =& $bs->getBookmarks(0, NULL, NULL, NULL, $terms = "eeuaae"); $bookmarks =& $bs->getBookmarks(0, NULL, NULL, NULL, $terms = "eeuaae");
$this->assertEquals(1, $bookmarks['total']); $this->assertEquals(1, $bookmarks['total']);
}*/ }*/
/**
* Test if deleting a bookmark works.
*
* @return void
*/
public function testDeleteBookmark() public function testDeleteBookmark()
{ {
//FIXME $bookmarks = $this->bs->getBookmarks();
$this->assertEquals(0, $bookmarks['total']);
$bid = $this->addBookmark();
$bookmarks = $this->bs->getBookmarks();
$this->assertEquals(1, $bookmarks['total']);
$bid2 = $this->addBookmark();
$bookmarks = $this->bs->getBookmarks();
$this->assertEquals(2, $bookmarks['total']);
$this->assertTrue($this->bs->deleteBookmark($bid));
$bookmarks = $this->bs->getBookmarks();
$this->assertEquals(1, $bookmarks['total']);
$this->assertTrue($this->bs->deleteBookmark($bid2));
$bookmarks = $this->bs->getBookmarks();
$this->assertEquals(0, $bookmarks['total']);
}
/**
* Test if deleting a bookmark with a vote works.
*
* @return void
*/
public function testDeleteBookmarkWithVote()
{
$uid = $this->addUser();
$bid = $this->addBookmark();
$bid = $this->addBookmark();
$this->vs->vote($bid, $uid, 1);
$this->assertTrue($this->vs->hasVoted($bid, $uid));
$bid2 = $this->addBookmark();
$this->vs->vote($bid2, $uid, 1);
$this->assertTrue($this->vs->hasVoted($bid2, $uid));
$this->assertTrue($this->bs->deleteBookmark($bid));
$this->assertFalse($this->vs->hasVoted($bid, $uid));
$this->assertTrue($this->vs->hasVoted($bid2, $uid));
} }
} }

View file

@ -27,23 +27,50 @@ class TestBase extends PHPUnit_Framework_TestCase
/** /**
* Create a new bookmark. * Create a new bookmark.
* *
* @param integer $user User ID the bookmark shall belong
*
* @return integer ID of bookmark * @return integer ID of bookmark
*/ */
protected function addBookmark() protected function addBookmark($user = null)
{ {
$bs = SemanticScuttle_Service_Factory::get('Bookmark'); if ($user === null) {
$user = $this->addUser();
}
$bs = SemanticScuttle_Service_Factory::get('Bookmark');
$rand = rand(); $rand = rand();
$bid = $bs->addBookmark( $bid = $bs->addBookmark(
'http://example.org/' . $rand, 'http://example.org/' . $rand,
'unittest bookmark #' . $rand, 'unittest bookmark #' . $rand,
'description', 'description',
null, null,
0, 0,
array('unittest') array('unittest'),
null, false, false,
$user
); );
return $bid; return $bid;
} }
/**
* Creates a new user in the database.
*
* @return integer ID of user
*/
protected function addUser()
{
$us = SemanticScuttle_Service_Factory::get('User');
$rand = rand();
$uid = $us->addUser(
'unittestuser-' . $rand,
$rand,
'unittest-' . $rand . '@example.org'
);
return $uid;
}
} }
?> ?>

View file

@ -60,7 +60,7 @@ if (POST_SUBMITTED != '') {
$tplVars['error'] = T_('Antispam answer is not valid. Please try again.'); $tplVars['error'] = T_('Antispam answer is not valid. Please try again.');
// Register details // Register details
} elseif ($userservice->addUser($posteduser, POST_PASS, POST_MAIL)) { } elseif ($userservice->addUser($posteduser, POST_PASS, POST_MAIL) !== false) {
// Log in with new username // Log in with new username
$login = $userservice->login($posteduser, POST_PASS); $login = $userservice->login($posteduser, POST_PASS);
if ($login) { if ($login) {