diff options
Diffstat (limited to 'tests')
| -rw-r--r-- | tests/BookmarkTest.php | 153 | ||||
| -rw-r--r-- | tests/TestBase.php | 35 | 
2 files changed, 132 insertions, 56 deletions
| diff --git a/tests/BookmarkTest.php b/tests/BookmarkTest.php index bbc3774..d7f4240 100644 --- a/tests/BookmarkTest.php +++ b/tests/BookmarkTest.php @@ -28,10 +28,10 @@ if (!defined('PHPUnit_MAIN_METHOD')) {   */  class BookmarkTest extends TestBase  { -	protected $us; -	protected $bs; -	protected $ts; -	protected $tts; +    protected $us; +    protected $bs; +    protected $ts; +    protected $tts; @@ -50,83 +50,132 @@ class BookmarkTest extends TestBase -	protected function setUp() -	{ -		$this->us =SemanticScuttle_Service_Factory::get('User'); -		$this->bs =SemanticScuttle_Service_Factory::get('Bookmark'); -		$this->bs->deleteAll(); -		$this->b2ts=SemanticScuttle_Service_Factory::get('Bookmark2Tag'); -		$this->b2ts->deleteAll(); -		$this->tts =SemanticScuttle_Service_Factory::get('Tag2Tag'); -		$this->tts->deleteAll(); -		$this->tsts =SemanticScuttle_Service_Factory::get('TagStat'); -		$this->tsts->deleteAll(); -	} - -	public function testHardCharactersInBookmarks() -	{		 -		$bs = $this->bs; -		$title = "title&é\"'(-è_çà)="; -		$desc = "description#{[|`\^@]}³<> ¹¡÷׿&é\"'(-è\\_çà)="; -		$tag1 = "#{|`^@]³¹¡¿<&é\"'(-è\\_çà)";	 -		$tag2 = "&é\"'(-è.[?./§!_çà)"; - -		$bs->addBookmark( +    protected function setUp() +    { +        $this->us = SemanticScuttle_Service_Factory::get('User'); +        $this->bs = SemanticScuttle_Service_Factory::get('Bookmark'); +        $this->bs->deleteAll(); +        $this->b2ts= SemanticScuttle_Service_Factory::get('Bookmark2Tag'); +        $this->b2ts->deleteAll(); +        $this->tts = SemanticScuttle_Service_Factory::get('Tag2Tag'); +        $this->tts->deleteAll(); +        $this->tsts = SemanticScuttle_Service_Factory::get('TagStat'); +        $this->tsts->deleteAll(); +        $this->vs = SemanticScuttle_Service_Factory::get('Vote'); +        $this->vs->deleteAll(); +    } + +    public function testHardCharactersInBookmarks() +    { +        $bs = $this->bs; +        $title = "title&é\"'(-è_çà)="; +        $desc = "description#{[|`\^@]}³<> ¹¡÷׿&é\"'(-è\\_çà)="; +        $tag1 = "#{|`^@]³¹¡¿<&é\"'(-è\\_çà)"; +        $tag2 = "&é\"'(-è.[?./§!_çà)"; + +        $bs->addBookmark(              'http://site1.com', $title, $desc, 'note',              0, array($tag1, $tag2),              null, false, false, 1          ); -		$bookmarks = $bs->getBookmarks(0, 1); +        $bookmarks = $bs->getBookmarks(0, 1); -		$b0 = $bookmarks['bookmarks'][0]; -		$this->assertEquals($title, $b0['bTitle']); -		$this->assertEquals($desc, $b0['bDescription']); -		$this->assertEquals( -            str_replace(array('"', '\'', '/'), "_", $tag1),  +        $b0 = $bookmarks['bookmarks'][0]; +        $this->assertEquals($title, $b0['bTitle']); +        $this->assertEquals($desc, $b0['bDescription']); +        $this->assertEquals( +            str_replace(array('"', '\'', '/'), "_", $tag1),              $b0['tags'][0]          ); -		$this->assertEquals( +        $this->assertEquals(              str_replace(array('"', '\'', '/'), "_", $tag2),              $b0['tags'][1]          ); -	} +    } -	public function testUnificationOfBookmarks() -	{		 -		$bs = $this->bs; +    public function testUnificationOfBookmarks() +    { +        $bs = $this->bs; -		$bs->addBookmark( +        $bs->addBookmark(              'http://site1.com', "title", "description", 'note',              0, array('tag1'), null, false, false,              1          ); -		$bs->addBookmark( +        $bs->addBookmark(              "http://site1.com", "title2", "description2", 'note',              0, array('tag2'), null, false, false,              2          ); -		$bookmarks = $bs->getBookmarks(); -		$this->assertEquals(1, $bookmarks['total']); -	} +        $bookmarks = $bs->getBookmarks(); +        $this->assertEquals(1, $bookmarks['total']); +    } -	/*public function testSearchingBookmarksAccentsInsensible() -	 { -	 $bs = $this->bs; +    /*public function testSearchingBookmarksAccentsInsensible() +     { +     $bs = $this->bs; -	 $bs->addBookmark("http://site1.com", "title", "éèüaàê", "status", array('tag1'), null, false, false, 1); -	 $bookmarks =& $bs->getBookmarks(0, NULL, NULL, NULL, $terms = "eeaae"); //void -	 $this->assertEquals(0, $bookmarks['total']); -	 $bookmarks =& $bs->getBookmarks(0, NULL, NULL, NULL, $terms = "eeuaae"); -	 $this->assertEquals(1, $bookmarks['total']); -	 }*/ +     $bs->addBookmark("http://site1.com", "title", "éèüaàê", "status", array('tag1'), null, false, false, 1); +     $bookmarks =& $bs->getBookmarks(0, NULL, NULL, NULL, $terms = "eeaae"); //void +     $this->assertEquals(0, $bookmarks['total']); +     $bookmarks =& $bs->getBookmarks(0, NULL, NULL, NULL, $terms = "eeuaae"); +     $this->assertEquals(1, $bookmarks['total']); +     }*/ +    /** +     * Test if deleting a bookmark works. +     * +     * @return void +     */      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));      }  } diff --git a/tests/TestBase.php b/tests/TestBase.php index dc5643f..f9946e2 100644 --- a/tests/TestBase.php +++ b/tests/TestBase.php @@ -27,23 +27,50 @@ class TestBase extends PHPUnit_Framework_TestCase      /**       * Create a new bookmark.       * +     * @param integer $user User ID the bookmark shall belong +     *       * @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(); -        $bid = $bs->addBookmark( +        $bid  = $bs->addBookmark(              'http://example.org/' . $rand,              'unittest bookmark #' . $rand,              'description',              null,              0, -            array('unittest') +            array('unittest'), +            null, false, false, +            $user          );          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; +    } +  }  ?>
\ No newline at end of file | 
