BlogPosts() many_many are published, both by * normal 'save & publish' functionality and by publish date. */ public function testBlogPosts() { $member = Security::getCurrentUser(); if ($member) { Security::setCurrentUser(null); } $this->objFromFixture(BlogPost::class, 'FirstBlogPost'); /** * @var BlogTag $tag */ $tag = $this->objFromFixture(BlogTag::class, 'FirstTag'); $this->assertEquals(1, $tag->BlogPosts()->count(), 'Tag blog post count'); } /** * @see https://github.com/silverstripe/silverstripe-blog/issues/376 */ public function testAllowMultibyteUrlSegment() { $blog = $this->objFromFixture(Blog::class, 'FirstBlog'); $tag = new BlogTag(); $tag->BlogID = $blog->ID; $tag->Title = 'تست'; $tag->write(); // urlencoded $this->assertEquals('%D8%AA%D8%B3%D8%AA', $tag->URLSegment); $link = Controller::join_links($tag->Blog()->Link(), 'tag', '%D8%AA%D8%B3%D8%AA'); $this->assertEquals($link, $tag->getLink()); } /** * The first blog can be viewed by anybody. */ public function testCanView() { $this->useDraftSite(); $admin = $this->objFromFixture(Member::class, 'Admin'); $editor = $this->objFromFixture(Member::class, 'Editor'); /** @var Blog $firstBlog */ $firstBlog = $this->objFromFixture(Blog::class, 'FirstBlog'); $firstTag = $firstBlog->Tags(false)->find('URLSegment', 'first-tag'); $this->assertTrue($firstTag->canView($admin), 'Admin should be able to view tag.'); $this->assertTrue($firstTag->canView($editor), 'Editor should be able to view tag.'); /** @var Blog $secondBlog */ $secondBlog = $this->objFromFixture(Blog::class, 'SecondBlog'); $secondTag = $secondBlog->Tags(false)->find('URLSegment', 'second-tag'); $this->assertTrue($secondTag->canView($admin), 'Admin should be able to view tag.'); $this->assertFalse($secondTag->canView($editor), 'Editor should not be able to view tag.'); } public function testCanEdit() { $this->useDraftSite(); $admin = $this->objFromFixture(Member::class, 'Admin'); $editor = $this->objFromFixture(Member::class, 'Editor'); /** @var Blog $firstBlog */ $firstBlog = $this->objFromFixture(Blog::class, 'FirstBlog'); $firstTag = $firstBlog->Tags(false)->find('URLSegment', 'first-tag'); $this->assertTrue($firstTag->canEdit($admin), 'Admin should be able to edit tag.'); $this->assertTrue($firstTag->canEdit($editor), 'Editor should be able to edit tag.'); /** @var Blog $secondBlog */ $secondBlog = $this->objFromFixture(Blog::class, 'SecondBlog'); $secondTag = $secondBlog->Tags(false)->find('URLSegment', 'second-tag'); $this->assertTrue($secondTag->canEdit($admin), 'Admin should be able to edit tag.'); $this->assertFalse($secondTag->canEdit($editor), 'Editor should not be able to edit tag.'); /** @var Blog $thirdBlog */ $thirdBlog = $this->objFromFixture(Blog::class, 'ThirdBlog'); $thirdTag = $thirdBlog->Tags(false)->find('URLSegment', 'third-tag'); $this->assertTrue($thirdTag->canEdit($admin), 'Admin should always be able to edit tags.'); $this->assertTrue($thirdTag->canEdit($editor), 'Editor should be able to edit tag.'); } public function testCanCreate() { $this->useDraftSite(); $admin = $this->objFromFixture(Member::class, 'Admin'); $editor = $this->objFromFixture(Member::class, 'Editor'); $tag = singleton(BlogTag::class); $this->assertTrue($tag->canCreate($admin), 'Admin should be able to create tag.'); $this->assertTrue($tag->canCreate($editor), 'Editor should be able to create tag.'); } public function testCanDelete() { $this->useDraftSite(); $admin = $this->objFromFixture(Member::class, 'Admin'); $editor = $this->objFromFixture(Member::class, 'Editor'); /** @var Blog $firstBlog */ $firstBlog = $this->objFromFixture(Blog::class, 'FirstBlog'); $firstTag = $firstBlog->Tags(false)->find('URLSegment', 'first-tag'); $this->assertTrue($firstTag->canDelete($admin), 'Admin should be able to delete tag.'); $this->assertTrue($firstTag->canDelete($editor), 'Editor should be able to delete tag.'); /** @var Blog $secondBlog */ $secondBlog = $this->objFromFixture(Blog::class, 'SecondBlog'); $secondTag = $secondBlog->Tags(false)->find('URLSegment', 'second-tag'); $this->assertTrue($secondTag->canDelete($admin), 'Admin should be able to delete tag.'); $this->assertFalse($secondTag->canDelete($editor), 'Editor should not be able to delete tag.'); /** @var Blog $thirdBlog */ $thirdBlog = $this->objFromFixture(Blog::class, 'ThirdBlog'); $thirdTag = $thirdBlog->Tags(false)->find('URLSegment', 'third-tag'); $this->assertTrue($thirdTag->canDelete($admin), 'Admin should always be able to delete tags.'); $this->assertTrue($thirdTag->canDelete($editor), 'Editor should be able to delete tag.'); } public function testDuplicateTagsForURLSegment() { $blog = new Blog(); $blog->Title = 'Testing for duplicates blog'; $blog->write(); $tag1 = new BlogTag(); $tag1->Title = 'cat-test'; $tag1->BlogID = $blog->ID; $tag1->write(); $this->assertEquals('cat-test', $tag1->URLSegment); $tag2 = new BlogTag(); $tag2->Title = 'cat test'; $tag2->BlogID = $blog->ID; $tag2->write(); $this->assertEquals('cat-test-1', $tag2->URLSegment); } public function testDuplicateTags() { $blog = new Blog(); $blog->Title = 'Testing for duplicate tags'; $blog->write(); $tag = new BlogTag(); $tag->Title = 'Test'; $tag->BlogID = $blog->ID; $tag->URLSegment = 'test'; $tag->write(); $tag = new BlogTag(); $tag->Title = 'Test'; $tag->URLSegment = 'test'; $tag->BlogID = $blog->ID; try { $tag->write(); $this->fail('Duplicate BlogTag written'); } catch (ValidationException $e) { $messages = $e->getResult()->getMessages(); $this->assertCount(1, $messages); $this->assertEquals(BlogTag::DUPLICATE_EXCEPTION, $messages[0]['messageType']); } } public function testBlogTagUrlSegmentsAreAutomaticallyUpdated() { $tag = new BlogTag; $tag->Title = "a test"; $tag->write(); $this->assertEquals($tag->URLSegment, "a-test"); $tag->Title = "another test"; $tag->write(); $this->assertEquals($tag->URLSegment, "another-test"); } }