objFromFixture('CommentableItem', 'spammed'); $this->assertDOSEquals(array( array('Name' => 'Comment 1'), array('Name' => 'Comment 3') ), $item->getComments(), 'Only 2 non spam posts should be shown'); // when moderated, only moderated, non spam posts should be shown. Commenting::set_config_value('CommentableItem','require_moderation', true); $this->assertDOSEquals(array( array('Name' => 'Comment 3') ), $item->getComments(), 'Only 1 non spam, moderated post should be shown'); // when logged in as an user with CMS_ACCESS_CommentAdmin rights they // should see all the comments whether we have moderation on or not $this->logInWithPermission('CMS_ACCESS_CommentAdmin'); Commenting::set_config_value('CommentableItem','require_moderation', true); $this->assertEquals(4, $item->getComments()->Count()); Commenting::set_config_value('CommentableItem','require_moderation', false); $this->assertEquals(4, $item->getComments()->Count()); } public function testCanView() { $visitor = $this->objFromFixture('Member', 'visitor'); $admin = $this->objFromFixture('Member', 'commentadmin'); $comment = $this->objFromFixture('Comment', 'firstComA'); $this->assertTrue($comment->canView($visitor), 'Unauthenticated members can view comments associated to a object with ProvideComments=1' ); $this->assertTrue($comment->canView($admin), 'Admins with CMS_ACCESS_CommentAdmin permissions can view comments associated to a page with ProvideComments=1' ); $disabledComment = $this->objFromFixture('Comment', 'disabledCom'); $this->assertFalse($disabledComment->canView($visitor), 'Unauthenticated members can not view comments associated to a object with ProvideComments=0' ); $this->assertTrue($disabledComment->canView($admin), 'Admins with CMS_ACCESS_CommentAdmin permissions can view comments associated to a page with ProvideComments=0' ); } public function testCanEdit() { $visitor = $this->objFromFixture('Member', 'visitor'); $admin = $this->objFromFixture('Member', 'commentadmin'); $comment = $this->objFromFixture('Comment', 'firstComA'); $this->assertFalse($comment->canEdit($visitor)); $this->assertTrue($comment->canEdit($admin)); } public function testCanDelete() { $visitor = $this->objFromFixture('Member', 'visitor'); $admin = $this->objFromFixture('Member', 'commentadmin'); $comment = $this->objFromFixture('Comment', 'firstComA'); $this->assertFalse($comment->canEdit($visitor)); $this->assertTrue($comment->canEdit($admin)); } public function testDeleteComment() { $comment = $this->objFromFixture('Comment', 'firstComA'); $this->assertNull($comment->DeleteLink(), 'No permission to see delete link'); $delete = $this->get('CommentingController/delete/'.$comment->ID); $check = DataObject::get_by_id('Comment', $comment->ID); $this->assertTrue($check && $check->exists()); $firstPage = $this->objFromFixture('CommentableItem', 'first'); $this->autoFollowRedirection = false; $this->logInAs('commentadmin'); $firstComment = $this->objFromFixture('Comment', 'firstComA'); $firstCommentID = $firstComment->ID; Director::test($firstPage->RelativeLink(), null, $this->session()); $delete = $this->get('CommentingController/delete/'.$firstComment->ID); $check = DataObject::get_by_id('Comment', $firstCommentID); $this->assertFalse($check && $check->exists()); } /* Test a reply to a comment. This should set the following: - a depth of 2 - lineage containing ten characters, namely the ID of the parent and then the ID of the child comment, padded out to 5 chars each */ public function testReplyToComment() { $comment1 = $this->objFromFixture('Comment', 'firstComA'); $comment2 = $this->objFromFixture('Comment', 'secondComC'); $comment2->ParentCommentID = $comment1->ID; $comment2->write(); $check = DataObject::get_by_id('Comment', $comment2->ID); $this->assertEquals(2, $check->Depth); $parentpadded = str_pad($check->ParentCommentID, 5, '0', STR_PAD_LEFT); $lineage = $parentpadded.str_pad($check->ID, 5, '0', STR_PAD_LEFT); $this->assertEquals($lineage, $check->Lineage); } public function testCanReply() { Commenting::set_config_value('CommentableItem','maximum_thread_comment_depth', 8); Commenting::set_config_value('CommentableItem','thread_comments', true); Commenting::set_config_value('CommentableItem','require_moderation', false); $disabledComment = $this->objFromFixture('Comment', 'disabledCom'); $this->assertFalse($disabledComment->CanReply(), 'One cannot reply to a disabled comment' ); // nothing to stop this one being replied to $comment = $this->objFromFixture('Comment', 'firstComA'); $this->assertTrue($comment->CanReply(), 'This comment can be replied to'); Commenting::set_config_value('CommentableItem','maximum_thread_comment_depth', 1); $this->assertFalse($comment->CanReply(), 'Cannot reply due to having reached maximum depth'); Commenting::set_config_value('CommentableItem','maximum_thread_comment_depth', 8); Commenting::set_config_value('CommentableItem','thread_comments', false); $this->assertFalse($comment->CanReply(), 'Cannot reply due threaded comments being turned off'); Commenting::set_config_value('CommentableItem','thread_comments', true); $comment->Moderated = false; $this->assertFalse($comment->CanReply(), "Cannot reply to a comment that is still awaiting moderation"); } public function testSpamComment() { $comment = $this->objFromFixture('Comment', 'firstComA'); $this->assertNull($comment->SpamLink(), 'No permission to see mark as spam link'); $spam = $this->get('CommentingController/spam/'.$comment->ID); $check = DataObject::get_by_id('Comment', $comment->ID); $this->assertEquals(0, $check->IsSpam, 'No permission to mark as spam'); $this->autoFollowRedirection = false; $this->logInAs('commentadmin'); $this->assertContains('CommentingController/spam/'. $comment->ID, $comment->SpamLink()->getValue()); $spam = $this->get('CommentingController/spam/'.$comment->ID); $check = DataObject::get_by_id('Comment', $comment->ID); $this->assertEquals(1, $check->IsSpam); $this->assertNull($check->SpamLink()); } public function testHamComment() { $comment = $this->objFromFixture('Comment', 'secondComC'); $this->assertNull($comment->HamLink(), 'No permission to see mark as ham link'); $ham = $this->get('CommentingController/ham/'.$comment->ID); $check = DataObject::get_by_id('Comment', $comment->ID); $this->assertEquals(1, $check->IsSpam, 'No permission to mark as ham'); $this->autoFollowRedirection = false; $this->logInAs('commentadmin'); $this->assertContains('CommentingController/ham/'. $comment->ID, $comment->HamLink()->getValue()); $ham = $this->get('CommentingController/ham/'.$comment->ID); $check = DataObject::get_by_id('Comment', $comment->ID); $this->assertEquals(0, $check->IsSpam); $this->assertNull($check->HamLink()); } public function testApproveComment() { $comment = $this->objFromFixture('Comment', 'secondComB'); $this->assertNull($comment->ApproveLink(), 'No permission to see mark as approved link'); $ham = $this->get('CommentingController/approve/'.$comment->ID); $check = DataObject::get_by_id('Comment', $comment->ID); $this->assertEquals(0, $check->Moderated, 'No permission to mark as approved'); $this->autoFollowRedirection = false; $this->logInAs('commentadmin'); $this->assertContains('CommentingController/approve/'. $comment->ID, $comment->ApproveLink()->getValue()); $ham = $this->get('CommentingController/approve/'.$comment->ID); $check = DataObject::get_by_id('Comment', $comment->ID); $this->assertEquals(1, $check->Moderated); $this->assertNull($check->ApproveLink()); } public function testCommenterURLWrite() { $comment = new Comment(); // We only care about the CommenterURL, so only set that // Check a http and https URL. Add more test urls here as needed. $protocols = array( 'Http', 'Https', ); $url = '://example.com'; foreach($protocols as $protocol) { $comment->CommenterURL = $protocol . $url; // The protocol should stay as if, assuming it is valid $comment->write(); $this->assertEquals($comment->CommenterURL, $protocol . $url, $protocol . ':// is a valid protocol'); } } public function testSanitizesWithAllowHtml() { if(!class_exists('HTMLPurifier')) { $this->markTestSkipped('HTMLPurifier class not found'); return; } $origAllowed = Commenting::get_config_value('CommentableItem','html_allowed'); // Without HTML allowed $comment1 = new Comment(); $comment1->BaseClass = 'CommentableItem'; $comment1->Comment = '
my comment
'; $comment1->write(); $this->assertEquals( 'my comment
', $comment1->Comment, 'Does not remove HTML tags with html_allowed=false, ' . 'which is correct behaviour because the HTML will be escaped' ); // With HTML allowed Commenting::set_config_value('CommentableItem','html_allowed', true); $comment2 = new Comment(); $comment2->BaseClass = 'CommentableItem'; $comment2->Comment = 'my comment
'; $comment2->write(); $this->assertEquals( 'my comment
', $comment2->Comment, 'Removes HTML tags which are not on the whitelist' ); Commenting::set_config_value('CommentableItem','html_allowed', $origAllowed); } public function testDefaultTemplateRendersHtmlWithAllowHtml() { if(!class_exists('HTMLPurifier')) { $this->markTestSkipped('HTMLPurifier class not found'); } $origAllowed = Commenting::get_config_value('CommentableItem', 'html_allowed'); $item = new CommentableItem(); $item->write(); // Without HTML allowed $comment = new Comment(); $comment->Comment = 'my comment
'; $comment->ParentID = $item->ID; $comment->BaseClass = 'CommentableItem'; $comment->write(); $html = $item->customise(array('CommentsEnabled' => true))->renderWith('CommentsInterface'); $this->assertContains( '<p>my comment</p>', $html ); Commenting::set_config_value('CommentableItem','html_allowed', true); $html = $item->customise(array('CommentsEnabled' => true))->renderWith('CommentsInterface'); $this->assertContains( 'my comment
', $html ); Commenting::set_config_value('CommentableItem','html_allowed', $origAllowed); } } /** * @package comments * @subpackage tests */ class CommentableItem extends DataObject implements TestOnly { private static $db = array( 'ProvideComments' => 'Boolean', 'Title' => 'Varchar' ); public function RelativeLink() { return "CommentableItem_Controller"; } public function canView($member = null) { return true; } public function Link() { return $this->RelativeLink(); } public function AbsoluteLink() { return Director::absoluteURL($this->RelativeLink()); } } /** * @package comments * @subpackage tests */ class CommentableItem_Controller extends Controller implements TestOnly { public function index() { return CommentableItem::get()->first()->CommentsForm(); } }