From 27044d86a52b8113a0f447e658feafad3d7b6435 Mon Sep 17 00:00:00 2001 From: Robbie Averill Date: Fri, 22 Sep 2017 14:54:44 +1200 Subject: [PATCH 1/4] FIX Display individual years in blog archive widget when set to "Yearly" --- code/widgets/BlogArchiveWidget.php | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/code/widgets/BlogArchiveWidget.php b/code/widgets/BlogArchiveWidget.php index e6b7b8f90..6fc4695ed 100644 --- a/code/widgets/BlogArchiveWidget.php +++ b/code/widgets/BlogArchiveWidget.php @@ -105,14 +105,15 @@ public function getArchive() $posts = $query->execute(); $result = new ArrayList(); while ($next = $posts->next()) { - $date = Date::create(); - $date->setValue(strtotime($next['PublishDate'])); - $year = $date->Format('Y'); - if ($this->ArchiveType == 'Yearly') { + $year = $next['PublishDate']; $month = null; $title = $year; } else { + $date = Date::create(); + $date->setValue(strtotime($next['PublishDate'])); + + $year = $date->Format('Y'); $month = $date->Format('m'); $title = $date->FormatI18N('%B %Y'); } From a1e4f3efce46f342031c003746a5a0d49bb7dbd4 Mon Sep 17 00:00:00 2001 From: Robbie Averill Date: Tue, 26 Sep 2017 16:15:57 +1300 Subject: [PATCH 2/4] Add tests for BlogArchiveWidget --- code/widgets/BlogArchiveWidget.php | 3 +- tests/Widgets/BlogArchiveWidgetTest.php | 71 +++++++++++++++++++++++++ tests/Widgets/BlogArchiveWidgetTest.yml | 27 ++++++++++ 3 files changed, 100 insertions(+), 1 deletion(-) create mode 100644 tests/Widgets/BlogArchiveWidgetTest.php create mode 100644 tests/Widgets/BlogArchiveWidgetTest.yml diff --git a/code/widgets/BlogArchiveWidget.php b/code/widgets/BlogArchiveWidget.php index 6fc4695ed..a971fcaaa 100644 --- a/code/widgets/BlogArchiveWidget.php +++ b/code/widgets/BlogArchiveWidget.php @@ -96,7 +96,7 @@ public function getArchive() ); $stage = Versioned::current_stage(); - $suffix = ($stage == 'Stage') ? '' : "_{$stage}"; + $suffix = ($stage === 'Live') ? '_Live' : ''; $query = SQLSelect::create($fields, "BlogPost{$suffix}") ->addGroupBy($publishDate) ->addOrderBy('PublishDate Desc') @@ -125,6 +125,7 @@ public function getArchive() } $this->extend('updateGetArchive', $result); + return $result; } } diff --git a/tests/Widgets/BlogArchiveWidgetTest.php b/tests/Widgets/BlogArchiveWidgetTest.php new file mode 100644 index 000000000..7f93de41b --- /dev/null +++ b/tests/Widgets/BlogArchiveWidgetTest.php @@ -0,0 +1,71 @@ +markTestSkipped('Test requires silverstripe/widgets to be installed.'); + } + + SS_Datetime::set_mock_now('2017-09-20 00:00:00'); + + parent::setUp(); + } + + public function tearDown() + { + parent::tearDown(); + + SS_Datetime::clear_mock_now(); + } + + public function testArchiveMonthlyFromStage() + { + $widget = $this->objFromFixture('BlogArchiveWidget', 'archive-monthly'); + $archive = $widget->getArchive(); + + $this->assertInstanceOf('SS_List', $archive); + $this->assertCount(3, $archive); + $this->assertDOSContains(array( + array('Title' => 'August 2017'), + array('Title' => 'September 2017'), + array('Title' => 'May 2015'), + ), $archive); + } + + public function testArchiveMonthlyFromLive() + { + $original = Versioned::current_stage(); + + $this->objFromFixture('BlogPost', 'post-b')->doPublish(); + Versioned::reading_stage('Live'); + + $widget = $this->objFromFixture('BlogArchiveWidget', 'archive-monthly'); + $archive = $widget->getArchive(); + + $this->assertCount(1, $archive); + $this->assertDOSContains(array( + array('Title' => 'August 2017'), + ), $archive); + + Versioned::reading_stage($original); + } + + public function testArchiveYearly() + { + $widget = $this->objFromFixture('BlogArchiveWidget', 'archive-yearly'); + $archive = $widget->getArchive(); + + $this->assertInstanceOf('SS_List', $archive); + $this->assertCount(2, $archive); + $this->assertDOSContains(array( + array('Title' => '2017'), + array('Title' => '2015'), + ), $archive); + } +} diff --git a/tests/Widgets/BlogArchiveWidgetTest.yml b/tests/Widgets/BlogArchiveWidgetTest.yml new file mode 100644 index 000000000..41269563a --- /dev/null +++ b/tests/Widgets/BlogArchiveWidgetTest.yml @@ -0,0 +1,27 @@ +Blog: + my-blog: + Title: My Blog + +BlogPost: + post-a: + Title: September Digest + PublishDate: 2017-09-01 00:00:00 + ParentID: =>Blog.my-blog + post-b: + Title: August is Awesome + PublishDate: 2017-08-01 00:00:00 + ParentID: =>Blog.my-blog + post-c: + Title: 2015 is so two years ago + PublishDate: 2015-05-02 00:01:02 + ParentID: =>Blog.my-blog + +BlogArchiveWidget: + archive-monthly: + NumberToDisplay: 5 + ArchiveType: Monthly + BlogID: =>Blog.my-blog + archive-yearly: + NumberToDisplay: 5 + ArchiveType: Yearly + BlogID: =>Blog.my-blog From 92f61928701012723cace4189c131bd84114cdb4 Mon Sep 17 00:00:00 2001 From: Robbie Averill Date: Tue, 26 Sep 2017 17:05:04 +1300 Subject: [PATCH 3/4] Increase mimumum versioned of SilverStripe to 3.2 and update versions in Travis configuration --- .travis.yml | 10 +++++----- composer.json | 4 ++-- 2 files changed, 7 insertions(+), 7 deletions(-) diff --git a/.travis.yml b/.travis.yml index 651cf6ce0..a10d84447 100755 --- a/.travis.yml +++ b/.travis.yml @@ -14,7 +14,7 @@ before_install: env: global: - - DB=MYSQL CORE_RELEASE=3.1 + - DB=MYSQL CORE_RELEASE=3.6 # Turn coverage off by default, as it's expensive time wise - COVERAGE=0 @@ -27,13 +27,13 @@ matrix: - php: 5.6 env: DB=MYSQL COVERAGE=1 - php: 5.5 - env: DB=MYSQL + env: DB=MYSQL CORE_RELEASE=3.2 - php: 5.6 - env: DB=PGSQL + env: DB=PGSQL CORE_RELEASE=3.3 - php: 5.6 - env: DB=MYSQL CORE_RELEASE=3.2 + env: DB=MYSQL CORE_RELEASE=3.4 - php: 5.6 - env: DB=PGSQL CORE_RELEASE=3.2 + env: DB=PGSQL CORE_RELEASE=3.5 - php: 5.4 env: DB=SQLITE - php: 5.3 diff --git a/composer.json b/composer.json index d333288b1..8073483e4 100755 --- a/composer.json +++ b/composer.json @@ -8,7 +8,7 @@ ], "type": "silverstripe-module", "require": { - "silverstripe/cms": "^3.1.0", + "silverstripe/cms": "^3.2.0", "silverstripe/lumberjack": "~1.1", "silverstripe/tagfield": "^1.0" }, @@ -32,4 +32,4 @@ }, "minimum-stability": "dev", "prefer-stable": true -} \ No newline at end of file +} From 8e684dea507a5bf54c812c40d900b31dc44aa856 Mon Sep 17 00:00:00 2001 From: Robbie Averill Date: Tue, 26 Sep 2017 17:17:53 +1300 Subject: [PATCH 4/4] FIX BlogArchiveWidget for PostgreSQL compatibility --- code/widgets/BlogArchiveWidget.php | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/code/widgets/BlogArchiveWidget.php b/code/widgets/BlogArchiveWidget.php index a971fcaaa..711c93931 100644 --- a/code/widgets/BlogArchiveWidget.php +++ b/code/widgets/BlogArchiveWidget.php @@ -92,15 +92,15 @@ public function getArchive() $publishDate = DB::get_conn()->formattedDatetimeClause('"PublishDate"', $format); $fields = array( 'PublishDate' => $publishDate, - 'Total' => "Count('PublishDate')" + 'Total' => "COUNT('\"PublishDate\"')" ); $stage = Versioned::current_stage(); $suffix = ($stage === 'Live') ? '_Live' : ''; - $query = SQLSelect::create($fields, "BlogPost{$suffix}") + $query = SQLSelect::create($fields, '"BlogPost' . $suffix . '"') ->addGroupBy($publishDate) - ->addOrderBy('PublishDate Desc') - ->addWhere(array('PublishDate < ?' => SS_Datetime::now()->Format('Y-m-d'))); + ->addOrderBy('"PublishDate" DESC') + ->addWhere(array('"PublishDate" < ?' => SS_Datetime::now()->Format('Y-m-d'))); $posts = $query->execute(); $result = new ArrayList();