diff --git a/code/Model/SiteTree.php b/code/Model/SiteTree.php index 511bf4ae88..882d3c5ea5 100755 --- a/code/Model/SiteTree.php +++ b/code/Model/SiteTree.php @@ -2612,8 +2612,10 @@ public function onAfterRevertToLive() // Need to update pages linking to this one as no longer broken foreach ($stageSelf->DependentPages() as $page) { - /** @var SiteTree $page */ - $page->writeWithoutVersion(); + if ($page->hasExtension(Versioned::class)) { + /** @var Versioned $page */ + $page->writeWithoutVersion(); + } } } diff --git a/tests/php/Model/SiteTreeTest.php b/tests/php/Model/SiteTreeTest.php index e6e06ed656..5e45765e50 100644 --- a/tests/php/Model/SiteTreeTest.php +++ b/tests/php/Model/SiteTreeTest.php @@ -12,6 +12,7 @@ use SilverStripe\CMS\Tests\Controllers\SiteTreeTest_NamespaceMapTestController; use SilverStripe\CMS\Tests\CMSEditLinkExtensionTest\BelongsToPage; use SilverStripe\CMS\Tests\CMSEditLinkExtensionTest\PageWithChild; +use SilverStripe\CMS\Tests\Model\SiteTreeBrokenLinksTest\NotPageObject; use SilverStripe\CMS\Tests\Page\SiteTreeTest_NamespaceMapTest; use SilverStripe\Control\ContentNegotiator; use SilverStripe\Control\Controller; @@ -69,6 +70,7 @@ class SiteTreeTest extends SapphireTest SiteTreeTest_DataObject::class, PageWithChild::class, BelongsToPage::class, + NotPageObject::class, ]; public function reservedSegmentsProvider() @@ -2119,4 +2121,23 @@ public function provideSanatiseInvalidExtraMeta(): array ] ]; } + + public function testOnAfterRevertToLive() + { + // Create new page and publish it + $page = SiteTree::create(); + $page->Content = 'Test content'; + $id = $page->write(); + $page->publishRecursive(); + + // Add link to non-page object + /** @var NotPageObject $obj */ + $obj = $this->objFromFixture(NotPageObject::class, 'object1'); + $obj->Content = 'Link to Page'; + $obj->write(); + + //Test that method doesn't throw exception + $this->expectNotToPerformAssertions(); + $page->onAfterRevertToLive(); + } } diff --git a/tests/php/Model/SiteTreeTest.yml b/tests/php/Model/SiteTreeTest.yml index 3b570f3bb8..eda4182d1f 100755 --- a/tests/php/Model/SiteTreeTest.yml +++ b/tests/php/Model/SiteTreeTest.yml @@ -128,3 +128,7 @@ SilverStripe\CMS\Tests\Model\SiteTreeTest_DataObject: relations: Title: 'Linked DataObject' Pages: =>Page.home,=>Page.about,=>Page.staff + +SilverStripe\CMS\Tests\Model\SiteTreeBrokenLinksTest\NotPageObject: + object1: + Content: 'Everything will be ok'