mirror of
https://github.com/wilr/silverstripe-googlesitemaps.git
synced 2024-10-22 11:05:48 +02:00
Merge pull request #70 from nfauchelle/master
Fix issue with last mod timestamp of the sitemap index file
This commit is contained in:
commit
edfcd22021
@ -283,11 +283,12 @@ class GoogleSitemap {
|
|||||||
$neededForPage = ceil($count / $countPerFile);
|
$neededForPage = ceil($count / $countPerFile);
|
||||||
|
|
||||||
for($i = 1; $i <= $neededForPage; $i++) {
|
for($i = 1; $i <= $neededForPage; $i++) {
|
||||||
$sliced = $instances
|
|
||||||
->limit($countPerFile, ($i - 1) * $countPerFile)
|
|
||||||
->last();
|
|
||||||
|
|
||||||
$lastModified = ($sliced) ? $sliced->dbObject('LastEdited')->Format('Y-m-d') : date('Y-m-d');
|
$lastEdited = $instances
|
||||||
|
->limit($countPerFile, ($i - 1) * $countPerFile)
|
||||||
|
->max('LastEdited');
|
||||||
|
|
||||||
|
$lastModified = ($lastEdited) ? date('Y-m-d', strtotime($lastEdited)) : date('Y-m-d');
|
||||||
|
|
||||||
$sitemaps->push(new ArrayData(array(
|
$sitemaps->push(new ArrayData(array(
|
||||||
'ClassName' => 'SiteTree',
|
'ClassName' => 'SiteTree',
|
||||||
|
@ -92,17 +92,29 @@ class GoogleSitemapTest extends FunctionalTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public function testLastModifiedDateOnRootXML() {
|
public function testLastModifiedDateOnRootXML() {
|
||||||
GoogleSitemap::register_dataobject("GoogleSitemapTest_DataObject");
|
Config::inst()->update('GoogleSitemap', 'enabled', true);
|
||||||
|
|
||||||
DB::query("
|
if(!class_exists('Page')) {
|
||||||
UPDATE GoogleSitemapTest_DataObject SET LastEdited = '2012-01-14'"
|
$this->markTestIncomplete('No cms module installed, page related test skipped');
|
||||||
);
|
}
|
||||||
|
|
||||||
|
$page = $this->objFromFixture('Page', 'Page1');
|
||||||
|
$page->publish('Stage', 'Live');
|
||||||
|
$page->flushCache();
|
||||||
|
|
||||||
|
$page2 = $this->objFromFixture('Page', 'Page2');
|
||||||
|
$page2->publish('Stage', 'Live');
|
||||||
|
$page2->flushCache();
|
||||||
|
|
||||||
|
DB::query("UPDATE \"SiteTree_Live\" SET \"LastEdited\"='2014-03-14 00:00:00' WHERE \"ID\"='".$page->ID."'");
|
||||||
|
DB::query("UPDATE \"SiteTree_Live\" SET \"LastEdited\"='2014-01-01 00:00:00' WHERE \"ID\"='".$page2->ID."'");
|
||||||
|
|
||||||
$response = $this->get('sitemap.xml');
|
$response = $this->get('sitemap.xml');
|
||||||
$body = $response->getBody();
|
$body = $response->getBody();
|
||||||
|
|
||||||
$expected = "<lastmod>2012-01-14</lastmod>";
|
$expected = '<lastmod>2014-03-14</lastmod>';
|
||||||
$this->assertEquals(1, substr_count($body, $expected));
|
|
||||||
|
$this->assertEquals(1, substr_count($body, $expected) , 'The last mod date should use most recent LastEdited date');
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testIndexFilePaginatedSitemapFiles() {
|
public function testIndexFilePaginatedSitemapFiles() {
|
||||||
@ -227,6 +239,10 @@ class GoogleSitemapTest extends FunctionalTest {
|
|||||||
// invalid field doesn't break google
|
// invalid field doesn't break google
|
||||||
$page->Priority = 'foo';
|
$page->Priority = 'foo';
|
||||||
$this->assertEquals(0.5, $page->getGooglePriority());
|
$this->assertEquals(0.5, $page->getGooglePriority());
|
||||||
|
|
||||||
|
// custom value (set as string as db field is varchar)
|
||||||
|
$page->Priority = '0.2';
|
||||||
|
$this->assertEquals(0.2, $page->getGooglePriority());
|
||||||
|
|
||||||
// -1 indicates that we should not index this
|
// -1 indicates that we should not index this
|
||||||
$page->Priority = -1;
|
$page->Priority = -1;
|
||||||
|
Loading…
Reference in New Issue
Block a user