2010-03-21 23:32:22 +01:00
|
|
|
<?php
|
|
|
|
|
2017-04-23 22:23:34 +02:00
|
|
|
namespace SilverStripe\Subsites\Tests;
|
|
|
|
|
2017-05-30 17:35:02 +02:00
|
|
|
use Page;
|
|
|
|
use SilverStripe\CMS\Controllers\CMSMain;
|
2017-05-29 13:42:42 +02:00
|
|
|
use SilverStripe\CMS\Model\ErrorPage;
|
2017-05-30 17:35:02 +02:00
|
|
|
use SilverStripe\CMS\Model\SiteTree;
|
2017-05-29 13:42:42 +02:00
|
|
|
use SilverStripe\Control\Director;
|
2017-05-30 17:35:02 +02:00
|
|
|
use SilverStripe\Control\Session;
|
|
|
|
use SilverStripe\Core\Config\Config;
|
2016-09-22 16:38:29 +02:00
|
|
|
use SilverStripe\Core\Convert;
|
|
|
|
use SilverStripe\Dev\TestOnly;
|
2017-05-30 17:35:02 +02:00
|
|
|
use SilverStripe\Forms\FieldList;
|
|
|
|
use SilverStripe\Security\Member;
|
|
|
|
use SilverStripe\SiteConfig\SiteConfig;
|
2017-05-24 15:26:28 +02:00
|
|
|
use SilverStripe\Subsites\Extensions\SiteTreeSubsites;
|
2017-05-24 15:25:34 +02:00
|
|
|
use SilverStripe\Subsites\Model\Subsite;
|
|
|
|
use SilverStripe\Subsites\Pages\SubsitesVirtualPage;
|
2017-05-30 17:35:02 +02:00
|
|
|
use SilverStripe\Versioned\Versioned;
|
2016-09-22 16:38:29 +02:00
|
|
|
|
2017-05-24 15:26:28 +02:00
|
|
|
class SiteTreeSubsitesTest extends BaseSubsiteTest
|
|
|
|
{
|
|
|
|
|
2017-05-30 15:14:28 +02:00
|
|
|
public static $fixture_file = 'subsites/tests/php/SubsiteTest.yml';
|
2017-05-24 15:26:28 +02:00
|
|
|
|
|
|
|
protected $extraDataObjects = [
|
|
|
|
'SiteTreeSubsitesTest_ClassA',
|
|
|
|
'SiteTreeSubsitesTest_ClassB',
|
|
|
|
'SiteTreeSubsitesTest_ErrorPage'
|
|
|
|
];
|
|
|
|
|
|
|
|
protected $illegalExtensions = [
|
2017-05-29 13:42:42 +02:00
|
|
|
SiteTree::class => ['Translatable']
|
2017-05-24 15:26:28 +02:00
|
|
|
];
|
|
|
|
|
2017-05-30 17:35:02 +02:00
|
|
|
public function testPagesInDifferentSubsitesCanShareURLSegment()
|
|
|
|
{
|
2017-05-24 15:26:28 +02:00
|
|
|
$subsiteMain = $this->objFromFixture(Subsite::class, 'main');
|
|
|
|
$subsite1 = $this->objFromFixture(Subsite::class, 'subsite1');
|
|
|
|
|
|
|
|
$pageMain = new SiteTree();
|
|
|
|
$pageMain->URLSegment = 'testpage';
|
|
|
|
$pageMain->write();
|
|
|
|
$pageMain->publish('Stage', 'Live');
|
|
|
|
|
|
|
|
$pageMainOther = new SiteTree();
|
|
|
|
$pageMainOther->URLSegment = 'testpage';
|
|
|
|
$pageMainOther->write();
|
|
|
|
$pageMainOther->publish('Stage', 'Live');
|
|
|
|
|
|
|
|
$this->assertNotEquals($pageMain->URLSegment, $pageMainOther->URLSegment,
|
|
|
|
'Pages in same subsite cant share the same URL'
|
|
|
|
);
|
|
|
|
|
|
|
|
Subsite::changeSubsite($subsite1->ID);
|
|
|
|
|
|
|
|
$pageSubsite1 = new SiteTree();
|
|
|
|
$pageSubsite1->URLSegment = 'testpage';
|
|
|
|
$pageSubsite1->write();
|
|
|
|
$pageSubsite1->publish('Stage', 'Live');
|
|
|
|
|
|
|
|
$this->assertEquals($pageMain->URLSegment, $pageSubsite1->URLSegment,
|
|
|
|
'Pages in different subsites can share the same URL'
|
|
|
|
);
|
2017-05-30 17:35:02 +02:00
|
|
|
}
|
2017-05-24 15:26:28 +02:00
|
|
|
|
2017-05-30 17:35:02 +02:00
|
|
|
public function testBasicSanity()
|
|
|
|
{
|
2017-05-29 13:42:42 +02:00
|
|
|
$this->assertTrue(singleton(SiteTree::class)->getSiteConfig() instanceof SiteConfig);
|
2017-05-24 15:26:28 +02:00
|
|
|
// The following assert is breaking in Translatable.
|
2017-05-29 13:42:42 +02:00
|
|
|
$this->assertTrue(singleton(SiteTree::class)->getCMSFields() instanceof FieldList);
|
2017-05-24 15:26:28 +02:00
|
|
|
$this->assertTrue(singleton(SubsitesVirtualPage::class)->getCMSFields() instanceof FieldList);
|
|
|
|
$this->assertTrue(is_array(singleton(SiteTreeSubsites::class)->extraStatics()));
|
|
|
|
}
|
|
|
|
|
2017-05-30 17:35:02 +02:00
|
|
|
public function testErrorPageLocations()
|
|
|
|
{
|
2017-05-31 06:41:45 +02:00
|
|
|
$this->markTestSkipped('needs refactoring');
|
|
|
|
|
2017-05-30 17:35:02 +02:00
|
|
|
$subsite1 = $this->objFromFixture(Subsite::class, 'domaintest1');
|
2017-05-24 15:26:28 +02:00
|
|
|
|
2017-05-30 17:35:02 +02:00
|
|
|
Subsite::changeSubsite($subsite1->ID);
|
|
|
|
$path = ErrorPage::get_filepath_for_errorcode(500);
|
2017-05-24 15:26:28 +02:00
|
|
|
|
2017-05-30 17:35:02 +02:00
|
|
|
$static_path = Config::inst()->get(ErrorPage::class, 'static_filepath');
|
|
|
|
$expected_path = $static_path . '/error-500-' . $subsite1->domain() . '.html';
|
|
|
|
$this->assertEquals($expected_path, $path);
|
|
|
|
}
|
2017-05-24 15:26:28 +02:00
|
|
|
|
2017-05-29 13:42:42 +02:00
|
|
|
public function testCanEditSiteTree()
|
2017-05-24 15:26:28 +02:00
|
|
|
{
|
2017-05-29 13:42:42 +02:00
|
|
|
$admin = $this->objFromFixture(Member::class, 'admin');
|
|
|
|
$subsite1member = $this->objFromFixture(Member::class, 'subsite1member');
|
|
|
|
$subsite2member = $this->objFromFixture(Member::class, 'subsite2member');
|
2017-05-24 15:26:28 +02:00
|
|
|
$mainpage = $this->objFromFixture('Page', 'home');
|
|
|
|
$subsite1page = $this->objFromFixture('Page', 'subsite1_home');
|
|
|
|
$subsite2page = $this->objFromFixture('Page', 'subsite2_home');
|
|
|
|
$subsite1 = $this->objFromFixture(Subsite::class, 'subsite1');
|
|
|
|
$subsite2 = $this->objFromFixture(Subsite::class, 'subsite2');
|
|
|
|
|
2017-05-30 17:35:02 +02:00
|
|
|
// Cant pass member as arguments to canEdit() because of GroupSubsites
|
2017-06-01 14:49:55 +02:00
|
|
|
Session::set('loggedInAs', $admin->ID);
|
2017-05-30 17:35:02 +02:00
|
|
|
$this->assertTrue(
|
|
|
|
(bool)$subsite1page->canEdit(),
|
|
|
|
'Administrators can edit all subsites'
|
|
|
|
);
|
|
|
|
|
|
|
|
// @todo: Workaround because GroupSubsites->augmentSQL() is relying on session state
|
|
|
|
Subsite::changeSubsite($subsite1);
|
|
|
|
|
2017-06-01 14:49:55 +02:00
|
|
|
Session::set('loggedInAs', $subsite1member->ID);
|
2017-05-30 17:35:02 +02:00
|
|
|
$this->assertTrue(
|
|
|
|
(bool)$subsite1page->canEdit(),
|
|
|
|
'Members can edit pages on a subsite if they are in a group belonging to this subsite'
|
|
|
|
);
|
|
|
|
|
2017-06-01 14:49:55 +02:00
|
|
|
Session::set('loggedInAs', $subsite2member->ID);
|
2017-05-30 17:35:02 +02:00
|
|
|
$this->assertFalse(
|
|
|
|
(bool)$subsite1page->canEdit(),
|
|
|
|
'Members cant edit pages on a subsite if they are not in a group belonging to this subsite'
|
|
|
|
);
|
|
|
|
|
|
|
|
// @todo: Workaround because GroupSubsites->augmentSQL() is relying on session state
|
|
|
|
Subsite::changeSubsite(0);
|
|
|
|
$this->assertFalse(
|
|
|
|
$mainpage->canEdit(),
|
|
|
|
'Members cant edit pages on the main site if they are not in a group allowing this'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Similar to {@link SubsitesVirtualPageTest->testSubsiteVirtualPageCanHaveSameUrlsegmentAsOtherSubsite()}.
|
|
|
|
*/
|
|
|
|
public function testTwoPagesWithSameURLOnDifferentSubsites()
|
|
|
|
{
|
|
|
|
// Set up a couple of pages with the same URL on different subsites
|
2017-05-24 15:26:28 +02:00
|
|
|
$s1 = $this->objFromFixture(Subsite::class, 'domaintest1');
|
|
|
|
$s2 = $this->objFromFixture(Subsite::class, 'domaintest2');
|
|
|
|
|
2017-05-30 17:35:02 +02:00
|
|
|
$p1 = new SiteTree();
|
2017-06-01 14:49:55 +02:00
|
|
|
$p1->Title = $p1->URLSegment = 'test-page';
|
2017-05-30 17:35:02 +02:00
|
|
|
$p1->SubsiteID = $s1->ID;
|
|
|
|
$p1->write();
|
2017-05-24 15:26:28 +02:00
|
|
|
|
|
|
|
$p2 = new SiteTree();
|
2017-06-01 14:49:55 +02:00
|
|
|
$p2->Title = $p1->URLSegment = 'test-page';
|
2017-05-24 15:26:28 +02:00
|
|
|
$p2->SubsiteID = $s2->ID;
|
|
|
|
$p2->write();
|
|
|
|
|
|
|
|
// Check that the URLs weren't modified in our set-up
|
|
|
|
$this->assertEquals($p1->URLSegment, 'test-page');
|
|
|
|
$this->assertEquals($p2->URLSegment, 'test-page');
|
|
|
|
|
|
|
|
// Check that if we switch between the different subsites, we receive the correct pages
|
|
|
|
Subsite::changeSubsite($s1);
|
|
|
|
$this->assertEquals($p1->ID, SiteTree::get_by_link('test-page')->ID);
|
|
|
|
|
2017-05-30 17:35:02 +02:00
|
|
|
Subsite::changeSubsite($s2);
|
|
|
|
$this->assertEquals($p2->ID, SiteTree::get_by_link('test-page')->ID);
|
|
|
|
}
|
2017-05-24 15:26:28 +02:00
|
|
|
|
2017-05-30 17:35:02 +02:00
|
|
|
public function testPageTypesBlacklistInClassDropdown()
|
|
|
|
{
|
|
|
|
$editor = $this->objFromFixture(Member::class, 'editor');
|
2017-06-01 14:49:55 +02:00
|
|
|
Session::set('loggedInAs', $editor->ID);
|
2017-05-24 15:26:28 +02:00
|
|
|
|
|
|
|
$s1 = $this->objFromFixture(Subsite::class, 'domaintest1');
|
|
|
|
$s2 = $this->objFromFixture(Subsite::class, 'domaintest2');
|
2017-05-30 17:35:02 +02:00
|
|
|
$page = singleton(SiteTree::class);
|
|
|
|
|
2017-05-31 06:41:45 +02:00
|
|
|
$s1->PageTypeBlacklist = implode(',', [SiteTreeSubsitesTest_ClassA::class , ErrorPage::class]);
|
2017-05-30 17:35:02 +02:00
|
|
|
$s1->write();
|
|
|
|
|
|
|
|
Subsite::changeSubsite($s1);
|
|
|
|
$settingsFields = $page->getSettingsFields()->dataFieldByName('ClassName')->getSource();
|
|
|
|
|
|
|
|
$this->assertArrayNotHasKey(ErrorPage::class,
|
|
|
|
$settingsFields
|
|
|
|
);
|
2017-05-31 06:41:45 +02:00
|
|
|
$this->assertArrayNotHasKey(SiteTreeSubsitesTest_ClassA::class,
|
2017-05-30 17:35:02 +02:00
|
|
|
$settingsFields
|
|
|
|
);
|
2017-05-31 06:41:45 +02:00
|
|
|
$this->assertArrayHasKey(SiteTreeSubsitesTest_ClassB::class,
|
2017-05-30 17:35:02 +02:00
|
|
|
$settingsFields
|
|
|
|
);
|
|
|
|
|
|
|
|
Subsite::changeSubsite($s2);
|
|
|
|
$settingsFields = $page->getSettingsFields()->dataFieldByName('ClassName')->getSource();
|
|
|
|
$this->assertArrayHasKey(ErrorPage::class,
|
|
|
|
$settingsFields
|
|
|
|
);
|
2017-05-31 06:41:45 +02:00
|
|
|
$this->assertArrayHasKey(SiteTreeSubsitesTest_ClassA::class,
|
2017-05-30 17:35:02 +02:00
|
|
|
$settingsFields
|
|
|
|
);
|
2017-05-31 06:41:45 +02:00
|
|
|
$this->assertArrayHasKey(SiteTreeSubsitesTest_ClassB::class,
|
2017-05-30 17:35:02 +02:00
|
|
|
$settingsFields
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testCopyToSubsite()
|
|
|
|
{
|
2017-05-29 13:42:42 +02:00
|
|
|
// Remove baseurl if testing in subdir
|
2017-05-30 15:14:28 +02:00
|
|
|
Config::modify()->set(Director::class, 'alternate_base_url', '/');
|
2017-05-29 13:42:42 +02:00
|
|
|
|
|
|
|
/** @var Subsite $otherSubsite */
|
|
|
|
$otherSubsite = $this->objFromFixture(Subsite::class, 'subsite1');
|
|
|
|
$staffPage = $this->objFromFixture('Page', 'staff'); // nested page
|
|
|
|
$contactPage = $this->objFromFixture('Page', 'contact'); // top level page
|
|
|
|
|
|
|
|
$staffPage2 = $staffPage->duplicateToSubsite($otherSubsite->ID);
|
|
|
|
$contactPage2 = $contactPage->duplicateToSubsite($otherSubsite->ID);
|
|
|
|
|
|
|
|
$this->assertNotEquals($staffPage->ID, $staffPage2->ID);
|
|
|
|
$this->assertNotEquals($staffPage->SubsiteID, $staffPage2->SubsiteID);
|
|
|
|
$this->assertNotEquals($contactPage->ID, $contactPage2->ID);
|
|
|
|
$this->assertNotEquals($contactPage->SubsiteID, $contactPage2->SubsiteID);
|
|
|
|
$this->assertEmpty($staffPage2->ParentID);
|
|
|
|
$this->assertEmpty($contactPage2->ParentID);
|
|
|
|
$this->assertNotEmpty($staffPage->ParentID);
|
|
|
|
$this->assertEmpty($contactPage->ParentID);
|
|
|
|
|
|
|
|
// Staff is shifted to top level and given a unique url segment
|
|
|
|
$domain = $otherSubsite->domain();
|
2017-05-30 17:35:02 +02:00
|
|
|
$this->assertEquals('http://' . $domain . '/staff-2/', $staffPage2->AbsoluteLink());
|
|
|
|
$this->assertEquals('http://' . $domain . '/contact-us-2/', $contactPage2->AbsoluteLink());
|
2017-05-29 13:42:42 +02:00
|
|
|
}
|
2017-05-24 15:26:28 +02:00
|
|
|
|
2017-05-30 17:35:02 +02:00
|
|
|
public function testPageTypesBlacklistInCMSMain()
|
|
|
|
{
|
|
|
|
$editor = $this->objFromFixture(Member::class, 'editor');
|
2017-06-01 14:49:55 +02:00
|
|
|
Session::set('loggedInAs', $editor->ID);
|
2017-05-24 15:26:28 +02:00
|
|
|
|
2017-05-30 17:35:02 +02:00
|
|
|
$cmsmain = new CMSMain();
|
2017-05-24 15:26:28 +02:00
|
|
|
|
2017-05-30 17:35:02 +02:00
|
|
|
$s1 = $this->objFromFixture(Subsite::class, 'domaintest1');
|
|
|
|
$s2 = $this->objFromFixture(Subsite::class, 'domaintest2');
|
2017-05-24 15:26:28 +02:00
|
|
|
|
2017-05-31 06:41:45 +02:00
|
|
|
$s1->PageTypeBlacklist = implode(',', [SiteTreeSubsitesTest_ClassA::class , ErrorPage::class]);
|
2017-05-30 17:35:02 +02:00
|
|
|
$s1->write();
|
2017-05-24 15:26:28 +02:00
|
|
|
|
2017-05-30 17:35:02 +02:00
|
|
|
Subsite::changeSubsite($s1);
|
|
|
|
$hints = Convert::json2array($cmsmain->SiteTreeHints());
|
|
|
|
$classes = $hints['Root']['disallowedChildren'];
|
|
|
|
$this->assertContains(ErrorPage::class, $classes);
|
2017-05-31 06:41:45 +02:00
|
|
|
$this->assertContains(SiteTreeSubsitesTest_ClassA::class, $classes);
|
|
|
|
$this->assertNotContains(SiteTreeSubsitesTest_ClassB::class, $classes);
|
2017-05-30 17:35:02 +02:00
|
|
|
|
|
|
|
Subsite::changeSubsite($s2);
|
|
|
|
$hints = Convert::json2array($cmsmain->SiteTreeHints());
|
|
|
|
$classes = $hints['Root']['disallowedChildren'];
|
|
|
|
$this->assertNotContains(ErrorPage::class, $classes);
|
2017-05-31 06:41:45 +02:00
|
|
|
$this->assertNotContains(SiteTreeSubsitesTest_ClassA::class, $classes);
|
|
|
|
$this->assertNotContains(SiteTreeSubsitesTest_ClassB::class, $classes);
|
2017-05-30 17:35:02 +02:00
|
|
|
}
|
2017-05-24 15:26:28 +02:00
|
|
|
|
2017-05-29 13:42:42 +02:00
|
|
|
/**
|
|
|
|
* Tests that url segments between subsites don't conflict, but do conflict within them
|
|
|
|
*/
|
2017-05-30 17:35:02 +02:00
|
|
|
public function testValidateURLSegment()
|
|
|
|
{
|
2017-05-29 13:42:42 +02:00
|
|
|
$this->logInWithPermission('ADMIN');
|
|
|
|
// Saving existing page in the same subsite doesn't change urls
|
|
|
|
$mainHome = $this->objFromFixture('Page', 'home');
|
|
|
|
$mainSubsiteID = $this->idFromFixture(Subsite::class, 'main');
|
|
|
|
Subsite::changeSubsite($mainSubsiteID);
|
|
|
|
$mainHome->Content = '<p>Some new content</p>';
|
|
|
|
$mainHome->write();
|
|
|
|
$this->assertEquals('home', $mainHome->URLSegment);
|
|
|
|
$mainHome->doPublish();
|
|
|
|
$mainHomeLive = Versioned::get_one_by_stage('Page', 'Live', sprintf('"SiteTree"."ID" = \'%d\'', $mainHome->ID));
|
|
|
|
$this->assertEquals('home', $mainHomeLive->URLSegment);
|
|
|
|
|
|
|
|
// Saving existing page in another subsite doesn't change urls
|
|
|
|
Subsite::changeSubsite($mainSubsiteID);
|
|
|
|
$subsite1Home = $this->objFromFixture('Page', 'subsite1_home');
|
|
|
|
$subsite1Home->Content = '<p>In subsite 1</p>';
|
|
|
|
$subsite1Home->write();
|
|
|
|
$this->assertEquals('home', $subsite1Home->URLSegment);
|
|
|
|
$subsite1Home->doPublish();
|
2017-05-30 17:35:02 +02:00
|
|
|
$subsite1HomeLive = Versioned::get_one_by_stage('Page', 'Live',
|
|
|
|
sprintf('"SiteTree"."ID" = \'%d\'', $subsite1Home->ID));
|
2017-05-29 13:42:42 +02:00
|
|
|
$this->assertEquals('home', $subsite1HomeLive->URLSegment);
|
|
|
|
|
|
|
|
// Creating a new page in a subsite doesn't conflict with urls in other subsites
|
|
|
|
$subsite1ID = $this->idFromFixture(Subsite::class, 'subsite1');
|
|
|
|
Subsite::changeSubsite($subsite1ID);
|
|
|
|
$subsite1NewPage = new Page();
|
|
|
|
$subsite1NewPage->SubsiteID = $subsite1ID;
|
|
|
|
$subsite1NewPage->Title = 'Important Page (Subsite 1)';
|
|
|
|
$subsite1NewPage->URLSegment = 'important-page'; // Also exists in main subsite
|
|
|
|
$subsite1NewPage->write();
|
|
|
|
$this->assertEquals('important-page', $subsite1NewPage->URLSegment);
|
|
|
|
$subsite1NewPage->doPublish();
|
2017-05-30 17:35:02 +02:00
|
|
|
$subsite1NewPageLive = Versioned::get_one_by_stage('Page', 'Live',
|
|
|
|
sprintf('"SiteTree"."ID" = \'%d\'', $subsite1NewPage->ID));
|
2017-05-29 13:42:42 +02:00
|
|
|
$this->assertEquals('important-page', $subsite1NewPageLive->URLSegment);
|
|
|
|
|
|
|
|
// Creating a new page in a subsite DOES conflict with urls in the same subsite
|
|
|
|
$subsite1NewPage2 = new Page();
|
|
|
|
$subsite1NewPage2->SubsiteID = $subsite1ID;
|
|
|
|
$subsite1NewPage2->Title = 'Important Page (Subsite 1)';
|
|
|
|
$subsite1NewPage2->URLSegment = 'important-page'; // Also exists in main subsite
|
|
|
|
$subsite1NewPage2->write();
|
|
|
|
$this->assertEquals('important-page-2', $subsite1NewPage2->URLSegment);
|
|
|
|
$subsite1NewPage2->doPublish();
|
2017-05-30 17:35:02 +02:00
|
|
|
$subsite1NewPage2Live = Versioned::get_one_by_stage('Page', 'Live',
|
|
|
|
sprintf('"SiteTree"."ID" = \'%d\'', $subsite1NewPage2->ID));
|
2017-05-29 13:42:42 +02:00
|
|
|
$this->assertEquals('important-page-2', $subsite1NewPage2Live->URLSegment);
|
|
|
|
|
|
|
|
// Original page is left un-modified
|
|
|
|
$mainSubsiteImportantPageID = $this->idFromFixture('Page', 'importantpage');
|
|
|
|
$mainSubsiteImportantPage = Page::get()->byID($mainSubsiteImportantPageID);
|
|
|
|
$this->assertEquals('important-page', $mainSubsiteImportantPage->URLSegment);
|
|
|
|
$mainSubsiteImportantPage->Content = '<p>New Important Page Content</p>';
|
|
|
|
$mainSubsiteImportantPage->write();
|
|
|
|
$this->assertEquals('important-page', $mainSubsiteImportantPage->URLSegment);
|
|
|
|
}
|
2017-05-24 15:26:28 +02:00
|
|
|
|
2017-05-30 17:35:02 +02:00
|
|
|
public function testCopySubsiteWithChildren()
|
|
|
|
{
|
2017-05-29 13:42:42 +02:00
|
|
|
$page = $this->objFromFixture('Page', 'about');
|
|
|
|
$newSubsite = $this->objFromFixture(Subsite::class, 'subsite1');
|
2017-05-24 15:26:28 +02:00
|
|
|
|
2017-05-29 13:42:42 +02:00
|
|
|
$moved = $page->duplicateToSubsite($newSubsite->ID, true);
|
|
|
|
$this->assertEquals($moved->SubsiteID, $newSubsite->ID, 'Ensure returned records are on new subsite');
|
2017-05-30 17:35:02 +02:00
|
|
|
$this->assertEquals($moved->AllChildren()->count(), $page->AllChildren()->count(),
|
|
|
|
'All pages are copied across');
|
2017-05-24 15:26:28 +02:00
|
|
|
}
|
2016-09-22 16:38:29 +02:00
|
|
|
|
2017-05-30 17:35:02 +02:00
|
|
|
public function testCopySubsiteWithoutChildren()
|
|
|
|
{
|
2017-05-29 13:42:42 +02:00
|
|
|
$page = $this->objFromFixture('Page', 'about');
|
|
|
|
$newSubsite = $this->objFromFixture(Subsite::class, 'subsite2');
|
|
|
|
|
|
|
|
$moved = $page->duplicateToSubsite($newSubsite->ID, false);
|
|
|
|
$this->assertEquals($moved->SubsiteID, $newSubsite->ID, 'Ensure returned records are on new subsite');
|
|
|
|
$this->assertEquals($moved->AllChildren()->count(), 0, 'All pages are copied across');
|
|
|
|
}
|
2010-03-21 23:32:22 +01:00
|
|
|
}
|
2011-08-30 18:58:36 +02:00
|
|
|
|
2017-05-29 13:42:42 +02:00
|
|
|
|
2017-05-24 15:26:28 +02:00
|
|
|
class SiteTreeSubsitesTest_ClassA extends SiteTree implements TestOnly
|
|
|
|
{
|
|
|
|
}
|
2017-05-30 17:35:02 +02:00
|
|
|
|
2017-05-24 15:26:28 +02:00
|
|
|
class SiteTreeSubsitesTest_ClassB extends SiteTree implements TestOnly
|
|
|
|
{
|
|
|
|
}
|
2015-11-20 03:32:52 +01:00
|
|
|
|
2017-05-24 15:26:28 +02:00
|
|
|
class SiteTreeSubsitesTest_ErrorPage extends ErrorPage implements TestOnly
|
|
|
|
{
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Helper method to call protected members
|
|
|
|
*
|
|
|
|
* @param int $statusCode
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public static function get_error_filename_spy($statusCode)
|
|
|
|
{
|
|
|
|
return self::get_error_filename($statusCode);
|
|
|
|
}
|
2016-09-22 16:38:29 +02:00
|
|
|
}
|