Merge pull request #575 from creative-commoners/pulls/3.3/archive-tests

NEW Add tests for blog archive links and tidy up code re-use a little
This commit is contained in:
Dylan Wagstaff 2019-02-14 10:08:24 +13:00 committed by GitHub
commit 5fe07757bc
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 42 additions and 12 deletions

View File

@ -621,18 +621,15 @@ class BlogPost extends Page
* Returns a monthly archive link for the current blog post.
*
* @param string $type
*
* @return string
*/
public function getMonthlyArchiveLink($type = 'day')
{
/**
* @var DBDatetime $date
*/
/** @var DBDatetime $date */
$date = $this->dbObject('PublishDate');
if ($type != 'year') {
if ($type == 'day') {
if ($type !== 'year') {
if ($type === 'day') {
return Controller::join_links(
$this->Parent()->Link('archive'),
$date->format('Y'),
@ -654,12 +651,7 @@ class BlogPost extends Page
*/
public function getYearlyArchiveLink()
{
/**
* @var DBDatetime $date
*/
$date = $this->dbObject('PublishDate');
return Controller::join_links($this->Parent()->Link('archive'), $date->format('Y'));
return $this->getMonthlyArchiveLink('year');
}
/**

View File

@ -146,4 +146,42 @@ class BlogPostTest extends SapphireTest
$this->expectException(\InvalidArgumentException::class);
$blogPost->MinutesToRead('not-a-number');
}
/**
* @param string $type
* @param string $expected
* @dataProvider monthlyArchiveLinkProvider
* @group wip
*/
public function testGetMonthlyArchiveLink($type, $expected)
{
/** @var BlogPost $blogPost */
$blogPost = $this->objFromFixture(BlogPost::class, 'FirstBlogPost');
$archiveLink = $blogPost->getMonthlyArchiveLink($type);
$this->assertContains('archive/', $archiveLink);
$this->assertStringEndsWith($expected, $archiveLink);
}
/**
* @return array[]
*/
public function monthlyArchiveLinkProvider()
{
return [
['day', '/2013/10/1'],
['month', '/2013/10'],
['year', '/2013'],
];
}
public function testGetYearlyArchiveLink()
{
/** @var BlogPost $blogPost */
$blogPost = $this->objFromFixture(BlogPost::class, 'FirstBlogPost');
$archiveLink = $blogPost->getYearlyArchiveLink();
$this->assertContains('archive/', $archiveLink);
$this->assertStringEndsWith('/2013', $archiveLink);
}
}