Fix various ORM test issues

This commit is contained in:
Damian Mooyman 2016-11-13 20:35:43 +13:00
parent 00c9c2c775
commit 22cb3d0d74
105 changed files with 668 additions and 732 deletions

View File

@ -514,21 +514,21 @@ mappings:
SilverStripe\View\Parsers\SS_Transliterator: SilverStripe\View\Parsers\Transliterator SilverStripe\View\Parsers\SS_Transliterator: SilverStripe\View\Parsers\Transliterator
URLSegmentFilter: SilverStripe\View\Parsers\URLSegmentFilter URLSegmentFilter: SilverStripe\View\Parsers\URLSegmentFilter
CampaignAdminTest: SilverStripe\Admin\Tests\CampaignAdminTest CampaignAdminTest: SilverStripe\Admin\Tests\CampaignAdminTest
CampaignAdminTest_InvalidChangeSet: SilverStripe\Admin\Tests\CampaignAdminTest_InvalidChangeSet CampaignAdminTest_InvalidChangeSet: SilverStripe\Admin\Tests\CampaignAdminTest\CampaignAdminTest_InvalidChangeSet
CMSMenuItemTest: SilverStripe\Admin\Tests\CMSMenuItemTest CMSMenuItemTest: SilverStripe\Admin\Tests\CMSMenuItemTest
CMSMenuTest: SilverStripe\Admin\Tests\CMSMenuTest CMSMenuTest: SilverStripe\Admin\Tests\CMSMenuTest
CMSMenuTest_LeftAndMainController: SilverStripe\Admin\Tests\CMSMenuTest_LeftAndMainController CMSMenuTest_LeftAndMainController: SilverStripe\Admin\Tests\CMSMenuTest\CMSMenuTest_LeftAndMainController
CMSMenuTest_CustomTitle: SilverStripe\Admin\Tests\CMSMenuTest_CustomTitle CMSMenuTest_CustomTitle: SilverStripe\Admin\Tests\CMSMenuTest\CMSMenuTest_CustomTitle
CMSProfileControllerTest: SilverStripe\Admin\Tests\CMSProfileControllerTest CMSProfileControllerTest: SilverStripe\Admin\Tests\CMSProfileControllerTest
CMSProfileControllerTestExtension: SilverStripe\Admin\Tests\CMSProfileControllerTestExtension CMSProfileControllerTestExtension: SilverStripe\Admin\Tests\CMSProfileControllerTest\CMSProfileControllerTestExtension
LeftAndMainTest: SilverStripe\Admin\Tests\LeftAndMainTest LeftAndMainTest: SilverStripe\Admin\Tests\LeftAndMainTest
LeftAndMainTest_Controller: SilverStripe\Admin\Tests\LeftAndMainTest_Controller LeftAndMainTest_Controller: SilverStripe\Admin\Tests\LeftAndMainTest\LeftAndMainTest_Controller
LeftAndMainTest_Object: SilverStripe\Admin\Tests\LeftAndMainTest_Object LeftAndMainTest_Object: SilverStripe\Admin\Tests\LeftAndMainTest\LeftAndMainTest_Object
ModelAdminTest: SilverStripe\Admin\Tests\ModelAdminTest ModelAdminTest: SilverStripe\Admin\Tests\ModelAdminTest
ModelAdminTest_Admin: SilverStripe\Admin\Tests\ModelAdminTest_Admin ModelAdminTest_Admin: SilverStripe\Admin\Tests\ModelAdminTest\ModelAdminTest_Admin
ModelAdminTest_PlayerAdmin: SilverStripe\Admin\Tests\ModelAdminTest_PlayerAdmin ModelAdminTest_PlayerAdmin: SilverStripe\Admin\Tests\ModelAdminTest\ModelAdminTest_PlayerAdmin
ModelAdminTest_Contact: SilverStripe\Admin\Tests\ModelAdminTest_Contact ModelAdminTest_Contact: SilverStripe\Admin\Tests\ModelAdminTest\ModelAdminTest_Contact
ModelAdminTest_Player: SilverStripe\Admin\Tests\ModelAdminTest_Player ModelAdminTest_Player: SilverStripe\Admin\Tests\ModelAdminTest\ModelAdminTest_Player
SecurityAdminTest: SilverStripe\Admin\Tests\SecurityAdminTest SecurityAdminTest: SilverStripe\Admin\Tests\SecurityAdminTest
AssetControlExtensionTest: SilverStripe\Assets\Tests\AssetControlExtensionTest AssetControlExtensionTest: SilverStripe\Assets\Tests\AssetControlExtensionTest
AssetControlExtensionTest_VersionedObject: SilverStripe\Assets\Tests\AssetControlExtensionTest_VersionedObject AssetControlExtensionTest_VersionedObject: SilverStripe\Assets\Tests\AssetControlExtensionTest_VersionedObject
@ -989,7 +989,7 @@ mappings:
ViewableDataTest_Cached: SilverStripe\View\Tests\ViewableDataTest\ViewableDataTest_Cached ViewableDataTest_Cached: SilverStripe\View\Tests\ViewableDataTest\ViewableDataTest_Cached
ViewableDataTest_NotCached: SilverStripe\View\Tests\ViewableDataTest\ViewableDataTest_NotCached ViewableDataTest_NotCached: SilverStripe\View\Tests\ViewableDataTest\ViewableDataTest_NotCached
ViewableDataTest_Failover: SilverStripe\View\Tests\ViewableDataTest\ViewableDataTest_Failover ViewableDataTest_Failover: SilverStripe\View\Tests\ViewableDataTest\ViewableDataTest_Failover
AssetStoreTest_SpyStore: SilverStripe\Assets\Tests\Store\AssetStoreTest\TestAssetStore AssetStoreTest_SpyStore: SilverStripe\Assets\Tests\Storage\AssetStoreTest\TestAssetStore
GridField_URLHandlerTest: SilverStripe\Forms\Tests\GridField\GridField_URLHandlerTest GridField_URLHandlerTest: SilverStripe\Forms\Tests\GridField\GridField_URLHandlerTest
GridField_URLHandlerTest_Controller: SilverStripe\Forms\Tests\GridField\GridField_URLHandlerTest\GridField_URLHandlerTest_Controller GridField_URLHandlerTest_Controller: SilverStripe\Forms\Tests\GridField\GridField_URLHandlerTest\GridField_URLHandlerTest_Controller
GridField_URLHandlerTest_Component: SilverStripe\Forms\Tests\GridField\GridField_URLHandlerTest\GridField_URLHandlerTest_Component GridField_URLHandlerTest_Component: SilverStripe\Forms\Tests\GridField\GridField_URLHandlerTest\GridField_URLHandlerTest_Component
@ -1050,6 +1050,11 @@ mappings:
SearchFilterApplyRelationTest_ManyManyParent: SilverStripe\ORM\Tests\Filters\SearchFilterApplyRelationTest\SearchFilterApplyRelationTest_ManyManyParent SearchFilterApplyRelationTest_ManyManyParent: SilverStripe\ORM\Tests\Filters\SearchFilterApplyRelationTest\SearchFilterApplyRelationTest_ManyManyParent
SearchFilterApplyRelationTest_ManyManyChild: SilverStripe\ORM\Tests\Filters\SearchFilterApplyRelationTest\SearchFilterApplyRelationTest_ManyManyChild SearchFilterApplyRelationTest_ManyManyChild: SilverStripe\ORM\Tests\Filters\SearchFilterApplyRelationTest\SearchFilterApplyRelationTest_ManyManyChild
SearchFilterApplyRelationTest_ManyManyGrantChild: SilverStripe\ORM\Tests\Filters\SearchFilterApplyRelationTest\SearchFilterApplyRelationTest_ManyManyGrantChild SearchFilterApplyRelationTest_ManyManyGrantChild: SilverStripe\ORM\Tests\Filters\SearchFilterApplyRelationTest\SearchFilterApplyRelationTest_ManyManyGrantChild
RSSFeedTest: SilverStripe\Control\Tests\RSS\RSSFeedTest
RSSFeedTest_ItemA: SilverStripe\Control\Tests\RSS\RSSFeedTest\ItemA
RSSFeedTest_ItemB: SilverStripe\Control\Tests\RSS\RSSFeedTest\ItemB
RSSFeedTest_ItemC: SilverStripe\Control\Tests\RSS\RSSFeedTest\ItemC
RSSFeedTest_ItemD: SilverStripe\Control\Tests\RSS\RSSFeedTest\ItemD
skipConfigs: skipConfigs:
- db - db
- casting - casting

View File

@ -70,7 +70,8 @@ class CMSMenu extends Object implements IteratorAggregate, i18nEntityProvider {
*/ */
public static function add_controller($controllerClass) { public static function add_controller($controllerClass) {
if($menuItem = self::menuitem_for_controller($controllerClass)) { if($menuItem = self::menuitem_for_controller($controllerClass)) {
self::add_menu_item_obj($controllerClass, $menuItem); $code = static::get_menu_code($controllerClass);
self::add_menu_item_obj($code, $menuItem);
} }
} }

View File

@ -2,16 +2,9 @@
namespace SilverStripe\Admin\Tests; namespace SilverStripe\Admin\Tests;
use SilverStripe\Admin\CMSMenuItem; use SilverStripe\Admin\CMSMenuItem;
use SilverStripe\Dev\SapphireTest; use SilverStripe\Dev\SapphireTest;
/**
* @package framework
* @subpackage tests
*/
class CMSMenuItemTest extends SapphireTest { class CMSMenuItemTest extends SapphireTest {
public function testAttributes() { public function testAttributes() {

View File

@ -2,55 +2,48 @@
namespace SilverStripe\Admin\Tests; namespace SilverStripe\Admin\Tests;
use SilverStripe\Admin\CMSMenu; use SilverStripe\Admin\CMSMenu;
use SilverStripe\Admin\CMSMenuItem; use SilverStripe\Admin\CMSMenuItem;
use SilverStripe\Admin\LeftAndMain; use SilverStripe\Admin\LeftAndMain;
use SilverStripe\Admin\ModelAdmin;
use SilverStripe\Admin\SecurityAdmin; use SilverStripe\Admin\SecurityAdmin;
use SilverStripe\Dev\SapphireTest; use SilverStripe\Dev\SapphireTest;
use SilverStripe\Dev\TestOnly; use SilverStripe\Dev\TestOnly;
/**
* @package framework
* @subpackage tests
*/
class CMSMenuTest extends SapphireTest implements TestOnly { class CMSMenuTest extends SapphireTest implements TestOnly {
public function testBasicMenuHandling() { public function testBasicMenuHandling() {
// Clear existing menu // Clear existing menu
CMSMenu::clear_menu(); CMSMenu::clear_menu();
$menuItems = CMSMenu::get_menu_items(); $menuItems = CMSMenu::get_menu_items();
$this->assertTrue((empty($menuItems)), 'Menu can be cleared'); $this->assertTrue((empty($menuItems)), 'Menu can be cleared');
// Add a controller to the menu and check it is as expected // Add a controller to the menu and check it is as expected
CMSMenu::add_controller('CMSMenuTest_LeftAndMainController'); CMSMenu::add_controller(CMSMenuTest\LeftAndMainController::class);
$menuItems = CMSMenu::get_menu_items(); $menuItems = CMSMenu::get_menu_items();
$menuItem = $menuItems['CMSMenuTest_LeftAndMainController']; $menuItem = $menuItems['SilverStripe-Admin-Tests-CMSMenuTest-LeftAndMainController'];
$this->assertInstanceOf('SilverStripe\\Admin\\CMSMenuItem', $menuItem, 'Controller menu item is of class CMSMenuItem'); $this->assertInstanceOf(CMSMenuItem::class, $menuItem, 'Controller menu item is of class CMSMenuItem');
$this->assertContains($menuItem->url, singleton('CMSMenuTest_LeftAndMainController')->Link(), $this->assertContains($menuItem->url, CMSMenuTest\LeftAndMainController::singleton()->Link(),
'Controller menu item has the correct link'); 'Controller menu item has the correct link');
$this->assertEquals($menuItem->controller, 'CMSMenuTest_LeftAndMainController', $this->assertEquals($menuItem->controller, CMSMenuTest\LeftAndMainController::class,
'Controller menu item has the correct controller class'); 'Controller menu item has the correct controller class');
$this->assertEquals($menuItem->priority, singleton('CMSMenuTest_LeftAndMainController')->stat('menu_priority'), $this->assertEquals($menuItem->priority, CMSMenuTest\LeftAndMainController::singleton()->stat('menu_priority'),
'Controller menu item has the correct priority'); 'Controller menu item has the correct priority');
CMSMenu::clear_menu(); CMSMenu::clear_menu();
// Add another controller // Add another controller
CMSMenu::add_controller('CMSMenuTest_CustomTitle'); CMSMenu::add_controller(CMSMenuTest\CustomTitle::class);
$menuItems = CMSMenu::get_menu_items(); $menuItems = CMSMenu::get_menu_items();
$menuItem = $menuItems['CMSMenuTest_CustomTitle']; $menuItem = $menuItems['SilverStripe-Admin-Tests-CMSMenuTest-CustomTitle'];
$this->assertInstanceOf('SilverStripe\\Admin\\CMSMenuItem', $menuItem, 'Controller menu item is of class CMSMenuItem'); $this->assertInstanceOf(CMSMenuItem::class, $menuItem, 'Controller menu item is of class CMSMenuItem');
$this->assertEquals('CMSMenuTest_CustomTitle (localised)', $menuItem->title); $this->assertEquals(CMSMenuTest\CustomTitle::class . ' (localised)', $menuItem->title);
CMSMenu::clear_menu(); CMSMenu::clear_menu();
// Add a link to the menu // Add a link to the menu
CMSMenu::add_link('LinkCode', 'link title', 'http://www.example.com'); CMSMenu::add_link('LinkCode', 'link title', 'http://www.example.com');
$menuItems = CMSMenu::get_menu_items(); $menuItems = CMSMenu::get_menu_items();
$menuItem = $menuItems['LinkCode']; $menuItem = $menuItems['LinkCode'];
$this->assertInstanceOf('SilverStripe\\Admin\\CMSMenuItem', $menuItem, 'Link menu item is of class CMSMenuItem'); $this->assertInstanceOf(CMSMenuItem::class, $menuItem, 'Link menu item is of class CMSMenuItem');
$this->assertEquals($menuItem->title, 'link title', 'Link menu item has the correct title'); $this->assertEquals($menuItem->title, 'link title', 'Link menu item has the correct title');
$this->assertEquals($menuItem->url,'http://www.example.com', 'Link menu item has the correct link'); $this->assertEquals($menuItem->url,'http://www.example.com', 'Link menu item has the correct link');
$this->assertNull($menuItem->controller, 'Link menu item has no controller class'); $this->assertNull($menuItem->controller, 'Link menu item has no controller class');
@ -61,10 +54,10 @@ class CMSMenuTest extends SapphireTest implements TestOnly {
public function testRemove() { public function testRemove() {
CMSMenu::clear_menu(); CMSMenu::clear_menu();
CMSMenu::add_menu_item('custom', 'Custom Title', 'custom'); CMSMenu::add_menu_item('custom', 'Custom Title', 'custom');
CMSMenu::add_menu_item('other', 'Other Section', 'other', 'CMSMenuTest_LeftAndMainController'); CMSMenu::add_menu_item('other', 'Other Section', 'other', CMSMenuTest\LeftAndMainController::class);
$this->assertNotEmpty(CMSMenu::get_menu_items()); $this->assertNotEmpty(CMSMenu::get_menu_items());
CMSMenu::remove_menu_class('CMSMenuTest_LeftAndMainController'); CMSMenu::remove_menu_class(CMSMenuTest\LeftAndMainController::class);
CMSMenu::remove_menu_item('custom'); CMSMenu::remove_menu_item('custom');
$this->assertEmpty(CMSMenu::get_menu_items()); $this->assertEmpty(CMSMenu::get_menu_items());
@ -92,10 +85,9 @@ class CMSMenuTest extends SapphireTest implements TestOnly {
// 1.) SecurityAdmin is included // 1.) SecurityAdmin is included
// 2.) LeftAndMain & ModelAdmin are excluded // 2.) LeftAndMain & ModelAdmin are excluded
$cmsClasses = CMSMenu::get_cms_classes(); $cmsClasses = CMSMenu::get_cms_classes();
$this->assertContains('SilverStripe\\Admin\\SecurityAdmin', $cmsClasses, 'SecurityAdmin included in valid CMS Classes'); $this->assertContains(SecurityAdmin::class, $cmsClasses, 'SecurityAdmin included in valid CMS Classes');
$this->assertNotContains('SilverStripe\\Admin\\LeftAndMain', $cmsClasses, 'LeftAndMain not included in valid CMS Classes'); $this->assertNotContains(LeftAndMain::class, $cmsClasses, 'LeftAndMain not included in valid CMS Classes');
$this->assertNotContains('SilverStripe\\Admin\\ModelAdmin', $cmsClasses, 'LeftAndMain not included in valid CMS Classes'); $this->assertNotContains(ModelAdmin::class, $cmsClasses, 'LeftAndMain not included in valid CMS Classes');
} }
public function testAdvancedMenuHandling() { public function testAdvancedMenuHandling() {
@ -104,12 +96,16 @@ class CMSMenuTest extends SapphireTest implements TestOnly {
CMSMenu::clear_menu(); CMSMenu::clear_menu();
CMSMenu::populate_menu(); CMSMenu::populate_menu();
$menuItem = CMSMenu::get_menu_item('SilverStripe-Admin-SecurityAdmin'); $menuItem = CMSMenu::get_menu_item('SilverStripe-Admin-SecurityAdmin');
$this->assertInstanceOf('SilverStripe\\Admin\\CMSMenuItem', $menuItem, 'SecurityAdmin menu item exists'); $this->assertInstanceOf(CMSMenuItem::class, $menuItem, 'SecurityAdmin menu item exists');
$this->assertContains($menuItem->url, SecurityAdmin::singleton()->Link(), 'Menu item has the correct link'); $this->assertContains($menuItem->url, SecurityAdmin::singleton()->Link(), 'Menu item has the correct link');
$this->assertEquals($menuItem->controller, 'SilverStripe\\Admin\\SecurityAdmin', 'Menu item has the correct controller class');
$this->assertEquals( $this->assertEquals(
$menuItem->priority, SecurityAdmin::class,
$menuItem->controller,
'Menu item has the correct controller class'
);
$this->assertEquals(
SecurityAdmin::singleton()->stat('menu_priority'), SecurityAdmin::singleton()->stat('menu_priority'),
$menuItem->priority,
'Menu item has the correct priority' 'Menu item has the correct priority'
); );
@ -128,31 +124,3 @@ class CMSMenuTest extends SapphireTest implements TestOnly {
} }
} }
/**
* @package framework
* @subpackage tests
*/
class CMSMenuTest_LeftAndMainController extends LeftAndMain implements TestOnly {
private static $url_segment = 'CMSMenuTest_LeftAndMainController';
private static $menu_title = 'CMSMenuTest_LeftAndMainController';
private static $menu_priority = 50;
}
class CMSMenuTest_CustomTitle extends LeftAndMain implements TestOnly {
private static $url_segment = 'CMSMenuTest_CustomTitle';
private static $menu_priority = 50;
public static function menu_title($class = null, $localised = false) {
if($localised) {
return __CLASS__ . ' (localised)';
} else {
return __CLASS__ . ' (unlocalised)';
}
}
}

View File

@ -0,0 +1,22 @@
<?php
namespace SilverStripe\Admin\Tests\CMSMenuTest;
use SilverStripe\Admin\LeftAndMain;
use SilverStripe\Dev\TestOnly;
class CustomTitle extends LeftAndMain implements TestOnly
{
private static $url_segment = 'CMSMenuTest_CustomTitle';
private static $menu_priority = 50;
public static function menu_title($class = null, $localised = false)
{
if ($localised) {
return __CLASS__ . ' (localised)';
} else {
return __CLASS__ . ' (unlocalised)';
}
}
}

View File

@ -0,0 +1,15 @@
<?php
namespace SilverStripe\Admin\Tests\CMSMenuTest;
use SilverStripe\Admin\LeftAndMain;
use SilverStripe\Dev\TestOnly;
class LeftAndMainController extends LeftAndMain implements TestOnly
{
private static $url_segment = 'CMSMenuTest_LeftAndMainController';
private static $menu_title = 'CMSMenuTest_LeftAndMainController';
private static $menu_priority = 50;
}

View File

@ -2,19 +2,9 @@
namespace SilverStripe\Admin\Tests; namespace SilverStripe\Admin\Tests;
use SilverStripe\ORM\DataExtension;
use SilverStripe\Core\Config\Config;
use SilverStripe\Dev\FunctionalTest; use SilverStripe\Dev\FunctionalTest;
use SilverStripe\Security\Member; use SilverStripe\Security\Member;
/**
* @package framework
* @subpackage tests
*/
class CMSProfileControllerTest extends FunctionalTest { class CMSProfileControllerTest extends FunctionalTest {
protected static $fixture_file = 'CMSProfileControllerTest.yml'; protected static $fixture_file = 'CMSProfileControllerTest.yml';
@ -22,8 +12,8 @@ class CMSProfileControllerTest extends FunctionalTest {
public $autoFollowRedirection = false; public $autoFollowRedirection = false;
public function testMemberCantEditAnother() { public function testMemberCantEditAnother() {
$member = $this->objFromFixture('SilverStripe\\Security\\Member', 'user1'); $member = $this->objFromFixture(Member::class, 'user1');
$anotherMember = $this->objFromFixture('SilverStripe\\Security\\Member', 'user2'); $anotherMember = $this->objFromFixture(Member::class, 'user2');
$this->session()->inst_set('loggedInAs', $member->ID); $this->session()->inst_set('loggedInAs', $member->ID);
$response = $this->post('admin/myprofile/EditForm', array( $response = $this->post('admin/myprofile/EditForm', array(
@ -37,13 +27,13 @@ class CMSProfileControllerTest extends FunctionalTest {
'Password[_ConfirmPassword]' => 'password', 'Password[_ConfirmPassword]' => 'password',
)); ));
$anotherMember = $this->objFromFixture('SilverStripe\\Security\\Member', 'user2'); $anotherMember = $this->objFromFixture(Member::class, 'user2');
$this->assertNotEquals($anotherMember->FirstName, 'JoeEdited', 'FirstName field stays the same'); $this->assertNotEquals($anotherMember->FirstName, 'JoeEdited', 'FirstName field stays the same');
} }
public function testMemberEditsOwnProfile() { public function testMemberEditsOwnProfile() {
$member = $this->objFromFixture('SilverStripe\\Security\\Member', 'user3'); $member = $this->objFromFixture(Member::class, 'user3');
$this->session()->inst_set('loggedInAs', $member->ID); $this->session()->inst_set('loggedInAs', $member->ID);
$response = $this->post('admin/myprofile/EditForm', array( $response = $this->post('admin/myprofile/EditForm', array(
@ -57,16 +47,18 @@ class CMSProfileControllerTest extends FunctionalTest {
'Password[_ConfirmPassword]' => 'password', 'Password[_ConfirmPassword]' => 'password',
)); ));
$member = $this->objFromFixture('SilverStripe\\Security\\Member', 'user3'); $member = $this->objFromFixture(Member::class, 'user3');
$this->assertEquals('JoeEdited', $member->FirstName, 'FirstName field was changed'); $this->assertEquals('JoeEdited', $member->FirstName, 'FirstName field was changed');
} }
public function testExtendedPermissionsStopEditingOwnProfile() { public function testExtendedPermissionsStopEditingOwnProfile() {
$existingExtensions = Member::config()->get('extensions'); $existingExtensions = Member::config()->get('extensions');
Member::config()->update('extensions', array('CMSProfileControllerTestExtension')); Member::config()->update('extensions', [
CMSProfileControllerTest\TestExtension::class
]);
$member = $this->objFromFixture('SilverStripe\\Security\\Member', 'user1'); $member = $this->objFromFixture(Member::class, 'user1');
$this->session()->inst_set('loggedInAs', $member->ID); $this->session()->inst_set('loggedInAs', $member->ID);
$response = $this->post('admin/myprofile/EditForm', array( $response = $this->post('admin/myprofile/EditForm', array(
@ -80,7 +72,7 @@ class CMSProfileControllerTest extends FunctionalTest {
'Password[_ConfirmPassword]' => 'password', 'Password[_ConfirmPassword]' => 'password',
)); ));
$member = $this->objFromFixture('SilverStripe\\Security\\Member', 'user1'); $member = $this->objFromFixture(Member::class, 'user1');
$this->assertNotEquals($member->FirstName, 'JoeEdited', $this->assertNotEquals($member->FirstName, 'JoeEdited',
'FirstName field was NOT changed because we modified canEdit'); 'FirstName field was NOT changed because we modified canEdit');
@ -91,15 +83,3 @@ class CMSProfileControllerTest extends FunctionalTest {
} }
} }
/**
* @package framework
* @subpackage tests
*/
class CMSProfileControllerTestExtension extends DataExtension {
public function canEdit($member = null) {
return false;
}
}

View File

@ -0,0 +1,14 @@
<?php
namespace SilverStripe\Admin\Tests\CMSProfileControllerTest;
use SilverStripe\ORM\DataExtension;
class TestExtension extends DataExtension
{
public function canEdit($member = null)
{
return false;
}
}

View File

@ -2,16 +2,15 @@
namespace SilverStripe\Admin\Tests; namespace SilverStripe\Admin\Tests;
use SilverStripe\Dev\SapphireTest; use SilverStripe\Dev\SapphireTest;
use SilverStripe\Admin\CampaignAdmin; use SilverStripe\Admin\CampaignAdmin;
use SilverStripe\ORM\Versioning\ChangeSet;
use SilverStripe\ORM\UnexpectedDataException;
use ReflectionClass; use ReflectionClass;
class CampaignAdminTest extends SapphireTest class CampaignAdminTest extends SapphireTest
{ {
protected $extraDataObjects = [
CampaignAdminTest\InvalidChangeSet::class,
];
/** /**
* Call a protected method on an object via reflection * Call a protected method on an object via reflection
@ -19,27 +18,20 @@ class CampaignAdminTest extends SapphireTest
* @param object $object The object to call the method on * @param object $object The object to call the method on
* @param string $method The name of the method * @param string $method The name of the method
* @param array $args The arguments to pass to the method * @param array $args The arguments to pass to the method
* @return mixed
*/ */
function callProtectedMethod($object, $method, $args = []) { protected function callProtectedMethod($object, $method, $args = []) {
$class = new ReflectionClass(get_class($object)); $class = new ReflectionClass(get_class($object));
$methodObj = $class->getMethod($method); $methodObj = $class->getMethod($method);
$methodObj->setAccessible(true); $methodObj->setAccessible(true);
return $methodObj->invokeArgs($object, $args); return $methodObj->invokeArgs($object, $args);
} }
function testInvalidDataHandling() { public function testInvalidDataHandling() {
$changeset = new CampaignAdminTest_InvalidChangeSet(); $changeset = new CampaignAdminTest\InvalidChangeSet();
$admin = new CampaignAdmin(); $admin = new CampaignAdmin();
$result = $this->callProtectedMethod($admin, 'getChangeSetResource', [$changeset] ); $result = $this->callProtectedMethod($admin, 'getChangeSetResource', [$changeset] );
$this->assertEquals('Corrupt database! bad data' , $result['Description']); $this->assertEquals('Corrupt database! bad data' , $result['Description']);
} }
} }
class CampaignAdminTest_InvalidChangeSet extends ChangeSet
{
function sync()
{
throw new UnexpectedDataException("bad data");
}
}

View File

@ -0,0 +1,14 @@
<?php
namespace SilverStripe\Admin\Tests\CampaignAdminTest;
use SilverStripe\ORM\UnexpectedDataException;
use SilverStripe\ORM\Versioning\ChangeSet;
class InvalidChangeSet extends ChangeSet
{
public function sync()
{
throw new UnexpectedDataException("bad data");
}
}

View File

@ -2,30 +2,29 @@
namespace SilverStripe\Admin\Tests; namespace SilverStripe\Admin\Tests;
use SilverStripe\ORM\DataObject; use SilverStripe\ORM\DataObject;
use SilverStripe\Admin\CMSMenu; use SilverStripe\Admin\CMSMenu;
use SilverStripe\Admin\LeftAndMain; use SilverStripe\Admin\LeftAndMain;
use SilverStripe\Core\Config\Config;
use SilverStripe\Dev\FunctionalTest; use SilverStripe\Dev\FunctionalTest;
use SilverStripe\Dev\TestOnly; use SilverStripe\Security\Member;
use SilverStripe\View\Requirements; use SilverStripe\View\Requirements;
/**
* @package framework
* @subpackage tests
*/
class LeftAndMainTest extends FunctionalTest { class LeftAndMainTest extends FunctionalTest {
protected static $fixture_file = 'LeftAndMainTest.yml'; protected static $fixture_file = 'LeftAndMainTest.yml';
protected $extraDataObjects = array('LeftAndMainTest_Object'); protected $extraDataObjects = [
LeftAndMainTest\TestObject::class
];
protected $extraControllers = [
LeftAndMainTest\TestController::class,
];
protected $backupCombined; protected $backupCombined;
public function setUp() { public function setUp()
{
parent::setUp(); parent::setUp();
// @todo fix controller stack problems and re-activate // @todo fix controller stack problems and re-activate
@ -35,10 +34,10 @@ class LeftAndMainTest extends FunctionalTest {
LeftAndMain::config() LeftAndMain::config()
->update('extra_requirements_css', array( ->update('extra_requirements_css', array(
FRAMEWORK_DIR . '/tests/assets/LeftAndMainTest.css' FRAMEWORK_ADMIN_DIR . '/tests/assets/LeftAndMainTest.css'
)) ))
->update('extra_requirements_javascript', array( ->update('extra_requirements_javascript', array(
FRAMEWORK_DIR . '/tests/assets/LeftAndMainTest.js' FRAMEWORK_ADMIN_DIR . '/tests/assets/LeftAndMainTest.js'
)); ));
Requirements::set_combined_files_enabled(false); Requirements::set_combined_files_enabled(false);
@ -66,9 +65,8 @@ class LeftAndMainTest extends FunctionalTest {
Requirements::set_combined_files_enabled($this->backupCombined); Requirements::set_combined_files_enabled($this->backupCombined);
} }
public function testExtraCssAndJavascript() { public function testExtraCssAndJavascript() {
$admin = $this->objFromFixture('SilverStripe\\Security\\Member', 'admin'); $admin = $this->objFromFixture(Member::class, 'admin');
$this->session()->inst_set('loggedInAs', $admin->ID); $this->session()->inst_set('loggedInAs', $admin->ID);
$response = $this->get('LeftAndMainTest_Controller'); $response = $this->get('LeftAndMainTest_Controller');
@ -86,7 +84,7 @@ class LeftAndMainTest extends FunctionalTest {
$this->logInWithPermission('ADMIN'); $this->logInWithPermission('ADMIN');
// forcing sorting for non-MySQL // forcing sorting for non-MySQL
$rootPages = LeftAndMainTest_Object::get() $rootPages = LeftAndMainTest\TestObject::get()
->filter("ParentID", 0) ->filter("ParentID", 0)
->sort('"ID"'); ->sort('"ID"');
$siblingIDs = $rootPages->column('ID'); $siblingIDs = $rootPages->column('ID');
@ -105,9 +103,9 @@ class LeftAndMainTest extends FunctionalTest {
$response = $this->post('LeftAndMainTest_Controller/savetreenode', $data); $response = $this->post('LeftAndMainTest_Controller/savetreenode', $data);
$this->assertEquals(200, $response->getStatusCode()); $this->assertEquals(200, $response->getStatusCode());
$page1 = DataObject::get_by_id('LeftAndMainTest_Object', $page1->ID, false); $page1 = DataObject::get_by_id(LeftAndMainTest\TestObject::class, $page1->ID, false);
$page2 = DataObject::get_by_id('LeftAndMainTest_Object', $page2->ID, false); $page2 = DataObject::get_by_id(LeftAndMainTest\TestObject::class, $page2->ID, false);
$page3 = DataObject::get_by_id('LeftAndMainTest_Object', $page3->ID, false); $page3 = DataObject::get_by_id(LeftAndMainTest\TestObject::class, $page3->ID, false);
$this->assertEquals(2, $page1->Sort, 'Page1 is sorted after Page2'); $this->assertEquals(2, $page1->Sort, 'Page1 is sorted after Page2');
$this->assertEquals(1, $page2->Sort, 'Page2 is sorted before Page1'); $this->assertEquals(1, $page2->Sort, 'Page2 is sorted before Page1');
@ -117,10 +115,10 @@ class LeftAndMainTest extends FunctionalTest {
public function testSaveTreeNodeParentID() { public function testSaveTreeNodeParentID() {
$this->logInWithPermission('ADMIN'); $this->logInWithPermission('ADMIN');
$page2 = $this->objFromFixture('LeftAndMainTest_Object', 'page2'); $page2 = $this->objFromFixture(LeftAndMainTest\TestObject::class, 'page2');
$page3 = $this->objFromFixture('LeftAndMainTest_Object', 'page3'); $page3 = $this->objFromFixture(LeftAndMainTest\TestObject::class, 'page3');
$page31 = $this->objFromFixture('LeftAndMainTest_Object', 'page31'); $page31 = $this->objFromFixture(LeftAndMainTest\TestObject::class, 'page31');
$page32 = $this->objFromFixture('LeftAndMainTest_Object', 'page32'); $page32 = $this->objFromFixture(LeftAndMainTest\TestObject::class, 'page32');
// Move page2 into page3, between page3.1 and page 3.2 // Move page2 into page3, between page3.1 and page 3.2
$siblingIDs = array( $siblingIDs = array(
@ -135,9 +133,9 @@ class LeftAndMainTest extends FunctionalTest {
); );
$response = $this->post('LeftAndMainTest_Controller/savetreenode', $data); $response = $this->post('LeftAndMainTest_Controller/savetreenode', $data);
$this->assertEquals(200, $response->getStatusCode()); $this->assertEquals(200, $response->getStatusCode());
$page2 = DataObject::get_by_id('LeftAndMainTest_Object', $page2->ID, false); $page2 = DataObject::get_by_id(LeftAndMainTest\TestObject::class, $page2->ID, false);
$page31 = DataObject::get_by_id('LeftAndMainTest_Object', $page31->ID, false); $page31 = DataObject::get_by_id(LeftAndMainTest\TestObject::class, $page31->ID, false);
$page32 = DataObject::get_by_id('LeftAndMainTest_Object', $page32->ID, false); $page32 = DataObject::get_by_id(LeftAndMainTest\TestObject::class, $page32->ID, false);
$this->assertEquals($page3->ID, $page2->ParentID, 'Moved page gets new parent'); $this->assertEquals($page3->ID, $page2->ParentID, 'Moved page gets new parent');
$this->assertEquals(1, $page31->Sort, 'Children pages before insertaion are unaffected'); $this->assertEquals(1, $page31->Sort, 'Children pages before insertaion are unaffected');
@ -149,7 +147,7 @@ class LeftAndMainTest extends FunctionalTest {
* Check that all subclasses of leftandmain can be accessed * Check that all subclasses of leftandmain can be accessed
*/ */
public function testLeftAndMainSubclasses() { public function testLeftAndMainSubclasses() {
$adminuser = $this->objFromFixture('SilverStripe\\Security\\Member','admin'); $adminuser = $this->objFromFixture(Member::class,'admin');
$this->session()->inst_set('loggedInAs', $adminuser->ID); $this->session()->inst_set('loggedInAs', $adminuser->ID);
$this->resetMenu(); $this->resetMenu();
@ -175,9 +173,9 @@ class LeftAndMainTest extends FunctionalTest {
} }
public function testCanView() { public function testCanView() {
$adminuser = $this->objFromFixture('SilverStripe\\Security\\Member', 'admin'); $adminuser = $this->objFromFixture(Member::class, 'admin');
$securityonlyuser = $this->objFromFixture('SilverStripe\\Security\\Member', 'securityonlyuser'); $securityonlyuser = $this->objFromFixture(Member::class, 'securityonlyuser');
$allcmssectionsuser = $this->objFromFixture('SilverStripe\\Security\\Member', 'allcmssectionsuser'); $allcmssectionsuser = $this->objFromFixture(Member::class, 'allcmssectionsuser');
// anonymous user // anonymous user
$this->session()->inst_set('loggedInAs', null); $this->session()->inst_set('loggedInAs', null);
@ -243,11 +241,11 @@ class LeftAndMainTest extends FunctionalTest {
* Test {@see LeftAndMain::updatetreenodes} * Test {@see LeftAndMain::updatetreenodes}
*/ */
public function testUpdateTreeNodes() { public function testUpdateTreeNodes() {
$page1 = $this->objFromFixture('LeftAndMainTest_Object', 'page1'); $page1 = $this->objFromFixture(LeftAndMainTest\TestObject::class, 'page1');
$page2 = $this->objFromFixture('LeftAndMainTest_Object', 'page2'); $page2 = $this->objFromFixture(LeftAndMainTest\TestObject::class, 'page2');
$page3 = $this->objFromFixture('LeftAndMainTest_Object', 'page3'); $page3 = $this->objFromFixture(LeftAndMainTest\TestObject::class, 'page3');
$page31 = $this->objFromFixture('LeftAndMainTest_Object', 'page31'); $page31 = $this->objFromFixture(LeftAndMainTest\TestObject::class, 'page31');
$page32 = $this->objFromFixture('LeftAndMainTest_Object', 'page32'); $page32 = $this->objFromFixture(LeftAndMainTest\TestObject::class, 'page32');
$this->logInWithPermission('ADMIN'); $this->logInWithPermission('ADMIN');
// Check page // Check page
@ -285,35 +283,3 @@ class LeftAndMainTest extends FunctionalTest {
$this->assertEquals(0, count($data)); $this->assertEquals(0, count($data));
} }
} }
/**
* @package framework
* @subpackage tests
*/
class LeftAndMainTest_Controller extends LeftAndMain implements TestOnly {
protected $template = 'BlankPage';
private static $tree_class = 'LeftAndMainTest_Object';
}
/**
* @package framework
* @subpackage tests
*/
class LeftAndMainTest_Object extends DataObject implements TestOnly {
private static $db = array(
'Title' => 'Varchar',
'URLSegment' => 'Varchar',
'Sort' => 'Int',
);
private static $default_sort = '"Sort"';
private static $extensions = array(
'SilverStripe\\ORM\\Hierarchy\\Hierarchy'
);
public function CMSTreeClasses() {}
}

View File

@ -1,4 +1,4 @@
LeftAndMainTest_Object: SilverStripe\Admin\Tests\LeftAndMainTest\TestObject:
page1: page1:
Title: Page 1 Title: Page 1
Sort: 1 Sort: 1
@ -10,11 +10,11 @@ LeftAndMainTest_Object:
Sort: 3 Sort: 3
page31: page31:
Title: Page 3.1 Title: Page 3.1
Parent: =>LeftAndMainTest_Object.page3 Parent: =>SilverStripe\Admin\Tests\LeftAndMainTest\TestObject.page3
Sort: 1 Sort: 1
page32: page32:
Title: Page 3.2 Title: Page 3.2
Parent: =>LeftAndMainTest_Object.page3 Parent: =>SilverStripe\Admin\Tests\LeftAndMainTest\TestObject.page3
Sort: 2 Sort: 2
page4: page4:
Title: Page 4 Title: Page 4

View File

@ -0,0 +1,19 @@
<?php
namespace SilverStripe\Admin\Tests\LeftAndMainTest;
use SilverStripe\Admin\LeftAndMain;
use SilverStripe\Control\Controller;
use SilverStripe\Dev\TestOnly;
class TestController extends LeftAndMain implements TestOnly
{
protected $template = 'BlankPage';
private static $tree_class = TestObject::class;
public function Link($action = null)
{
return Controller::join_links('LeftAndMainTest_Controller', $action, '/');
}
}

View File

@ -0,0 +1,29 @@
<?php
namespace SilverStripe\Admin\Tests\LeftAndMainTest;
use SilverStripe\Dev\TestOnly;
use SilverStripe\ORM\DataObject;
use SilverStripe\ORM\Hierarchy\Hierarchy;
class TestObject extends DataObject implements TestOnly
{
private static $table_name = 'LeftAndMainTest_Object';
private static $db = array(
'Title' => 'Varchar',
'URLSegment' => 'Varchar',
'Sort' => 'Int',
);
private static $default_sort = '"Sort"';
private static $extensions = [
Hierarchy::class
];
public function CMSTreeClasses()
{
}
}

View File

@ -2,42 +2,40 @@
namespace SilverStripe\Admin\Tests; namespace SilverStripe\Admin\Tests;
use SilverStripe\ORM\DataObject;
use SilverStripe\Security\Permission; use SilverStripe\Security\Permission;
use SilverStripe\Admin\ModelAdmin;
use SilverStripe\Dev\FunctionalTest; use SilverStripe\Dev\FunctionalTest;
use SilverStripe\Dev\TestOnly;
class ModelAdminTest extends FunctionalTest { class ModelAdminTest extends FunctionalTest {
protected static $fixture_file = 'ModelAdminTest.yml'; protected static $fixture_file = 'ModelAdminTest.yml';
protected $extraDataObjects = array( protected $extraDataObjects = [
'ModelAdminTest_Admin', ModelAdminTest\Contact::class,
'ModelAdminTest_Contact', ModelAdminTest\Player::class
'ModelAdminTest_Player' ];
);
protected $extraControllers = [
ModelAdminTest\ContactAdmin::class,
ModelAdminTest\PlayerAdmin::class,
];
public function testModelAdminOpens() { public function testModelAdminOpens() {
$this->autoFollowRedirection = false; $this->autoFollowRedirection = false;
$this->logInAs('admin'); $this->logInAs('admin');
$this->assertTrue((bool)Permission::check("ADMIN")); $this->assertTrue((bool)Permission::check("ADMIN"));
$this->assertEquals(200, $this->get('ModelAdminTest_Admin')->getStatusCode()); $this->assertEquals(200, $this->get('ContactAdmin')->getStatusCode());
} }
public function testExportFieldsDefaultIsSummaryFields() { public function testExportFieldsDefaultIsSummaryFields() {
$admin = new ModelAdminTest_Admin(); $admin = new ModelAdminTest\ContactAdmin();
$admin->doInit(); $admin->doInit();
$this->assertEquals( $this->assertEquals(
$admin->getExportFields(), $admin->getExportFields(),
ModelAdminTest_Contact::singleton()->summaryFields() ModelAdminTest\Contact::singleton()->summaryFields()
); );
} }
public function testExportFieldsOverloadedMethod() { public function testExportFieldsOverloadedMethod() {
$admin = new ModelAdminTest_PlayerAdmin(); $admin = new ModelAdminTest\PlayerAdmin();
$admin->doInit(); $admin->doInit();
$this->assertEquals($admin->getExportFields(), array( $this->assertEquals($admin->getExportFields(), array(
'Name' => 'Name', 'Name' => 'Name',
@ -46,44 +44,3 @@ class ModelAdminTest extends FunctionalTest {
} }
} }
class ModelAdminTest_Admin extends ModelAdmin implements TestOnly {
private static $url_segment = 'testadmin';
private static $managed_models = array(
'ModelAdminTest_Contact',
);
}
class ModelAdminTest_PlayerAdmin extends ModelAdmin implements TestOnly {
private static $url_segment = 'testadmin';
private static $managed_models = array(
'ModelAdminTest_Player'
);
public function getExportFields() {
return array(
'Name' => 'Name',
'Position' => 'Position'
);
}
}
class ModelAdminTest_Contact extends DataObject implements TestOnly {
private static $db = array(
'Name' => 'Varchar',
'Phone' => 'Varchar',
);
private static $summary_fields = array(
'Name' => 'Name',
'Phone' => 'Phone'
);
}
class ModelAdminTest_Player extends DataObject implements TestOnly {
private static $db = array(
'Name' => 'Varchar',
'Position' => 'Varchar',
);
private static $has_one = array(
'Contact' => 'ModelAdminTest_Contact'
);
}

View File

@ -1,4 +1,4 @@
ModelAdminTest_Contact: SilverStripe\Admin\Tests\ModelAdminTest\Contact:
sam: sam:
Name: Sam Name: Sam
Phone: 021 123 456 Phone: 021 123 456

View File

@ -0,0 +1,19 @@
<?php
namespace SilverStripe\Admin\Tests\ModelAdminTest;
use SilverStripe\Dev\TestOnly;
use SilverStripe\ORM\DataObject;
class Contact extends DataObject implements TestOnly
{
private static $table_name = 'ModelAdminTest_Contact';
private static $db = array(
'Name' => 'Varchar',
'Phone' => 'Varchar',
);
private static $summary_fields = array(
'Name' => 'Name',
'Phone' => 'Phone'
);
}

View File

@ -0,0 +1,21 @@
<?php
namespace SilverStripe\Admin\Tests\ModelAdminTest;
use SilverStripe\Admin\ModelAdmin;
use SilverStripe\Control\Controller;
use SilverStripe\Dev\TestOnly;
class ContactAdmin extends ModelAdmin implements TestOnly
{
private static $url_segment = 'contactadmin';
private static $managed_models = array(
Contact::class,
);
public function Link($action = null) {
if(!$action) $action = $this->sanitiseClassName($this->modelClass);
return Controller::join_links('ContactAdmin', $action, '/');
}
}

View File

@ -0,0 +1,18 @@
<?php
namespace SilverStripe\Admin\Tests\ModelAdminTest;
use SilverStripe\Dev\TestOnly;
use SilverStripe\ORM\DataObject;
class Player extends DataObject implements TestOnly
{
private static $table_name = 'ModelAdminTest_Player';
private static $db = array(
'Name' => 'Varchar',
'Position' => 'Varchar',
);
private static $has_one = array(
'Contact' => Contact::class
);
}

View File

@ -0,0 +1,29 @@
<?php
namespace SilverStripe\Admin\Tests\ModelAdminTest;
use SilverStripe\Admin\ModelAdmin;
use SilverStripe\Control\Controller;
use SilverStripe\Dev\TestOnly;
class PlayerAdmin extends ModelAdmin implements TestOnly
{
private static $url_segment = 'playeradmin';
private static $managed_models = array(
Player::class
);
public function getExportFields()
{
return array(
'Name' => 'Name',
'Position' => 'Position'
);
}
public function Link($action = null) {
if(!$action) $action = $this->sanitiseClassName($this->modelClass);
return Controller::join_links('PlayerAdmin', $action, '/');
}
}

View File

@ -2,21 +2,19 @@
namespace SilverStripe\Admin\Tests; namespace SilverStripe\Admin\Tests;
use SilverStripe\Core\Config\Config; use SilverStripe\Core\Config\Config;
use SilverStripe\Dev\FunctionalTest; use SilverStripe\Dev\FunctionalTest;
use SilverStripe\Security\Group;
use SilverStripe\Security\Member;
use SilverStripe\Security\Permission;
/**
* @package cms
* @subpackage tests
*/
class SecurityAdminTest extends FunctionalTest { class SecurityAdminTest extends FunctionalTest {
protected static $fixture_file = 'LeftAndMainTest.yml'; protected static $fixture_file = 'LeftAndMainTest.yml';
protected $extraDataObjects = array('LeftAndMainTest_Object'); protected $extraDataObjects = [
LeftAndMainTest\TestObject::class,
];
// TODO Fix export feature (moved from MemberTableField to GridFieldExportButton) // TODO Fix export feature (moved from MemberTableField to GridFieldExportButton)
// public function testGroupExport() { // public function testGroupExport() {
@ -55,11 +53,11 @@ class SecurityAdminTest extends FunctionalTest {
// } // }
public function testPermissionFieldRespectsHiddenPermissions() { public function testPermissionFieldRespectsHiddenPermissions() {
$this->session()->inst_set('loggedInAs', $this->idFromFixture('SilverStripe\\Security\\Member', 'admin')); $this->session()->inst_set('loggedInAs', $this->idFromFixture(Member::class, 'admin'));
$group = $this->objFromFixture('SilverStripe\\Security\\Group', 'admin'); $group = $this->objFromFixture(Group::class, 'admin');
Config::inst()->update('SilverStripe\\Security\\Permission', 'hidden_permissions', array('CMS_ACCESS_ReportAdmin')); Config::inst()->update(Permission::class, 'hidden_permissions', array('CMS_ACCESS_ReportAdmin'));
$response = $this->get(sprintf('admin/security/EditForm/field/Groups/item/%d/edit', $group->ID)); $response = $this->get(sprintf('admin/security/EditForm/field/Groups/item/%d/edit', $group->ID));
$this->assertContains( $this->assertContains(

View File

@ -16,7 +16,7 @@
It is safe to remove this file for normal website operation. It is safe to remove this file for normal website operation.
--> -->
<phpunit bootstrap="tests/php/bootstrap.php" colors="true"> <phpunit bootstrap="tests/bootstrap.php" colors="true">
<testsuite name="Default"> <testsuite name="Default">
<directory>tests/php</directory> <directory>tests/php</directory>

View File

@ -98,7 +98,7 @@ class DBClassName extends DBEnum {
return $baseClass; return $baseClass;
} }
// Fallback to global default // Fallback to global default
return 'SilverStripe\ORM\DataObject'; return DataObject::class;
} }
/** /**

View File

@ -32,7 +32,7 @@ class AssetControlExtensionTest extends SapphireTest {
// Setup fixture manually // Setup fixture manually
$object1 = new AssetControlExtensionTest\VersionedObject(); $object1 = new AssetControlExtensionTest\VersionedObject();
$object1->Title = 'My object'; $object1->Title = 'My object';
$fish1 = realpath(__DIR__ .'/../ORM/testimages/test-image-high-quality.jpg'); $fish1 = realpath(__DIR__ .'/../ORM/ImageTest/test-image-high-quality.jpg');
$object1->Header->setFromLocalFile($fish1, 'Header/MyObjectHeader.jpg'); $object1->Header->setFromLocalFile($fish1, 'Header/MyObjectHeader.jpg');
$object1->Download->setFromString('file content', 'Documents/File.txt'); $object1->Download->setFromString('file content', 'Documents/File.txt');
$object1->write(); $object1->write();
@ -151,7 +151,7 @@ class AssetControlExtensionTest extends SapphireTest {
$object3TupleOld = $object3->Header->getValue(); $object3TupleOld = $object3->Header->getValue();
// Replace image and write each to filesystem // Replace image and write each to filesystem
$fish1 = realpath(__DIR__ .'/../ORM/testimages/test-image-high-quality.jpg'); $fish1 = realpath(__DIR__ .'/../ORM/ImageTest/test-image-high-quality.jpg');
$object1->Header->setFromLocalFile($fish1, 'Header/Replaced_MyObjectHeader.jpg'); $object1->Header->setFromLocalFile($fish1, 'Header/Replaced_MyObjectHeader.jpg');
$object1->write(); $object1->write();
$object2->Image->setFromLocalFile($fish1, 'Images/Replaced_BeautifulFish.jpg'); $object2->Image->setFromLocalFile($fish1, 'Images/Replaced_BeautifulFish.jpg');

View File

@ -8,9 +8,6 @@ use SilverStripe\Dev\SapphireTest;
/** /**
* Tests for the {@link SS_FileFinder} class. * Tests for the {@link SS_FileFinder} class.
*
* @package framework
* @subpackage tests
*/ */
class FileFinderTest extends SapphireTest { class FileFinderTest extends SapphireTest {

View File

@ -44,7 +44,7 @@ class FileMigrationHelperTest extends SapphireTest {
TestAssetStore::activate('FileMigrationHelperTest/assets'); TestAssetStore::activate('FileMigrationHelperTest/assets');
// Ensure that each file has a local record file in this new assets base // Ensure that each file has a local record file in this new assets base
$from = FRAMEWORK_PATH . '/tests/php/ORM/testimages/test-image-low-quality.jpg'; $from = FRAMEWORK_PATH . '/tests/php/ORM/ImageTest/test-image-low-quality.jpg';
foreach(File::get()->exclude('ClassName', Folder::class) as $file) { foreach(File::get()->exclude('ClassName', Folder::class) as $file) {
$dest = TestAssetStore::base_path() . '/' . $file->generateFilename(); $dest = TestAssetStore::base_path() . '/' . $file->generateFilename();
Filesystem::makeFolder(dirname($dest)); Filesystem::makeFolder(dirname($dest));

View File

@ -7,10 +7,6 @@ use SilverStripe\Core\Config\Config;
use SilverStripe\Dev\SapphireTest; use SilverStripe\Dev\SapphireTest;
use SilverStripe\View\Parsers\Transliterator; use SilverStripe\View\Parsers\Transliterator;
/**
* @package framework
* @subpackage tests
*/
class FileNameFilterTest extends SapphireTest { class FileNameFilterTest extends SapphireTest {
public function setUp() { public function setUp() {

View File

@ -13,9 +13,6 @@ use SilverStripe\Assets\Tests\Storage\AssetStoreTest\TestAssetStore;
/** /**
* @author Ingo Schommer (ingo at silverstripe dot com) * @author Ingo Schommer (ingo at silverstripe dot com)
*
* @package framework
* @subpackage tests
*/ */
class FolderTest extends SapphireTest { class FolderTest extends SapphireTest {

View File

@ -8,9 +8,6 @@ use SilverStripe\Dev\SapphireTest;
/** /**
* Tests for the {@link GD} class. * Tests for the {@link GD} class.
*
* @package framework
* @subpackage tests
*/ */
class GDTest extends SapphireTest { class GDTest extends SapphireTest {

View File

@ -56,7 +56,7 @@ class AssetStoreTest extends SapphireTest
); );
// Test setFromStream (seekable) // Test setFromStream (seekable)
$fish1 = realpath(__DIR__ . '/../../ORM/testimages/test-image-high-quality.jpg'); $fish1 = realpath(__DIR__ . '/../../ORM/ImageTest/test-image-high-quality.jpg');
$fish1Stream = fopen($fish1, 'r'); $fish1Stream = fopen($fish1, 'r');
$fish1Tuple = $backend->setFromStream($fish1Stream, 'parent/awesome-fish.jpg'); $fish1Tuple = $backend->setFromStream($fish1Stream, 'parent/awesome-fish.jpg');
fclose($fish1Stream); fclose($fish1Stream);
@ -71,7 +71,7 @@ class AssetStoreTest extends SapphireTest
// Test with non-seekable streams // Test with non-seekable streams
TestAssetStore::$seekable_override = false; TestAssetStore::$seekable_override = false;
$fish2 = realpath(__DIR__ . '/../../ORM/testimages/test-image-low-quality.jpg'); $fish2 = realpath(__DIR__ . '/../../ORM/ImageTest/test-image-low-quality.jpg');
$fish2Stream = fopen($fish2, 'r'); $fish2Stream = fopen($fish2, 'r');
$fish2Tuple = $backend->setFromStream($fish2Stream, 'parent/mediocre-fish.jpg'); $fish2Tuple = $backend->setFromStream($fish2Stream, 'parent/mediocre-fish.jpg');
fclose($fish2Stream); fclose($fish2Stream);
@ -95,7 +95,7 @@ class AssetStoreTest extends SapphireTest
$backend = $this->getBackend(); $backend = $this->getBackend();
// Put a file in // Put a file in
$fish1 = realpath(__DIR__ . '/../../ORM/testimages/test-image-high-quality.jpg'); $fish1 = realpath(__DIR__ . '/../../ORM/ImageTest/test-image-high-quality.jpg');
$this->assertFileExists($fish1); $this->assertFileExists($fish1);
$fish1Tuple = $backend->setFromLocalFile($fish1, 'directory/lovely-fish.jpg'); $fish1Tuple = $backend->setFromLocalFile($fish1, 'directory/lovely-fish.jpg');
$this->assertEquals( $this->assertEquals(
@ -112,7 +112,7 @@ class AssetStoreTest extends SapphireTest
); );
// Write a different file with same name. Should not detect duplicates since sha are different // Write a different file with same name. Should not detect duplicates since sha are different
$fish2 = realpath(__DIR__ . '/../../ORM/testimages/test-image-low-quality.jpg'); $fish2 = realpath(__DIR__ . '/../../ORM/ImageTest/test-image-low-quality.jpg');
try { try {
$fish2Tuple = $backend->setFromLocalFile( $fish2Tuple = $backend->setFromLocalFile(
$fish2, $fish2,
@ -301,7 +301,7 @@ class AssetStoreTest extends SapphireTest
$backend = $this->getBackend(); $backend = $this->getBackend();
// jpg // jpg
$fish = realpath(__DIR__ . '/../../ORM/testimages/test-image-high-quality.jpg'); $fish = realpath(__DIR__ . '/../../ORM/ImageTest/test-image-high-quality.jpg');
$fishTuple = $backend->setFromLocalFile($fish, 'parent/awesome-fish.jpg'); $fishTuple = $backend->setFromLocalFile($fish, 'parent/awesome-fish.jpg');
$this->assertEquals( $this->assertEquals(
'image/jpeg', 'image/jpeg',
@ -335,7 +335,7 @@ class AssetStoreTest extends SapphireTest
$backend = $this->getBackend(); $backend = $this->getBackend();
// Put a file in // Put a file in
$fish1 = realpath(__DIR__ . '/../../ORM/testimages/test-image-high-quality.jpg'); $fish1 = realpath(__DIR__ . '/../../ORM/ImageTest/test-image-high-quality.jpg');
$this->assertFileExists($fish1); $this->assertFileExists($fish1);
$fish1Tuple = $backend->setFromLocalFile($fish1, 'directory/lovely-fish.jpg'); $fish1Tuple = $backend->setFromLocalFile($fish1, 'directory/lovely-fish.jpg');
$this->assertEquals( $this->assertEquals(
@ -353,7 +353,7 @@ class AssetStoreTest extends SapphireTest
// Write a different file with same name. // Write a different file with same name.
// Since we are using legacy filenames, this should generate a new filename // Since we are using legacy filenames, this should generate a new filename
$fish2 = realpath(__DIR__ . '/../../ORM/testimages/test-image-low-quality.jpg'); $fish2 = realpath(__DIR__ . '/../../ORM/ImageTest/test-image-low-quality.jpg');
try { try {
$backend->setFromLocalFile( $backend->setFromLocalFile(
$fish2, $fish2,
@ -456,7 +456,7 @@ class AssetStoreTest extends SapphireTest
public function testProtect() public function testProtect()
{ {
$backend = $this->getBackend(); $backend = $this->getBackend();
$fish = realpath(__DIR__ . '/../../ORM/testimages/test-image-high-quality.jpg'); $fish = realpath(__DIR__ . '/../../ORM/ImageTest/test-image-high-quality.jpg');
$fishTuple = $backend->setFromLocalFile($fish, 'parent/lovely-fish.jpg'); $fishTuple = $backend->setFromLocalFile($fish, 'parent/lovely-fish.jpg');
$fishVariantTuple = $backend->setFromLocalFile($fish, $fishTuple['Filename'], $fishTuple['Hash'], 'copy'); $fishVariantTuple = $backend->setFromLocalFile($fish, $fishTuple['Filename'], $fishTuple['Hash'], 'copy');

View File

@ -9,10 +9,6 @@ use SilverStripe\Core\Config\Config;
use SilverStripe\Dev\SapphireTest; use SilverStripe\Dev\SapphireTest;
use SilverStripe\ORM\Versioning\Versioned; use SilverStripe\ORM\Versioning\Versioned;
/**
* @package framework
* @subpackage tests
*/
class UploadTest extends SapphireTest { class UploadTest extends SapphireTest {
protected $usesDatabase = true; protected $usesDatabase = true;

View File

@ -3,28 +3,13 @@
namespace SilverStripe\Control\Tests; namespace SilverStripe\Control\Tests;
use SilverStripe\Control\Tests\DirectorTest\TestController; use SilverStripe\Control\Tests\DirectorTest\TestController;
use SilverStripe\ORM\DataModel;
use SilverStripe\Core\Config\Config; use SilverStripe\Core\Config\Config;
use SilverStripe\Core\Injector\Injector; use SilverStripe\Core\Injector\Injector;
use SilverStripe\Dev\SapphireTest; use SilverStripe\Dev\SapphireTest;
use SilverStripe\Dev\TestOnly;
use SilverStripe\Control\Director; use SilverStripe\Control\Director;
use SilverStripe\Control\RequestProcessor; use SilverStripe\Control\RequestProcessor;
use SilverStripe\Control\HTTPRequest;
use SilverStripe\Control\Session;
use SilverStripe\Control\HTTPResponse;
use SilverStripe\Control\RequestFilter;
use SilverStripe\Control\Controller;
/** /**
* @package framework
* @subpackage tests
*
* @todo test Director::alternateBaseFolder() * @todo test Director::alternateBaseFolder()
*/ */
class DirectorTest extends SapphireTest { class DirectorTest extends SapphireTest {
@ -433,7 +418,7 @@ class DirectorTest extends SapphireTest {
} }
/** /**
* @covers SilverStripe\Control\Director::extract_request_headers() * @covers \SilverStripe\Control\Director::extract_request_headers()
*/ */
public function testExtractRequestHeaders() { public function testExtractRequestHeaders() {
$request = array( $request = array(

View File

@ -5,11 +5,6 @@ use SilverStripe\Dev\SapphireTest;
use SilverStripe\Control\Email\Email; use SilverStripe\Control\Email\Email;
use SilverStripe\Control\Email\Mailer; use SilverStripe\Control\Email\Mailer;
/**
* @package framework
* @subpackage tests
*/
class EmailTest extends SapphireTest { class EmailTest extends SapphireTest {
public function testAttachFiles() { public function testAttachFiles() {

View File

@ -5,12 +5,6 @@ use SilverStripe\Dev\SapphireTest;
use SilverStripe\Dev\TestOnly; use SilverStripe\Dev\TestOnly;
use SilverStripe\Control\Email\Mailer; use SilverStripe\Control\Email\Mailer;
/**
* @package framework
* @subpackage tests
*/
class MailerTest extends SapphireTest { class MailerTest extends SapphireTest {
/** /**

View File

@ -6,10 +6,6 @@ use SilverStripe\Dev\SapphireTest;
use SilverStripe\Control\HTTPResponse; use SilverStripe\Control\HTTPResponse;
use SilverStripe\Control\HTTPResponse_Exception; use SilverStripe\Control\HTTPResponse_Exception;
/**
* @package framework
* @subpackage tests
*/
class HTTPResponseTest extends SapphireTest { class HTTPResponseTest extends SapphireTest {
public function testStatusDescriptionStripsNewlines() { public function testStatusDescriptionStripsNewlines() {

View File

@ -11,8 +11,6 @@ use SilverStripe\Control\HTTP;
* Tests the {@link HTTP} class * Tests the {@link HTTP} class
* *
* @skipUpgrade * @skipUpgrade
* @package framework
* @subpackage tests
*/ */
class HTTPTest extends FunctionalTest { class HTTPTest extends FunctionalTest {

View File

@ -5,10 +5,6 @@ namespace SilverStripe\Control\Tests;
use SilverStripe\Dev\SapphireTest; use SilverStripe\Dev\SapphireTest;
use SilverStripe\Control\NullHTTPRequest; use SilverStripe\Control\NullHTTPRequest;
/**
* @package framework
* @subpackage tests
*/
class NullHTTPRequestTest extends SapphireTest { class NullHTTPRequestTest extends SapphireTest {
public function testAllHttpVerbsAreFalse() { public function testAllHttpVerbsAreFalse() {

View File

@ -1,28 +1,23 @@
<?php <?php
use SilverStripe\Control\Controller; namespace SilverStripe\Control\Tests\RSS;
use SilverStripe\Control\Director;
use SilverStripe\Control\RSS\RSSFeed; use SilverStripe\Control\RSS\RSSFeed;
use SilverStripe\Core\Config\Config; use SilverStripe\Core\Config\Config;
use SilverStripe\Dev\SapphireTest; use SilverStripe\Dev\SapphireTest;
use SilverStripe\ORM\ArrayList; use SilverStripe\ORM\ArrayList;
use SilverStripe\View\ViewableData;
use SilverStripe\View\Parsers\ShortcodeParser; use SilverStripe\View\Parsers\ShortcodeParser;
/**
* @package framework
* @subpackage tests
*/
class RSSFeedTest extends SapphireTest { class RSSFeedTest extends SapphireTest {
protected static $original_host; protected static $original_host;
public function testRSSFeed() { public function testRSSFeed() {
$list = new ArrayList(); $list = new ArrayList();
$list->push(new RSSFeedTest_ItemA()); $list->push(new RSSFeedTest\ItemA());
$list->push(new RSSFeedTest_ItemB()); $list->push(new RSSFeedTest\ItemB());
$list->push(new RSSFeedTest_ItemC()); $list->push(new RSSFeedTest\ItemC());
$rssFeed = new RSSFeed($list, "http://www.example.com", "Test RSS Feed", "Test RSS Feed Description"); $rssFeed = new RSSFeed($list, "http://www.example.com", "Test RSS Feed", "Test RSS Feed Description");
$content = $rssFeed->outputToBrowser(); $content = $rssFeed->outputToBrowser();
@ -63,7 +58,7 @@ class RSSFeedTest extends SapphireTest {
public function testRSSFeedWithShortcode() { public function testRSSFeedWithShortcode() {
$list = new ArrayList(); $list = new ArrayList();
$list->push(new RSSFeedTest_ItemD()); $list->push(new RSSFeedTest\ItemD());
$rssFeed = new RSSFeed($list, "http://www.example.com", "Test RSS Feed", "Test RSS Feed Description"); $rssFeed = new RSSFeed($list, "http://www.example.com", "Test RSS Feed", "Test RSS Feed Description");
$content = $rssFeed->outputToBrowser(); $content = $rssFeed->outputToBrowser();
@ -92,8 +87,10 @@ class RSSFeedTest extends SapphireTest {
public function setUp() { public function setUp() {
parent::setUp(); parent::setUp();
Config::inst()->update('SilverStripe\\Control\\Director', 'alternate_base_url', '/'); Config::inst()->update(Director::class, 'alternate_base_url', '/');
if(!self::$original_host) self::$original_host = $_SERVER['HTTP_HOST']; if(!self::$original_host) {
self::$original_host = $_SERVER['HTTP_HOST'];
}
$_SERVER['HTTP_HOST'] = 'www.example.org'; $_SERVER['HTTP_HOST'] = 'www.example.org';
ShortcodeParser::get('default')->register('test_shortcode', function() { ShortcodeParser::get('default')->register('test_shortcode', function() {
@ -103,91 +100,6 @@ class RSSFeedTest extends SapphireTest {
public function tearDown() { public function tearDown() {
parent::tearDown(); parent::tearDown();
Config::inst()->update('SilverStripe\\Control\\Director', 'alternate_base_url', null);
$_SERVER['HTTP_HOST'] = self::$original_host; $_SERVER['HTTP_HOST'] = self::$original_host;
} }
} }
class RSSFeedTest_ItemA extends ViewableData {
// RSS-feed items must have $casting/$db information.
private static $casting = array(
'Title' => 'Varchar',
'Content' => 'Text',
'AltContent' => 'Text',
);
public function getTitle() {
return "ItemA";
}
public function getContent() {
return "ItemA Content";
}
public function getAltContent() {
return "ItemA AltContent";
}
public function Link($action = null) {
return Controller::join_links("item-a/", $action);
}
}
class RSSFeedTest_ItemB extends ViewableData {
// ItemB tests without $casting
public function Title() {
return "ItemB";
}
public function AbsoluteLink() {
return "http://www.example.com/item-b.html";
}
public function Content() {
return "ItemB Content";
}
public function AltContent() {
return "ItemB AltContent";
}
}
class RSSFeedTest_ItemC extends ViewableData {
// ItemC tests fields - Title has casting, Content doesn't.
private static $casting = array(
'Title' => 'Varchar',
'AltContent' => 'Text',
);
public $Title = "ItemC";
public $Content = "ItemC Content";
public $AltContent = "ItemC AltContent";
public function Link() {
return "item-c.html";
}
public function AbsoluteLink() {
return "http://www.example.com/item-c.html";
}
}
class RSSFeedTest_ItemD extends ViewableData {
// ItemD test fields - all fields use casting but Content & AltContent cast as HTMLText
private static $casting = array(
'Title' => 'Varchar',
'Content' => 'HTMLText', // Supports shortcodes
);
public $Title = 'ItemD';
public $Content = '<p>ItemD Content [test_shortcode]</p>';
public function Link() {
return 'item-d.html';
}
public function AbsoluteLink() {
return 'http://www.example.org/item-d.html';
}
}

View File

@ -0,0 +1,36 @@
<?php
namespace SilverStripe\Control\Tests\RSS\RSSFeedTest;
use SilverStripe\Control\Controller;
use SilverStripe\View\ViewableData;
class ItemA extends ViewableData
{
// RSS-feed items must have $casting/$db information.
private static $casting = array(
'Title' => 'Varchar',
'Content' => 'Text',
'AltContent' => 'Text',
);
public function getTitle()
{
return "ItemA";
}
public function getContent()
{
return "ItemA Content";
}
public function getAltContent()
{
return "ItemA AltContent";
}
public function Link($action = null)
{
return Controller::join_links("item-a/", $action);
}
}

View File

@ -0,0 +1,30 @@
<?php
namespace SilverStripe\Control\Tests\RSS\RSSFeedTest;
use SilverStripe\View\ViewableData;
class ItemB extends ViewableData
{
// ItemB tests without $casting
public function Title()
{
return "ItemB";
}
public function AbsoluteLink()
{
return "http://www.example.com/item-b.html";
}
public function Content()
{
return "ItemB Content";
}
public function AltContent()
{
return "ItemB AltContent";
}
}

View File

@ -0,0 +1,28 @@
<?php
namespace SilverStripe\Control\Tests\RSS\RSSFeedTest;
use SilverStripe\View\ViewableData;
class ItemC extends ViewableData
{
// ItemC tests fields - Title has casting, Content doesn't.
private static $casting = array(
'Title' => 'Varchar',
'AltContent' => 'Text',
);
public $Title = "ItemC";
public $Content = "ItemC Content";
public $AltContent = "ItemC AltContent";
public function Link()
{
return "item-c.html";
}
public function AbsoluteLink()
{
return "http://www.example.com/item-c.html";
}
}

View File

@ -0,0 +1,27 @@
<?php
namespace SilverStripe\Control\Tests\RSS\RSSFeedTest;
use SilverStripe\View\ViewableData;
class ItemD extends ViewableData
{
// ItemD test fields - all fields use casting but Content & AltContent cast as HTMLText
private static $casting = array(
'Title' => 'Varchar',
'Content' => 'HTMLText', // Supports shortcodes
);
public $Title = 'ItemD';
public $Content = '<p>ItemD Content [test_shortcode]</p>';
public function Link()
{
return 'item-d.html';
}
public function AbsoluteLink()
{
return 'http://www.example.org/item-d.html';
}
}

View File

@ -2,24 +2,14 @@
namespace SilverStripe\Control\Tests; namespace SilverStripe\Control\Tests;
use SilverStripe\Core\Config\Config; use SilverStripe\Core\Config\Config;
use SilverStripe\Core\Injector\Injector; use SilverStripe\Core\Injector\Injector;
use SilverStripe\Dev\SapphireTest; use SilverStripe\Dev\SapphireTest;
use SilverStripe\Control\Session; use SilverStripe\Control\Session;
/** /**
* Tests to cover the {@link Session} class * Tests to cover the {@link Session} class
*
* @package framework
* @subpackage tests
*/ */
class SessionTest extends SapphireTest { class SessionTest extends SapphireTest {
public function testGetSetBasics() { public function testGetSetBasics() {

View File

@ -5,10 +5,6 @@ namespace SilverStripe\Core\Tests\ClassInfoTest;
use SilverStripe\Dev\TestOnly; use SilverStripe\Dev\TestOnly;
use SilverStripe\ORM\DataObject; use SilverStripe\ORM\DataObject;
/**
* @package framework
* @subpackage tests
*/
class BaseClass extends DataObject implements TestOnly class BaseClass extends DataObject implements TestOnly
{ {
private static $table_name = 'ClassInfoTest_BaseClass'; private static $table_name = 'ClassInfoTest_BaseClass';

View File

@ -5,10 +5,6 @@ namespace SilverStripe\Core\Tests\ClassInfoTest;
use SilverStripe\Dev\TestOnly; use SilverStripe\Dev\TestOnly;
use SilverStripe\ORM\DataObject; use SilverStripe\ORM\DataObject;
/**
* @package framework
* @subpackage tests
*/
class BaseDataClass extends DataObject implements TestOnly class BaseDataClass extends DataObject implements TestOnly
{ {
private static $table_name = 'ClassInfoTest_BaseDataClass'; private static $table_name = 'ClassInfoTest_BaseDataClass';

View File

@ -2,10 +2,6 @@
namespace SilverStripe\Core\Tests\ClassInfoTest; namespace SilverStripe\Core\Tests\ClassInfoTest;
/**
* @package framework
* @subpackage tests
*/
class HasFields extends NoFields class HasFields extends NoFields
{ {
private static $table_name = 'ClassInfoTest_HasFields'; private static $table_name = 'ClassInfoTest_HasFields';

View File

@ -2,10 +2,6 @@
namespace SilverStripe\Core\Tests\ClassInfoTest; namespace SilverStripe\Core\Tests\ClassInfoTest;
/**
* @package framework
* @subpackage tests
*/
class NoFields extends BaseDataClass class NoFields extends BaseDataClass
{ {
private static $table_name = 'ClassInfoTest_NoFields'; private static $table_name = 'ClassInfoTest_NoFields';

View File

@ -2,10 +2,6 @@
namespace SilverStripe\Core\Tests\ClassInfoTest; namespace SilverStripe\Core\Tests\ClassInfoTest;
/**
* @package framework
* @subpackage tests
*/
class WithRelation extends NoFields class WithRelation extends NoFields
{ {
private static $table_name = 'ClassInfoTest_WithRelation'; private static $table_name = 'ClassInfoTest_WithRelation';

View File

@ -8,9 +8,6 @@ use SilverStripe\Control\Director;
/** /**
* Tests for the core of SilverStripe, such as how the temporary * Tests for the core of SilverStripe, such as how the temporary
* directory is determined throughout the framework. * directory is determined throughout the framework.
*
* @package framework
* @subpackage tests
*/ */
class CoreTest extends SapphireTest { class CoreTest extends SapphireTest {

View File

@ -6,9 +6,6 @@ use SilverStripe\Dev\SapphireTest;
/** /**
* Tests for the {@link ClassManifest} class. * Tests for the {@link ClassManifest} class.
*
* @package framework
* @subpackage tests
*/ */
class ClassLoaderTest extends SapphireTest { class ClassLoaderTest extends SapphireTest {

View File

@ -5,9 +5,6 @@ use SilverStripe\Dev\SapphireTest;
/** /**
* Tests for the {@link ClassManifest} class. * Tests for the {@link ClassManifest} class.
*
* @package framework
* @subpackage tests
*/ */
class ClassManifestTest extends SapphireTest { class ClassManifestTest extends SapphireTest {

View File

@ -5,9 +5,6 @@ use SilverStripe\Dev\SapphireTest;
/** /**
* Tests for the {@link ManifestFileFinder} class. * Tests for the {@link ManifestFileFinder} class.
*
* @package framework
* @subpackage tests
*/ */
class ManifestFileFinderTest extends SapphireTest { class ManifestFileFinderTest extends SapphireTest {

View File

@ -8,9 +8,6 @@ use SilverStripe\Dev\SapphireTest;
/** /**
* Tests for the {@link ClassManifest} class. * Tests for the {@link ClassManifest} class.
*
* @package framework
* @subpackage tests
*/ */
class NamespacedClassManifestTest extends SapphireTest { class NamespacedClassManifestTest extends SapphireTest {

View File

@ -4,12 +4,8 @@ use SilverStripe\View\ThemeResourceLoader;
use SilverStripe\View\ThemeManifest; use SilverStripe\View\ThemeManifest;
use SilverStripe\Dev\SapphireTest; use SilverStripe\Dev\SapphireTest;
/** /**
* Tests for the {@link TemplateLoader} class. * Tests for the {@link TemplateLoader} class.
*
* @package framework
* @subpackage tests
*/ */
class ThemeResourceLoaderTest extends SapphireTest { class ThemeResourceLoaderTest extends SapphireTest {

View File

@ -3,10 +3,6 @@
use SilverStripe\Core\Manifest\ClassManifest; use SilverStripe\Core\Manifest\ClassManifest;
use SilverStripe\Dev\SapphireTest; use SilverStripe\Dev\SapphireTest;
/**
* @package framework
* @subpackage tests
*/
class TokenisedRegularExpressionTest extends SapphireTest { class TokenisedRegularExpressionTest extends SapphireTest {
public function getTokens() { public function getTokens() {
return token_get_all(<<<PHP return token_get_all(<<<PHP

View File

@ -6,10 +6,6 @@ use SilverStripe\Dev\BulkLoader_Result;
use SilverStripe\Dev\SapphireTest; use SilverStripe\Dev\SapphireTest;
use SilverStripe\Dev\Tests\BulkLoaderResultTest\Player; use SilverStripe\Dev\Tests\BulkLoaderResultTest\Player;
/**
* @package framework
* @subpackage tests
*/
class BulkLoaderResultTest extends SapphireTest class BulkLoaderResultTest extends SapphireTest
{ {
protected $extraDataObjects = array(Player::class); protected $extraDataObjects = array(Player::class);

View File

@ -2,19 +2,14 @@
namespace SilverStripe\Dev\Tests; namespace SilverStripe\Dev\Tests;
use SilverStripe\Core\Config\Config;
use SilverStripe\Dev\DevelopmentAdmin; use SilverStripe\Dev\DevelopmentAdmin;
use SilverStripe\Dev\FunctionalTest; use SilverStripe\Dev\FunctionalTest;
use SilverStripe\Control\Director; use SilverStripe\Control\Director;
use SilverStripe\Control\Controller;
use Exception; use Exception;
use SilverStripe\Dev\Tests\DevAdminControllerTest\Controller1; use SilverStripe\Dev\Tests\DevAdminControllerTest\Controller1;
/** /**
* Note: the running of this test is handled by the thing it's testing (DevelopmentAdmin controller). * Note: the running of this test is handled by the thing it's testing (DevelopmentAdmin controller).
*
* @package framework
* @package tests
*/ */
class DevAdminControllerTest extends FunctionalTest { class DevAdminControllerTest extends FunctionalTest {

View File

@ -239,7 +239,7 @@ class CheckboxSetFieldTest extends SapphireTest {
// Invalid value should fail // Invalid value should fail
$validator = new RequiredFields(); $validator = new RequiredFields();
$fakeID = CheckboxSetFieldTest_Tag::get()->max('ID') + 1; $fakeID = CheckboxSetFieldTest\Tag::get()->max('ID') + 1;
$field->setValue(array($fakeID)); $field->setValue(array($fakeID));
$this->assertFalse( $this->assertFalse(
$field->validate($validator), $field->validate($validator),

View File

@ -3,19 +3,10 @@
namespace SilverStripe\Forms\Tests; namespace SilverStripe\Forms\Tests;
use SilverStripe\Assets\Storage\AssetStore; use SilverStripe\Assets\Storage\AssetStore;
use SilverStripe\Assets\Storage\DBFile;
use SilverStripe\Control\Director; use SilverStripe\Control\Director;
use SilverStripe\ORM\DataObject;
use SilverStripe\Core\Config\Config;
use SilverStripe\Dev\SapphireTest; use SilverStripe\Dev\SapphireTest;
use SilverStripe\Dev\TestOnly;
use SilverStripe\Assets\Tests\Storage\AssetStoreTest\TestAssetStore; use SilverStripe\Assets\Tests\Storage\AssetStoreTest\TestAssetStore;
/**
* Description of DBFileTest
*
* @author dmooyman
*/
class DBFileTest extends SapphireTest { class DBFileTest extends SapphireTest {
protected $extraDataObjects = array( protected $extraDataObjects = array(
@ -45,7 +36,7 @@ class DBFileTest extends SapphireTest {
$obj = new DBFileTest\TestObject(); $obj = new DBFileTest\TestObject();
// Test image tag // Test image tag
$fish = realpath(__DIR__ .'/../ORM/testimages/test-image-high-quality.jpg'); $fish = realpath(__DIR__ .'/../ORM/ImageTest/test-image-high-quality.jpg');
$this->assertFileExists($fish); $this->assertFileExists($fish);
$obj->MyFile->setFromLocalFile($fish, 'awesome-fish.jpg'); $obj->MyFile->setFromLocalFile($fish, 'awesome-fish.jpg');
$this->assertEquals( $this->assertEquals(
@ -65,7 +56,7 @@ class DBFileTest extends SapphireTest {
$obj = new DBFileTest\ImageOnly(); $obj = new DBFileTest\ImageOnly();
// Test from image // Test from image
$fish = realpath(__DIR__ .'/../ORM/testimages/test-image-high-quality.jpg'); $fish = realpath(__DIR__ .'/../ORM/ImageTest/test-image-high-quality.jpg');
$this->assertFileExists($fish); $this->assertFileExists($fish);
$obj->MyFile->setFromLocalFile($fish, 'awesome-fish.jpg'); $obj->MyFile->setFromLocalFile($fish, 'awesome-fish.jpg');
@ -78,7 +69,7 @@ class DBFileTest extends SapphireTest {
$obj = new DBFileTest\TestObject(); $obj = new DBFileTest\TestObject();
// Test from image // Test from image
$fish = realpath(__DIR__ .'/../ORM/testimages/test-image-high-quality.jpg'); $fish = realpath(__DIR__ .'/../ORM/ImageTest/test-image-high-quality.jpg');
$this->assertFileExists($fish); $this->assertFileExists($fish);
$obj->MyFile->setFromLocalFile($fish, 'private/awesome-fish.jpg', null, null, array( $obj->MyFile->setFromLocalFile($fish, 'private/awesome-fish.jpg', null, null, array(
'visibility' => AssetStore::VISIBILITY_PROTECTED 'visibility' => AssetStore::VISIBILITY_PROTECTED

View File

@ -5,10 +5,6 @@ namespace SilverStripe\Forms\Tests\DatetimeFieldTest;
use SilverStripe\Dev\TestOnly; use SilverStripe\Dev\TestOnly;
use SilverStripe\ORM\DataObject; use SilverStripe\ORM\DataObject;
/**
* @package framework
* @subpackage tests
*/
class Model extends DataObject implements TestOnly class Model extends DataObject implements TestOnly
{ {
private static $table_name = 'DatetimeFieldTest_Model'; private static $table_name = 'DatetimeFieldTest_Model';

View File

@ -5,10 +5,6 @@ namespace SilverStripe\Forms\Tests\FormFieldTest;
use SilverStripe\Core\Extension; use SilverStripe\Core\Extension;
use SilverStripe\Dev\TestOnly; use SilverStripe\Dev\TestOnly;
/**
* @package framework
* @subpackage tests
*/
class TestExtension extends Extension implements TestOnly class TestExtension extends Extension implements TestOnly
{ {

View File

@ -8,7 +8,6 @@ use SilverStripe\Forms\Tests\FormTest\ControllerWithStrictPostCheck;
use SilverStripe\Forms\Tests\FormTest\Player; use SilverStripe\Forms\Tests\FormTest\Player;
use SilverStripe\Forms\Tests\FormTest\Team; use SilverStripe\Forms\Tests\FormTest\Team;
use SilverStripe\ORM\DataModel; use SilverStripe\ORM\DataModel;
use SilverStripe\ORM\Tests\DataObjectTest\Team;
use SilverStripe\Security\SecurityToken; use SilverStripe\Security\SecurityToken;
use SilverStripe\Security\RandomGenerator; use SilverStripe\Security\RandomGenerator;
use SilverStripe\Dev\CSSContentParser; use SilverStripe\Dev\CSSContentParser;

View File

@ -6,10 +6,6 @@ use SilverStripe\Core\Extension;
use SilverStripe\Dev\TestOnly; use SilverStripe\Dev\TestOnly;
use SilverStripe\Forms\Form; use SilverStripe\Forms\Form;
/**
* @package framework
* @subpackage tests
*/
class DummyMediaFormFieldExtension extends Extension implements TestOnly class DummyMediaFormFieldExtension extends Extension implements TestOnly
{ {
public static $fields = null; public static $fields = null;

View File

@ -89,8 +89,8 @@ class ChangeSetTest extends SapphireTest {
$cs->addObject($this->objFromFixture(ChangeSetTest\EndObjectChild::class, 'endchild1')); $cs->addObject($this->objFromFixture(ChangeSetTest\EndObjectChild::class, 'endchild1'));
$this->assertChangeSetLooksLike($cs, [ $this->assertChangeSetLooksLike($cs, [
'ChangeSetTest_End.end1' => ChangeSetItem::EXPLICITLY, ChangeSetTest\EndObject::class.'.end1' => ChangeSetItem::EXPLICITLY,
'ChangeSetTest_EndChild.endchild1' => ChangeSetItem::EXPLICITLY ChangeSetTest\EndObjectChild::class.'.endchild1' => ChangeSetItem::EXPLICITLY
]); ]);
} }
@ -105,12 +105,12 @@ class ChangeSetTest extends SapphireTest {
$cs->sync(); $cs->sync();
$this->assertChangeSetLooksLike($cs, [ $this->assertChangeSetLooksLike($cs, [
'ChangeSetTest_Base.base' => ChangeSetItem::EXPLICITLY ChangeSetTest\BaseObject::class.'.base' => ChangeSetItem::EXPLICITLY
]); ]);
$cs->sync(); $cs->sync();
$this->assertChangeSetLooksLike($cs, [ $this->assertChangeSetLooksLike($cs, [
'ChangeSetTest_Base.base' => ChangeSetItem::EXPLICITLY ChangeSetTest\BaseObject::class.'.base' => ChangeSetItem::EXPLICITLY
]); ]);
} }
@ -126,7 +126,7 @@ class ChangeSetTest extends SapphireTest {
$cs->sync(); $cs->sync();
$this->assertChangeSetLooksLike($cs, [ $this->assertChangeSetLooksLike($cs, [
'ChangeSetTest_Base.base' => ChangeSetItem::EXPLICITLY ChangeSetTest\BaseObject::class.'.base' => ChangeSetItem::EXPLICITLY
]); ]);
$end = $this->objFromFixture(ChangeSetTest\EndObject::class, 'end1'); $end = $this->objFromFixture(ChangeSetTest\EndObject::class, 'end1');
@ -136,8 +136,8 @@ class ChangeSetTest extends SapphireTest {
$cs->sync(); $cs->sync();
$this->assertChangeSetLooksLike($cs, [ $this->assertChangeSetLooksLike($cs, [
'ChangeSetTest_Base.base' => ChangeSetItem::EXPLICITLY, ChangeSetTest\BaseObject::class.'.base' => ChangeSetItem::EXPLICITLY,
'ChangeSetTest_End.end1' => ChangeSetItem::IMPLICITLY ChangeSetTest\EndObject::class.'.end1' => ChangeSetItem::IMPLICITLY
]); ]);
$baseItem = ChangeSetItem::get_for_object($base)->first(); $baseItem = ChangeSetItem::get_for_object($base)->first();
@ -172,7 +172,7 @@ class ChangeSetTest extends SapphireTest {
$cs->sync(); $cs->sync();
$this->assertChangeSetLooksLike($cs, [ $this->assertChangeSetLooksLike($cs, [
'ChangeSetTest_Base.base' => ChangeSetItem::EXPLICITLY ChangeSetTest\BaseObject::class.'.base' => ChangeSetItem::EXPLICITLY
]); ]);
$this->assertTrue($cs->isSynced()); $this->assertTrue($cs->isSynced());
@ -184,8 +184,8 @@ class ChangeSetTest extends SapphireTest {
$cs->sync(); $cs->sync();
$this->assertChangeSetLooksLike($cs, [ $this->assertChangeSetLooksLike($cs, [
'ChangeSetTest_Base.base' => ChangeSetItem::EXPLICITLY, ChangeSetTest\BaseObject::class.'.base' => ChangeSetItem::EXPLICITLY,
'ChangeSetTest_End.end1' => ChangeSetItem::IMPLICITLY ChangeSetTest\EndObject::class.'.end1' => ChangeSetItem::IMPLICITLY
]); ]);
$this->assertTrue($cs->isSynced()); $this->assertTrue($cs->isSynced());
} }
@ -396,7 +396,7 @@ class ChangeSetTest extends SapphireTest {
// Assert changeset only contains root object // Assert changeset only contains root object
$this->assertChangeSetLooksLike($changeset, [ $this->assertChangeSetLooksLike($changeset, [
'ChangeSetTest_Base.base' => ChangeSetItem::EXPLICITLY ChangeSetTest\BaseObject::class.'.base' => ChangeSetItem::EXPLICITLY
]); ]);
$changeset->publish(); $changeset->publish();

View File

@ -2,24 +2,21 @@
namespace SilverStripe\ORM\Tests; namespace SilverStripe\ORM\Tests;
use SilverStripe\ORM\DataObject;
use SilverStripe\ORM\Tests\ComponentSetTest\Player;
use SilverStripe\Dev\SapphireTest; use SilverStripe\Dev\SapphireTest;
use SilverStripe\Dev\TestOnly;
class ComponentSetTest extends SapphireTest { class ComponentSetTest extends SapphireTest {
protected static $fixture_file = 'ComponentSetTest.yml'; protected static $fixture_file = 'ComponentSetTest.yml';
protected $extraDataObjects = array( protected $extraDataObjects = array(
Player::class, ComponentSetTest\Player::class,
ComponentSetTest\Team::class, ComponentSetTest\Team::class,
); );
public function testSetByIDListManyMany() { public function testSetByIDListManyMany() {
$team1 = $this->objFromFixture('ComponentSetTest_Team', 'team1'); $team1 = $this->objFromFixture(ComponentSetTest\Team::class, 'team1');
$player1_team1 = $this->objFromFixture('ComponentSetTest_Player', 'player1_team1'); $player1_team1 = $this->objFromFixture(ComponentSetTest\Player::class, 'player1_team1');
$player2 = $this->objFromFixture('ComponentSetTest_Player', 'player2'); $player2 = $this->objFromFixture(ComponentSetTest\Player::class, 'player2');
$team1->Players()->setByIdList(array( $team1->Players()->setByIdList(array(
$player1_team1->ID, $player1_team1->ID,

View File

@ -3,7 +3,7 @@ SilverStripe\ORM\Tests\ComponentSetTest\Player:
Email: player1_team1@test.com Email: player1_team1@test.com
player2: player2:
Email: player2@test.com Email: player2@test.com
ComponentSetTest_Team: SilverStripe\ORM\Tests\ComponentSetTest\Team:
team1: team1:
Title: team1 Title: team1
Players: =>SilverStripe\ORM\Tests\ComponentSetTest\Player.player1_team1 Players: =>SilverStripe\ORM\Tests\ComponentSetTest\Player.player1_team1

View File

@ -7,7 +7,9 @@ use SilverStripe\ORM\DataObject;
class CustomDefault extends DataObject implements TestOnly class CustomDefault extends DataObject implements TestOnly
{ {
private static $default_classname = 'DBClassNameTest_CustomDefaultSubclass'; private static $table_name = 'DBClassNameTest_CustomDefault';
private static $default_classname = CustomDefaultSubclass::class;
private static $db = array( private static $db = array(
'Title' => 'Varchar' 'Title' => 'Varchar'

View File

@ -18,7 +18,7 @@ use Exception;
*/ */
class DBMoneyTest extends SapphireTest { class DBMoneyTest extends SapphireTest {
protected static $fixture_file = 'MoneyTest.yml'; protected static $fixture_file = 'DBMoneyTest.yml';
protected $extraDataObjects = array( protected $extraDataObjects = array(
DBMoneyTest\TestObject::class, DBMoneyTest\TestObject::class,

View File

@ -1,4 +1,4 @@
SilverStripe\ORM\Tests\DBMoneyTest\DataObject: SilverStripe\ORM\Tests\DBMoneyTest\TestObject:
test1: test1:
MyMoneyCurrency: EUR MyMoneyCurrency: EUR
MyMoneyAmount: 1.23 MyMoneyAmount: 1.23
@ -8,7 +8,7 @@ SilverStripe\ORM\Tests\DBMoneyTest\DataObject:
test3: test3:
MyMoneyCurrency: NZD MyMoneyCurrency: NZD
MyMoneyAmount: 7.66 MyMoneyAmount: 7.66
SilverStripe\ORM\Tests\DBMoneyTest\SubClass: SilverStripe\ORM\Tests\DBMoneyTest\TestObjectSubclass:
test2: test2:
MyOtherMoneyCurrency: GBP MyOtherMoneyCurrency: GBP
MyOtherMoneyAmount: 2.46 MyOtherMoneyAmount: 2.46

View File

@ -23,7 +23,7 @@ class DBStringTest extends SapphireTest {
public function testDefault() { public function testDefault() {
/** @var DBString $dbField */ /** @var DBString $dbField */
$dbField = Object::create_from_string( $dbField = Object::create_from_string(
"StringFieldTest_MyStringField(['default' => 'Here is my default text'])", DBStringTest\MyStringField::class."(['default' => 'Here is my default text'])",
'Myfield' 'Myfield'
); );
$this->assertEquals( $this->assertEquals(

View File

@ -2,15 +2,13 @@
namespace SilverStripe\ORM\Tests; namespace SilverStripe\ORM\Tests;
use SilverStripe\Assets\Folder;
use SilverStripe\Assets\Image; use SilverStripe\Assets\Image;
use SilverStripe\ORM\Versioning\Versioned; use SilverStripe\ORM\Versioning\Versioned;
use SilverStripe\ORM\Versioning\DataDifferencer; use SilverStripe\ORM\Versioning\DataDifferencer;
use SilverStripe\ORM\DataObject;
use SilverStripe\Assets\File; use SilverStripe\Assets\File;
use SilverStripe\Assets\Filesystem; use SilverStripe\Assets\Filesystem;
use SilverStripe\Dev\SapphireTest; use SilverStripe\Dev\SapphireTest;
use SilverStripe\Dev\TestOnly;
use SilverStripe\Forms\ListboxField;
use SilverStripe\Assets\Tests\Storage\AssetStoreTest\TestAssetStore; use SilverStripe\Assets\Tests\Storage\AssetStoreTest\TestAssetStore;
class DataDifferencerTest extends SapphireTest { class DataDifferencerTest extends SapphireTest {
@ -33,7 +31,7 @@ class DataDifferencerTest extends SapphireTest {
// Create a test files for each of the fixture references // Create a test files for each of the fixture references
$files = File::get()->exclude('ClassName', Folder::class); $files = File::get()->exclude('ClassName', Folder::class);
foreach($files as $file) { foreach($files as $file) {
$fromPath = FRAMEWORK_PATH . '/tests/model/testimages/' . $file->Name; $fromPath = __DIR__ . '/ImageTest/' . $file->Name;
$destPath = TestAssetStore::getLocalPath($file); // Only correct for test asset store $destPath = TestAssetStore::getLocalPath($file); // Only correct for test asset store
Filesystem::makeFolder(dirname($destPath)); Filesystem::makeFolder(dirname($destPath));
copy($fromPath, $destPath); copy($fromPath, $destPath);
@ -62,7 +60,7 @@ class DataDifferencerTest extends SapphireTest {
} }
public function testHasOnes() { public function testHasOnes() {
/** @var \SilverStripe\ORM\Tests\DataDifferencerTest\DataDifferencerTest_Object $obj1 */ /** @var DataDifferencerTest\TestObject $obj1 */
$obj1 = $this->objFromFixture(DataDifferencerTest\TestObject::class, 'obj1'); $obj1 = $this->objFromFixture(DataDifferencerTest\TestObject::class, 'obj1');
$image1 = $this->objFromFixture(Image::class, 'image1'); $image1 = $this->objFromFixture(Image::class, 'image1');
$image2 = $this->objFromFixture(Image::class, 'image2'); $image2 = $this->objFromFixture(Image::class, 'image2');
@ -75,9 +73,9 @@ class DataDifferencerTest extends SapphireTest {
$obj1->write(); $obj1->write();
$afterVersion = $obj1->Version; $afterVersion = $obj1->Version;
$this->assertNotEquals($beforeVersion, $afterVersion); $this->assertNotEquals($beforeVersion, $afterVersion);
/** @var \SilverStripe\ORM\Tests\DataDifferencerTest\DataDifferencerTest_Object $obj1v1 */ /** @var DataDifferencerTest\TestObject $obj1v1 */
$obj1v1 = Versioned::get_version(DataDifferencerTest\TestObject::class, $obj1->ID, $beforeVersion); $obj1v1 = Versioned::get_version(DataDifferencerTest\TestObject::class, $obj1->ID, $beforeVersion);
/** @var \SilverStripe\ORM\Tests\DataDifferencerTest\DataDifferencerTest_Object $obj1v2 */ /** @var DataDifferencerTest\TestObject $obj1v2 */
$obj1v2 = Versioned::get_version(DataDifferencerTest\TestObject::class, $obj1->ID, $afterVersion); $obj1v2 = Versioned::get_version(DataDifferencerTest\TestObject::class, $obj1->ID, $afterVersion);
$differ = new DataDifferencer($obj1v1, $obj1v2); $differ = new DataDifferencer($obj1v1, $obj1v2);
$obj1Diff = $differ->diffedData(); $obj1Diff = $differ->diffedData();

View File

@ -12,7 +12,7 @@ SilverStripe\ORM\Tests\DataDifferencerTest\HasOneRelationObject:
Title: obj1 Title: obj1
relobj2: relobj2:
Title: obj2 Title: obj2
SilverStripe\ORM\Tests\DataDifferencerTest\Object: SilverStripe\ORM\Tests\DataDifferencerTest\TestObject:
obj1: obj1:
Choices: a,b Choices: a,b
Image: =>SilverStripe\Assets\Image.image1 Image: =>SilverStripe\Assets\Image.image1

View File

@ -15,7 +15,6 @@ use SilverStripe\ORM\Versioning\Versioned;
*/ */
class TestObject extends DataObject implements TestOnly class TestObject extends DataObject implements TestOnly
{ {
private static $table_name = 'DataDifferencerTest_Object'; private static $table_name = 'DataDifferencerTest_Object';
private static $extensions = array( private static $extensions = array(

View File

@ -92,7 +92,9 @@ class DataExtensionTest extends SapphireTest {
*/ */
public function testAddExtensionLoadsStatics() { public function testAddExtensionLoadsStatics() {
// Object::add_extension() will load DOD statics directly, so let's try adding a extension on the fly // Object::add_extension() will load DOD statics directly, so let's try adding a extension on the fly
DataExtensionTest\Player::add_extension('DataExtensionTest_PlayerExtension'); DataExtensionTest\Player::add_extension(
DataExtensionTest\PlayerExtension::class
);
// Now that we've just added the extension, we need to rebuild the database // Now that we've just added the extension, we need to rebuild the database
$this->resetDBSchema(true); $this->resetDBSchema(true);
@ -177,10 +179,10 @@ class DataExtensionTest extends SapphireTest {
} }
public function testExtensionAllMethodNamesHasOwner() { public function testExtensionAllMethodNamesHasOwner() {
/** @var \SilverStripe\ORM\Tests\DataExtensionTest\DataExtensionTest_MyObject $do */ /** @var DataExtensionTest\MyObject $do */
$do = DataExtensionTest\MyObject::create(); $do = DataExtensionTest\MyObject::create();
$this->assertTrue($do->hasMethod('getTestValueWithDataExtensionTest_MyObject')); $this->assertTrue($do->hasMethod('getTestValueWith_MyObject'));
} }
public function testPageFieldGeneration() { public function testPageFieldGeneration() {

View File

@ -2,6 +2,7 @@
namespace SilverStripe\ORM\Tests\DataExtensionTest; namespace SilverStripe\ORM\Tests\DataExtensionTest;
use SilverStripe\Core\ClassInfo;
use SilverStripe\Dev\TestOnly; use SilverStripe\Dev\TestOnly;
use SilverStripe\ORM\DataExtension; use SilverStripe\ORM\DataExtension;
@ -10,7 +11,7 @@ class AllMethodNames extends DataExtension implements TestOnly
public function allMethodNames() public function allMethodNames()
{ {
return array( return array(
strtolower('getTestValueWith' . $this->owner->ClassName) strtolower('getTestValueWith_' . ClassInfo::shortName($this->owner))
); );
} }
} }

View File

@ -21,9 +21,12 @@ class DataListTest extends SapphireTest {
// Borrow the model from DataObjectTest // Borrow the model from DataObjectTest
protected static $fixture_file = 'DataObjectTest.yml'; protected static $fixture_file = 'DataObjectTest.yml';
public function setUpOnce() { protected function getExtraDataObjects()
$this->extraDataObjects = DataObjectTest::$extra_data_objects; {
parent::setUpOnce(); return array_merge(
DataObjectTest::$extra_data_objects,
ManyManyListTest::$extra_data_objects
);
} }
public function testFilterDataObjectByCreatedDate() { public function testFilterDataObjectByCreatedDate() {

View File

@ -81,18 +81,18 @@ class DataObjectDuplicationTest extends SapphireTest {
$one->twos()->add($two); $one->twos()->add($two);
$one->threes()->add($three); $one->threes()->add($three);
$one = DataObject::get_by_id("DataObjectDuplicateTestClass1", $one->ID); $one = DataObject::get_by_id(DataObjectDuplicationTest\Class1::class, $one->ID);
$two = DataObject::get_by_id("DataObjectDuplicateTestClass2", $two->ID); $two = DataObject::get_by_id(DataObjectDuplicationTest\Class2::class, $two->ID);
$three = DataObject::get_by_id("DataObjectDuplicateTestClass3", $three->ID); $three = DataObject::get_by_id(DataObjectDuplicationTest\Class3::class, $three->ID);
//test duplication //test duplication
$oneCopy = $one->duplicate(); $oneCopy = $one->duplicate();
$twoCopy = $two->duplicate(); $twoCopy = $two->duplicate();
$threeCopy = $three->duplicate(); $threeCopy = $three->duplicate();
$oneCopy = DataObject::get_by_id("DataObjectDuplicateTestClass1", $oneCopy->ID); $oneCopy = DataObject::get_by_id(DataObjectDuplicationTest\Class1::class, $oneCopy->ID);
$twoCopy = DataObject::get_by_id("DataObjectDuplicateTestClass2", $twoCopy->ID); $twoCopy = DataObject::get_by_id(DataObjectDuplicationTest\Class2::class, $twoCopy->ID);
$threeCopy = DataObject::get_by_id("DataObjectDuplicateTestClass3", $threeCopy->ID); $threeCopy = DataObject::get_by_id(DataObjectDuplicationTest\Class3::class, $threeCopy->ID);
$this->assertNotNull($oneCopy, "Copy of 1 exists"); $this->assertNotNull($oneCopy, "Copy of 1 exists");
$this->assertNotNull($twoCopy, "Copy of 2 exists"); $this->assertNotNull($twoCopy, "Copy of 2 exists");

View File

@ -20,9 +20,9 @@ class DataObjectLazyLoadingTest extends SapphireTest {
'VersionedTest.yml' 'VersionedTest.yml'
); );
public function setUpOnce() protected function getExtraDataObjects()
{ {
$this->extraDataObjects = array_merge( return array_merge(
DataObjectTest::$extra_data_objects, DataObjectTest::$extra_data_objects,
ManyManyListTest::$extra_data_objects, ManyManyListTest::$extra_data_objects,
VersionedTest::$extra_data_objects, VersionedTest::$extra_data_objects,
@ -31,7 +31,6 @@ class DataObjectLazyLoadingTest extends SapphireTest {
VersionedSubObject::class, VersionedSubObject::class,
] ]
); );
parent::setUpOnce();
} }
public function testQueriedColumnsID() { public function testQueriedColumnsID() {

View File

@ -160,29 +160,29 @@ class DataObjectSchemaTest extends SapphireTest
); );
$this->assertEquals( $this->assertEquals(
[ [
'ID' => 'DataObjectSchemaTest_HasFields.PrimaryKey', 'ID' => DataObjectSchemaTest\HasFields::class.'.PrimaryKey',
'ClassName' => 'DataObjectSchemaTest_BaseDataClass.DBClassName', 'ClassName' => DataObjectSchemaTest\BaseDataClass::class.'.DBClassName',
'LastEdited' => 'DataObjectSchemaTest_BaseDataClass.DBDatetime', 'LastEdited' => DataObjectSchemaTest\BaseDataClass::class.'.DBDatetime',
'Created' => 'DataObjectSchemaTest_BaseDataClass.DBDatetime', 'Created' => DataObjectSchemaTest\BaseDataClass::class.'.DBDatetime',
'Title' => 'DataObjectSchemaTest_BaseDataClass.Varchar', 'Title' => DataObjectSchemaTest\BaseDataClass::class.'.Varchar',
'Description' => 'DataObjectSchemaTest_HasFields.Varchar', 'Description' => DataObjectSchemaTest\HasFields::class.'.Varchar',
'MoneyFieldCurrency' => 'DataObjectSchemaTest_HasFields.Varchar(3)', 'MoneyFieldCurrency' => DataObjectSchemaTest\HasFields::class.'.Varchar(3)',
'MoneyFieldAmount' => 'DataObjectSchemaTest_HasFields.Decimal(19,4)', 'MoneyFieldAmount' => DataObjectSchemaTest\HasFields::class.'.Decimal(19,4)',
'MoneyField' => 'DataObjectSchemaTest_HasFields.Money', 'MoneyField' => DataObjectSchemaTest\HasFields::class.'.Money',
], ],
$schema->fieldSpecs(HasFields::class, DataObjectSchema::INCLUDE_CLASS) $schema->fieldSpecs(HasFields::class, DataObjectSchema::INCLUDE_CLASS)
); );
// DB_ONLY excludes composite field MoneyField // DB_ONLY excludes composite field MoneyField
$this->assertEquals( $this->assertEquals(
[ [
'ID' => 'DataObjectSchemaTest_HasFields.PrimaryKey', 'ID' => DataObjectSchemaTest\HasFields::class.'.PrimaryKey',
'ClassName' => 'DataObjectSchemaTest_BaseDataClass.DBClassName', 'ClassName' => DataObjectSchemaTest\BaseDataClass::class.'.DBClassName',
'LastEdited' => 'DataObjectSchemaTest_BaseDataClass.DBDatetime', 'LastEdited' => DataObjectSchemaTest\BaseDataClass::class.'.DBDatetime',
'Created' => 'DataObjectSchemaTest_BaseDataClass.DBDatetime', 'Created' => DataObjectSchemaTest\BaseDataClass::class.'.DBDatetime',
'Title' => 'DataObjectSchemaTest_BaseDataClass.Varchar', 'Title' => DataObjectSchemaTest\BaseDataClass::class.'.Varchar',
'Description' => 'DataObjectSchemaTest_HasFields.Varchar', 'Description' => DataObjectSchemaTest\HasFields::class.'.Varchar',
'MoneyFieldCurrency' => 'DataObjectSchemaTest_HasFields.Varchar(3)', 'MoneyFieldCurrency' => DataObjectSchemaTest\HasFields::class.'.Varchar(3)',
'MoneyFieldAmount' => 'DataObjectSchemaTest_HasFields.Decimal(19,4)' 'MoneyFieldAmount' => DataObjectSchemaTest\HasFields::class.'.Decimal(19,4)'
], ],
$schema->fieldSpecs( $schema->fieldSpecs(
HasFields::class, HasFields::class,
@ -193,10 +193,10 @@ class DataObjectSchemaTest extends SapphireTest
// Use all options at once // Use all options at once
$this->assertEquals( $this->assertEquals(
[ [
'ID' => 'DataObjectSchemaTest_HasFields.PrimaryKey', 'ID' => DataObjectSchemaTest\HasFields::class.'.PrimaryKey',
'Description' => 'DataObjectSchemaTest_HasFields.Varchar', 'Description' => DataObjectSchemaTest\HasFields::class.'.Varchar',
'MoneyFieldCurrency' => 'DataObjectSchemaTest_HasFields.Varchar(3)', 'MoneyFieldCurrency' => DataObjectSchemaTest\HasFields::class.'.Varchar(3)',
'MoneyFieldAmount' => 'DataObjectSchemaTest_HasFields.Decimal(19,4)', 'MoneyFieldAmount' => DataObjectSchemaTest\HasFields::class.'.Decimal(19,4)',
], ],
$schema->fieldSpecs( $schema->fieldSpecs(
HasFields::class, HasFields::class,

View File

@ -53,15 +53,14 @@ class DataObjectTest extends SapphireTest {
DataObjectTest\Ploy::class, DataObjectTest\Ploy::class,
DataObjectTest\Bogey::class, DataObjectTest\Bogey::class,
DataObjectTest\Sortable::class, DataObjectTest\Sortable::class,
// From ManyManyListTest
ExtraFieldsObject::class,
Product::class,
Category::class,
); );
public function setUpOnce() { protected function getExtraDataObjects()
$this->extraDataObjects = static::$extra_data_objects; {
parent::setUpOnce(); return array_merge(
DataObjectTest::$extra_data_objects,
ManyManyListTest::$extra_data_objects
);
} }
public function testDb() { public function testDb() {

View File

@ -8,6 +8,9 @@ use SilverStripe\ORM\DB;
use SilverStripe\Dev\SapphireTest; use SilverStripe\Dev\SapphireTest;
use SilverStripe\Security\Member; use SilverStripe\Security\Member;
/**
* @skipUpgrade
*/
class DataQueryTest extends SapphireTest { class DataQueryTest extends SapphireTest {
protected static $fixture_file = 'DataQueryTest.yml'; protected static $fixture_file = 'DataQueryTest.yml';
@ -20,6 +23,9 @@ class DataQueryTest extends SapphireTest {
DataQueryTest\ObjectE::class, DataQueryTest\ObjectE::class,
DataQueryTest\ObjectF::class, DataQueryTest\ObjectF::class,
DataQueryTest\ObjectG::class, DataQueryTest\ObjectG::class,
SQLSelectTest\TestObject::class,
SQLSelectTest\TestBase::class,
SQLSelectTest\TestChild::class,
); );
public function testSortByJoinedFieldRetainsSourceInformation() { public function testSortByJoinedFieldRetainsSourceInformation() {
@ -34,7 +40,7 @@ class DataQueryTest extends SapphireTest {
$query = new DataQuery(DataQueryTest\ObjectB::class); $query = new DataQuery(DataQueryTest\ObjectB::class);
$result = $query->leftJoin( $result = $query->leftJoin(
DataQueryTest\ObjectC::class, 'DataQueryTest_C',
"\"DataQueryTest_B\".\"TestCID\" = \"DataQueryTest_B\".\"ID\"" "\"DataQueryTest_B\".\"TestCID\" = \"DataQueryTest_B\".\"ID\""
)->sort('"DataQueryTest_B"."Title"', 'ASC'); )->sort('"DataQueryTest_B"."Title"', 'ASC');
@ -61,12 +67,12 @@ class DataQueryTest extends SapphireTest {
// Test applyRelation with two has_ones pointing to the same class // Test applyRelation with two has_ones pointing to the same class
$dq = new DataQuery(DataQueryTest\ObjectB::class); $dq = new DataQuery(DataQueryTest\ObjectB::class);
$dq->applyRelation('TestC'); $dq->applyRelation('TestC');
$this->assertTrue($dq->query()->isJoinedTo(DataQueryTest\ObjectC::class)); $this->assertTrue($dq->query()->isJoinedTo('DataQueryTest_C'));
$this->assertContains('"DataQueryTest_C"."ID" = "DataQueryTest_B"."TestCID"', $dq->sql()); $this->assertContains('"DataQueryTest_C"."ID" = "DataQueryTest_B"."TestCID"', $dq->sql());
$dq = new DataQuery(DataQueryTest\ObjectB::class); $dq = new DataQuery(DataQueryTest\ObjectB::class);
$dq->applyRelation('TestCTwo'); $dq->applyRelation('TestCTwo');
$this->assertTrue($dq->query()->isJoinedTo(DataQueryTest\ObjectC::class)); $this->assertTrue($dq->query()->isJoinedTo('DataQueryTest_C'));
$this->assertContains('"DataQueryTest_C"."ID" = "DataQueryTest_B"."TestCTwoID"', $dq->sql()); $this->assertContains('"DataQueryTest_C"."ID" = "DataQueryTest_B"."TestCTwoID"', $dq->sql());
} }
@ -75,7 +81,7 @@ class DataQueryTest extends SapphireTest {
$newDQ = new DataQuery(DataQueryTest\ObjectE::class); $newDQ = new DataQuery(DataQueryTest\ObjectE::class);
//apply a relation to a relation from an ancestor class //apply a relation to a relation from an ancestor class
$newDQ->applyRelation('TestA'); $newDQ->applyRelation('TestA');
$this->assertTrue($newDQ->query()->isJoinedTo(DataQueryTest\ObjectC::class)); $this->assertTrue($newDQ->query()->isJoinedTo('DataQueryTest_C'));
$this->assertContains('"DataQueryTest_A"."ID" = "DataQueryTest_C"."TestAID"', $newDQ->sql($params)); $this->assertContains('"DataQueryTest_A"."ID" = "DataQueryTest_C"."TestAID"', $newDQ->sql($params));
//test many_many relation //test many_many relation
@ -128,7 +134,7 @@ class DataQueryTest extends SapphireTest {
public function testRelationOrderWithCustomJoin() { public function testRelationOrderWithCustomJoin() {
$dataQuery = new DataQuery(DataQueryTest\ObjectB::class); $dataQuery = new DataQuery(DataQueryTest\ObjectB::class);
$dataQuery->innerJoin(DataQueryTest\ObjectD::class, '"DataQueryTest_D"."RelationID" = "DataQueryTest_B"."ID"'); $dataQuery->innerJoin('DataQueryTest_D', '"DataQueryTest_D"."RelationID" = "DataQueryTest_B"."ID"');
$dataQuery->execute(); $dataQuery->execute();
} }
@ -207,7 +213,7 @@ class DataQueryTest extends SapphireTest {
} }
public function testOrderByMultiple() { public function testOrderByMultiple() {
$dq = new DataQuery('SQLSelectTest_DO'); $dq = new DataQuery(SQLSelectTest\TestObject::class);
$dq = $dq->sort('"Name" ASC, MID("Name", 8, 1) DESC'); $dq = $dq->sort('"Name" ASC, MID("Name", 8, 1) DESC');
$this->assertContains( $this->assertContains(
'ORDER BY "SQLSelectTest_DO"."Name" ASC, "_SortColumn0" DESC', 'ORDER BY "SQLSelectTest_DO"."Name" ASC, "_SortColumn0" DESC',
@ -296,8 +302,8 @@ class DataQueryTest extends SapphireTest {
)); ));
$result = $query->getFinalisedQuery(array('Title')); $result = $query->getFinalisedQuery(array('Title'));
$from = $result->getFrom(); $from = $result->getFrom();
$this->assertContains(DataQueryTest\ObjectC::class, array_keys($from)); $this->assertContains('DataQueryTest_C', array_keys($from));
$this->assertNotContains(DataQueryTest\ObjectE::class, array_keys($from)); $this->assertNotContains('DataQueryTest_E', array_keys($from));
// Including filter on sub-table requires it // Including filter on sub-table requires it
$query = new DataQuery(DataQueryTest\ObjectC::class); $query = new DataQuery(DataQueryTest\ObjectC::class);
@ -311,8 +317,8 @@ class DataQueryTest extends SapphireTest {
$from = $result->getFrom(); $from = $result->getFrom();
// Check that including "SortOrder" prompted inclusion of DataQueryTest_E table // Check that including "SortOrder" prompted inclusion of DataQueryTest_E table
$this->assertContains(DataQueryTest\ObjectC::class, array_keys($from)); $this->assertContains('DataQueryTest_C', array_keys($from));
$this->assertContains(DataQueryTest\ObjectE::class, array_keys($from)); $this->assertContains('DataQueryTest_E', array_keys($from));
$arrayResult = iterator_to_array($result->execute()); $arrayResult = iterator_to_array($result->execute());
$first = array_shift($arrayResult); $first = array_shift($arrayResult);
$this->assertNotNull($first); $this->assertNotNull($first);

View File

@ -4,7 +4,6 @@ namespace SilverStripe\ORM\Tests\DataQueryTest;
use SilverStripe\Dev\TestOnly; use SilverStripe\Dev\TestOnly;
use SilverStripe\ORM\DataObject; use SilverStripe\ORM\DataObject;
use SilverStripe\ORM\Tests\DataQueryTest;
class ObjectC extends DataObject implements TestOnly class ObjectC extends DataObject implements TestOnly
{ {
@ -15,18 +14,18 @@ class ObjectC extends DataObject implements TestOnly
); );
private static $has_one = array( private static $has_one = array(
'TestA' => DataQueryTest\ObjectA::class, 'TestA' => ObjectA::class,
'TestB' => DataQueryTest\ObjectB::class, 'TestB' => ObjectB::class,
); );
private static $has_many = array( private static $has_many = array(
'TestAs' => DataQueryTest\ObjectA::class, 'TestAs' => ObjectA::class,
'TestBs' => 'SilverStripe\\ORM\\Tests\\DataQueryTest\\ObjectB.TestC', 'TestBs' => 'SilverStripe\\ORM\\Tests\\DataQueryTest\\ObjectB.TestC',
'TestBsTwo' => 'SilverStripe\\ORM\\Tests\\DataQueryTest\\ObjectB.TestCTwo', 'TestBsTwo' => 'SilverStripe\\ORM\\Tests\\DataQueryTest\\ObjectB.TestCTwo',
); );
private static $many_many = array( private static $many_many = array(
'ManyTestAs' => DataQueryTest\ObjectA::class, 'ManyTestAs' => ObjectA::class,
'ManyTestBs' => DataQueryTest\ObjectB::class, 'ManyTestBs' => ObjectB::class,
); );
} }

View File

@ -4,13 +4,12 @@ namespace SilverStripe\ORM\Tests\DataQueryTest;
use SilverStripe\Dev\TestOnly; use SilverStripe\Dev\TestOnly;
use SilverStripe\ORM\DataObject; use SilverStripe\ORM\DataObject;
use SilverStripe\ORM\Tests\DataQueryTest;
class ObjectD extends DataObject implements TestOnly class ObjectD extends DataObject implements TestOnly
{ {
private static $table_name = 'DataQueryTest_D'; private static $table_name = 'DataQueryTest_D';
private static $has_one = array( private static $has_one = array(
'Relation' => DataQueryTest\ObjectB::class, 'Relation' => ObjectB::class,
); );
} }

View File

@ -3,9 +3,8 @@
namespace SilverStripe\ORM\Tests\DataQueryTest; namespace SilverStripe\ORM\Tests\DataQueryTest;
use SilverStripe\Dev\TestOnly; use SilverStripe\Dev\TestOnly;
use SilverStripe\ORM\Tests\DataQueryTest;
class ObjectE extends DataQueryTest\ObjectC implements TestOnly class ObjectE extends ObjectC implements TestOnly
{ {
private static $table_name = 'DataQueryTest_E'; private static $table_name = 'DataQueryTest_E';

View File

@ -3,14 +3,13 @@
namespace SilverStripe\ORM\Tests\DataQueryTest; namespace SilverStripe\ORM\Tests\DataQueryTest;
use SilverStripe\Dev\TestOnly; use SilverStripe\Dev\TestOnly;
use SilverStripe\ORM\Tests\DataQueryTest;
class ObjectG extends DataQueryTest\ObjectC implements TestOnly class ObjectG extends ObjectC implements TestOnly
{ {
private static $table_name = 'DataQueryTest_G'; private static $table_name = 'DataQueryTest_G';
private static $belongs_many_many = array( private static $belongs_many_many = array(
'ManyTestEs' => DataQueryTest\ObjectE::class, 'ManyTestEs' => ObjectE::class,
); );
} }

View File

@ -34,7 +34,7 @@ class SearchFilterApplyRelationTest extends SapphireTest {
$all = SearchFilterApplyRelationTest\TestObject::singleton(); $all = SearchFilterApplyRelationTest\TestObject::singleton();
$context = $all->getDefaultSearchContext(); $context = $all->getDefaultSearchContext();
$filter = new ExactMatchFilter("SearchFilterApplyRelationTest_HasOneGrantChild.Title"); $filter = new ExactMatchFilter("SearchFilterApplyRelationTest_HasOneGrandChild.Title");
$context->setFilters(null); $context->setFilters(null);
$context->addFilter($filter); $context->addFilter($filter);
$params = array( $params = array(
@ -51,31 +51,31 @@ class SearchFilterApplyRelationTest extends SapphireTest {
$all = SearchFilterApplyRelationTest\TestObject::singleton(); $all = SearchFilterApplyRelationTest\TestObject::singleton();
$context = $all->getDefaultSearchContext(); $context = $all->getDefaultSearchContext();
$filter = new PartialMatchFilter("SearchFilterApplyRelationTest_HasManyGrantChildren.Title"); $filter = new PartialMatchFilter("SearchFilterApplyRelationTest_HasManyGrandChildren.Title");
$context->setFilters(null); $context->setFilters(null);
$context->addFilter($filter); $context->addFilter($filter);
$params = array( $params = array(
"SearchFilterApplyRelationTest_HasManyGrantChildren__Title" => "I am has_many object1", "SearchFilterApplyRelationTest_HasManyGrandChildren__Title" => "I am has_many object1",
); );
$results = $context->getResults($params); $results = $context->getResults($params);
$this->assertEquals(1, $results->count()); $this->assertEquals(1, $results->count());
$this->assertEquals(array($do1->ID), $results->column('ID')); $this->assertEquals(array($do1->ID), $results->column('ID'));
$params = array( $params = array(
"SearchFilterApplyRelationTest_HasManyGrantChildren__Title" => "I am has_many object3", "SearchFilterApplyRelationTest_HasManyGrandChildren__Title" => "I am has_many object3",
); );
$results = $context->getResults($params); $results = $context->getResults($params);
$this->assertEquals(1, $results->count()); $this->assertEquals(1, $results->count());
$this->assertEquals(array($do2->ID), $results->column('ID')); $this->assertEquals(array($do2->ID), $results->column('ID'));
$params = array( $params = array(
"SearchFilterApplyRelationTest_HasManyGrantChildren__Title" => "I am has_many object", "SearchFilterApplyRelationTest_HasManyGrandChildren__Title" => "I am has_many object",
); );
$results = $context->getResults($params); $results = $context->getResults($params);
$this->assertEquals(2, $results->count()); $this->assertEquals(2, $results->count());
$params = array( $params = array(
"SearchFilterApplyRelationTest_HasManyGrantChildren__Title" => "not exist", "SearchFilterApplyRelationTest_HasManyGrandChildren__Title" => "not exist",
); );
$results = $context->getResults($params); $results = $context->getResults($params);
$this->assertEquals(0, $results->count()); $this->assertEquals(0, $results->count());
@ -85,29 +85,29 @@ class SearchFilterApplyRelationTest extends SapphireTest {
$all = SearchFilterApplyRelationTest\TestObject::singleton(); $all = SearchFilterApplyRelationTest\TestObject::singleton();
$context = $all->getDefaultSearchContext(); $context = $all->getDefaultSearchContext();
$filter = new PartialMatchFilter("ManyManyGrantChildren.Title"); $filter = new PartialMatchFilter("ManyManyGrandChildren.Title");
$context->setFilters(null); $context->setFilters(null);
$context->addFilter($filter); $context->addFilter($filter);
$params = array( $params = array(
"ManyManyGrantChildren__Title" => "I am many_many object1", "ManyManyGrandChildren__Title" => "I am many_many object1",
); );
$results = $context->getResults($params); $results = $context->getResults($params);
$this->assertEquals(2, $results->count()); $this->assertEquals(2, $results->count());
$params = array( $params = array(
"ManyManyGrantChildren__Title" => "I am many_many object2", "ManyManyGrandChildren__Title" => "I am many_many object2",
); );
$results = $context->getResults($params); $results = $context->getResults($params);
$this->assertEquals(2, $results->count()); $this->assertEquals(2, $results->count());
$params = array( $params = array(
"ManyManyGrantChildren__Title" => "I am many_many object", "ManyManyGrandChildren__Title" => "I am many_many object",
); );
$results = $context->getResults($params); $results = $context->getResults($params);
$this->assertEquals(2, $results->count()); $this->assertEquals(2, $results->count());
$params = array( $params = array(
"ManyManyGrantChildren__Title" => "not exist", "ManyManyGrandChildren__Title" => "not exist",
); );
$results = $context->getResults($params); $results = $context->getResults($params);
$this->assertEquals(0, $results->count()); $this->assertEquals(0, $results->count());

View File

@ -10,14 +10,14 @@ class TestObject extends DataObject implements TestOnly
private static $table_name = 'SearchFilterApplyRelationTest_DO'; private static $table_name = 'SearchFilterApplyRelationTest_DO';
private static $has_one = array( private static $has_one = array(
'SearchFilterApplyRelationTest_HasOneGrantChild' => HasOneGrandChild::class 'SearchFilterApplyRelationTest_HasOneGrandChild' => HasOneGrandChild::class
); );
private static $has_many = array( private static $has_many = array(
'SearchFilterApplyRelationTest_HasManyGrantChildren' => HasManyGrandChild::class 'SearchFilterApplyRelationTest_HasManyGrandChildren' => HasManyGrandChild::class
); );
private static $many_many = array( private static $many_many = array(
'ManyManyGrantChildren' => ManyManyGrandChild::class 'ManyManyGrandChildren' => ManyManyGrandChild::class
); );
} }

View File

@ -2,20 +2,13 @@
namespace SilverStripe\ORM\Tests; namespace SilverStripe\ORM\Tests;
use SilverStripe\ORM\ArrayList; use SilverStripe\ORM\ArrayList;
use SilverStripe\ORM\GroupedList; use SilverStripe\ORM\GroupedList;
use SilverStripe\Dev\SapphireTest; use SilverStripe\Dev\SapphireTest;
use SilverStripe\View\ArrayData; use SilverStripe\View\ArrayData;
/** /**
* Tests for the {@link GroupedList} list decorator. * Tests for the {@link GroupedList} list decorator.
*
* @package framework
* @subpackage tests
*/ */
class GroupedListTest extends SapphireTest { class GroupedListTest extends SapphireTest {

View File

@ -12,9 +12,12 @@ class HasManyListTest extends SapphireTest {
// Borrow the model from DataObjectTest // Borrow the model from DataObjectTest
protected static $fixture_file = 'DataObjectTest.yml'; protected static $fixture_file = 'DataObjectTest.yml';
public function setUpOnce() { protected function getExtraDataObjects()
$this->extraDataObjects = DataObjectTest::$extra_data_objects; {
parent::setUpOnce(); return array_merge(
DataObjectTest::$extra_data_objects,
ManyManyListTest::$extra_data_objects
);
} }
public function testRelationshipEmptyOnNewRecords() { public function testRelationshipEmptyOnNewRecords() {
@ -36,14 +39,14 @@ class HasManyListTest extends SapphireTest {
); );
// Test that each team has the correct fans // Test that each team has the correct fans
$team1 = $this->objFromFixture('DataObjectTest_Team', 'team1'); $team1 = $this->objFromFixture(DataObjectTest\Team::class, 'team1');
$team2 = $this->objFromFixture('DataObjectTest_Team', 'team2'); $team2 = $this->objFromFixture(DataObjectTest\Team::class, 'team2');
$this->assertEquals(array('Bob', 'Joe'), $team1->Comments()->sort('Name')->column('Name')); $this->assertEquals(array('Bob', 'Joe'), $team1->Comments()->sort('Name')->column('Name'));
$this->assertEquals(array('Phil'), $team2->Comments()->sort('Name')->column('Name')); $this->assertEquals(array('Phil'), $team2->Comments()->sort('Name')->column('Name'));
// Test that removing comments from unrelated team has no effect // Test that removing comments from unrelated team has no effect
$team1comment = $this->objFromFixture('DataObjectTest_TeamComment', 'comment1'); $team1comment = $this->objFromFixture(DataObjectTest\TeamComment::class, 'comment1');
$team2comment = $this->objFromFixture('DataObjectTest_TeamComment', 'comment3'); $team2comment = $this->objFromFixture(DataObjectTest\TeamComment::class, 'comment3');
$team1->Comments()->remove($team2comment); $team1->Comments()->remove($team2comment);
$team2->Comments()->remove($team1comment); $team2->Comments()->remove($team1comment);
$this->assertEquals(array('Bob', 'Joe'), $team1->Comments()->sort('Name')->column('Name')); $this->assertEquals(array('Bob', 'Joe'), $team1->Comments()->sort('Name')->column('Name'));
@ -52,8 +55,8 @@ class HasManyListTest extends SapphireTest {
$this->assertEquals($team2->ID, $team2comment->TeamID); $this->assertEquals($team2->ID, $team2comment->TeamID);
// Test that removing items from the related team resets the has_one relations on the fan // Test that removing items from the related team resets the has_one relations on the fan
$team1comment = $this->objFromFixture('DataObjectTest_TeamComment', 'comment1'); $team1comment = $this->objFromFixture(DataObjectTest\TeamComment::class, 'comment1');
$team2comment = $this->objFromFixture('DataObjectTest_TeamComment', 'comment3'); $team2comment = $this->objFromFixture(DataObjectTest\TeamComment::class, 'comment3');
$team1->Comments()->remove($team1comment); $team1->Comments()->remove($team1comment);
$team2->Comments()->remove($team2comment); $team2->Comments()->remove($team2comment);
$this->assertEquals(array('Bob'), $team1->Comments()->sort('Name')->column('Name')); $this->assertEquals(array('Bob'), $team1->Comments()->sort('Name')->column('Name'));

View File

@ -22,20 +22,17 @@ class HierarchyTest extends SapphireTest {
* Test the Hierarchy prevents infinite loops. * Test the Hierarchy prevents infinite loops.
*/ */
public function testPreventLoop() { public function testPreventLoop() {
$this->setExpectedException(
ValidationException::class,
sprintf('Infinite loop found within the "%s" hierarchy', HierarchyTest\TestObject::class)
);
$obj2 = $this->objFromFixture(HierarchyTest\TestObject::class, 'obj2'); $obj2 = $this->objFromFixture(HierarchyTest\TestObject::class, 'obj2');
$obj2aa = $this->objFromFixture(HierarchyTest\TestObject::class, 'obj2aa'); $obj2aa = $this->objFromFixture(HierarchyTest\TestObject::class, 'obj2aa');
$obj2->ParentID = $obj2aa->ID; $obj2->ParentID = $obj2aa->ID;
try {
$obj2->write(); $obj2->write();
} }
catch (ValidationException $e) {
$this->assertContains('Infinite loop found within the "HierarchyTest_Object" hierarchy', $e->getMessage());
return;
}
$this->fail('Failed to prevent infinite loop in hierarchy.');
}
/** /**
* Test Hierarchy::AllHistoricalChildren(). * Test Hierarchy::AllHistoricalChildren().
@ -63,7 +60,7 @@ class HierarchyTest extends SapphireTest {
// Obj 3 has been deleted; let's bring it back from the grave // Obj 3 has been deleted; let's bring it back from the grave
$obj3 = Versioned::get_including_deleted("HierarchyTest_Object", "\"Title\" = 'Obj 3'")->First(); $obj3 = Versioned::get_including_deleted(HierarchyTest\TestObject::class, "\"Title\" = 'Obj 3'")->First();
// Check that all obj 3 children are returned // Check that all obj 3 children are returned
$this->assertEquals(array("Obj 3a", "Obj 3b", "Obj 3c", "Obj 3d"), $this->assertEquals(array("Obj 3a", "Obj 3b", "Obj 3c", "Obj 3d"),
@ -86,7 +83,7 @@ class HierarchyTest extends SapphireTest {
$this->objFromFixture(HierarchyTest\TestObject::class, 'obj3')->markUnexpanded(); $this->objFromFixture(HierarchyTest\TestObject::class, 'obj3')->markUnexpanded();
// Query some objs in a different context and check their m // Query some objs in a different context and check their m
$objs = DataObject::get("HierarchyTest_Object", '', '"ID" ASC'); $objs = DataObject::get(HierarchyTest\TestObject::class, '', '"ID" ASC');
$marked = $expanded = array(); $marked = $expanded = array();
foreach($objs as $obj) { foreach($objs as $obj) {
if($obj->isMarked()) $marked[] = $obj->Title; if($obj->isMarked()) $marked[] = $obj->Title;
@ -547,7 +544,9 @@ EOT;
} }
public function testHideFromHeirarchy() { public function testHideFromHeirarchy() {
HierarchyTest\HideTestObject::config()->hide_from_hierarchy = array('HierarchyHideTest_SubObject'); HierarchyTest\HideTestObject::config()->update('hide_from_hierarchy', [
HierarchyTest\HideTestSubObject::class,
]);
$obj4 = $this->objFromFixture(HierarchyTest\HideTestObject::class, 'obj4'); $obj4 = $this->objFromFixture(HierarchyTest\HideTestObject::class, 'obj4');
$obj4->copyVersionToStage(Versioned::DRAFT, Versioned::LIVE); $obj4->copyVersionToStage(Versioned::DRAFT, Versioned::LIVE);

View File

@ -4,6 +4,7 @@ namespace SilverStripe\ORM\Tests;
use SilverStripe\Assets\File; use SilverStripe\Assets\File;
use SilverStripe\Assets\Filesystem as SSFilesystem; use SilverStripe\Assets\Filesystem as SSFilesystem;
use SilverStripe\Assets\Folder;
use SilverStripe\Assets\Image; use SilverStripe\Assets\Image;
use SilverStripe\Assets\Storage\DBFile; use SilverStripe\Assets\Storage\DBFile;
use SilverStripe\Core\Config\Config; use SilverStripe\Core\Config\Config;
@ -32,7 +33,7 @@ class ImageTest extends SapphireTest {
$files = File::get()->exclude('ClassName', Folder::class); $files = File::get()->exclude('ClassName', Folder::class);
foreach($files as $image) { foreach($files as $image) {
$filePath = TestAssetStore::getLocalPath($image); // Only correct for test asset store $filePath = TestAssetStore::getLocalPath($image); // Only correct for test asset store
$sourcePath = FRAMEWORK_PATH . '/tests/model/testimages/' . $image->Name; $sourcePath = __DIR__ . '/ImageTest/' . $image->Name;
if(!file_exists($filePath)) { if(!file_exists($filePath)) {
SSFilesystem::makeFolder(dirname($filePath)); SSFilesystem::makeFolder(dirname($filePath));
if (!copy($sourcePath, $filePath)) { if (!copy($sourcePath, $filePath)) {

View File

Before

Width:  |  Height:  |  Size: 148 KiB

After

Width:  |  Height:  |  Size: 148 KiB

View File

Before

Width:  |  Height:  |  Size: 12 KiB

After

Width:  |  Height:  |  Size: 12 KiB

View File

Before

Width:  |  Height:  |  Size: 5.8 KiB

After

Width:  |  Height:  |  Size: 5.8 KiB

View File

Before

Width:  |  Height:  |  Size: 5.8 KiB

After

Width:  |  Height:  |  Size: 5.8 KiB

View File

@ -19,12 +19,12 @@ class ManyManyListTest extends SapphireTest {
ManyManyListTest\Product::class, ManyManyListTest\Product::class,
]; ];
public function setUpOnce() { protected function getExtraDataObjects()
$this->extraDataObjects = array_merge( {
return array_merge(
DataObjectTest::$extra_data_objects, DataObjectTest::$extra_data_objects,
static::$extra_data_objects ManyManyListTest::$extra_data_objects
); );
parent::setUpOnce();
} }
public function testAddCompositedExtraFields() { public function testAddCompositedExtraFields() {

View File

@ -13,9 +13,12 @@ class MapTest extends SapphireTest {
// Borrow the model from DataObjectTest // Borrow the model from DataObjectTest
protected static $fixture_file = 'DataObjectTest.yml'; protected static $fixture_file = 'DataObjectTest.yml';
public function setUpOnce() { protected function getExtraDataObjects()
$this->extraDataObjects = DataObjectTest::$extra_data_objects; {
parent::setUpOnce(); return array_merge(
DataObjectTest::$extra_data_objects,
ManyManyListTest::$extra_data_objects
);
} }
public function testValues() { public function testValues() {
@ -76,7 +79,7 @@ class MapTest extends SapphireTest {
public function testDefaultConfigIsIDAndTitle() { public function testDefaultConfigIsIDAndTitle() {
$list = Team::get(); $list = Team::get();
$map = new Map($list); $map = new Map($list);
$this->assertEquals('Team 1', $map[$this->idFromFixture('DataObjectTest_Team', 'team1')]); $this->assertEquals('Team 1', $map[$this->idFromFixture(DataObjectTest\Team::class, 'team1')]);
} }
public function testSetKeyFieldAndValueField() { public function testSetKeyFieldAndValueField() {

View File

@ -2,25 +2,18 @@
namespace SilverStripe\ORM\Tests; namespace SilverStripe\ORM\Tests;
use SilverStripe\ORM\Connect\PDOQuery;
use SilverStripe\ORM\DB; use SilverStripe\ORM\DB;
use SilverStripe\ORM\Connect\PDOConnector; use SilverStripe\ORM\Connect\PDOConnector;
use SilverStripe\ORM\Queries\SQLUpdate; use SilverStripe\ORM\Queries\SQLUpdate;
use SilverStripe\Dev\SapphireTest; use SilverStripe\Dev\SapphireTest;
/**
* @package framework
* @subpackage testing
*/
class PDODatabaseTest extends SapphireTest { class PDODatabaseTest extends SapphireTest {
protected static $fixture_file = 'MySQLDatabaseTest.yml'; protected static $fixture_file = 'MySQLDatabaseTest.yml';
protected $extraDataObjects = array( protected $extraDataObjects = array(
'MySQLDatabaseTest_Data' MySQLDatabaseTest\Data::class
); );
public function testPreparedStatements() { public function testPreparedStatements() {
@ -38,12 +31,12 @@ class PDODatabaseTest extends SapphireTest {
'SELECT "Sort", "Title" FROM "MySQLDatabaseTest_Data" WHERE "Sort" > ? ORDER BY "Sort"', 'SELECT "Sort", "Title" FROM "MySQLDatabaseTest_Data" WHERE "Sort" > ? ORDER BY "Sort"',
array(2) array(2)
); );
$this->assertInstanceOf('SilverStripe\\ORM\\Connect\\PDOQuery', $result1); $this->assertInstanceOf(PDOQuery::class, $result1);
$this->assertInstanceOf('SilverStripe\\ORM\\Connect\\PDOQuery', $result2); $this->assertInstanceOf(PDOQuery::class, $result2);
// Also select non-prepared statement // Also select non-prepared statement
$result3 = DB::get_connector()->query('SELECT "Sort", "Title" FROM "MySQLDatabaseTest_Data" ORDER BY "Sort"'); $result3 = DB::get_connector()->query('SELECT "Sort", "Title" FROM "MySQLDatabaseTest_Data" ORDER BY "Sort"');
$this->assertInstanceOf('SilverStripe\\ORM\\Connect\\PDOQuery', $result3); $this->assertInstanceOf(PDOQuery::class, $result3);
// Iterating one level should not buffer, but return the right result // Iterating one level should not buffer, but return the right result
$this->assertEquals( $this->assertEquals(
@ -112,13 +105,13 @@ class PDODatabaseTest extends SapphireTest {
// Test update which affects no rows // Test update which affects no rows
$query->setWhere(array('Title' => 'Bob')); $query->setWhere(array('Title' => 'Bob'));
$result = $query->execute(); $result = $query->execute();
$this->assertInstanceOf('SilverStripe\\ORM\\Connect\\PDOQuery', $result); $this->assertInstanceOf(PDOQuery::class, $result);
$this->assertEquals(0, DB::affected_rows()); $this->assertEquals(0, DB::affected_rows());
// Test update which affects some rows // Test update which affects some rows
$query->setWhere(array('Title' => 'First Item')); $query->setWhere(array('Title' => 'First Item'));
$result = $query->execute(); $result = $query->execute();
$this->assertInstanceOf('SilverStripe\\ORM\\Connect\\PDOQuery', $result); $this->assertInstanceOf(PDOQuery::class, $result);
$this->assertEquals(1, DB::affected_rows()); $this->assertEquals(1, DB::affected_rows());
} }
} }

View File

@ -16,12 +16,12 @@ class PaginatedListTest extends SapphireTest {
protected static $fixture_file = 'DataObjectTest.yml'; protected static $fixture_file = 'DataObjectTest.yml';
public function setUpOnce() { protected function getExtraDataObjects()
$this->extraDataObjects = array_merge( {
return array_merge(
DataObjectTest::$extra_data_objects, DataObjectTest::$extra_data_objects,
ManyManyListTest::$extra_data_objects ManyManyListTest::$extra_data_objects
); );
parent::setUpOnce();
} }
public function testPageStart() { public function testPageStart() {

View File

@ -2,30 +2,28 @@
namespace SilverStripe\ORM\Tests; namespace SilverStripe\ORM\Tests;
use SilverStripe\Dev\SapphireTest; use SilverStripe\Dev\SapphireTest;
use SilverStripe\ORM\Tests\DataObjectTest\Fan; use SilverStripe\ORM\Tests\DataObjectTest\Fan;
use SilverStripe\ORM\Tests\DataObjectTest\Team; use SilverStripe\ORM\Tests\DataObjectTest\Team;
/** /**
* Tests the PolymorphicHasManyList class * Tests the PolymorphicHasManyList class
* *
* @see PolymorphicHasManyList * @see PolymorphicHasManyList
* *
* @todo Complete * @todo Complete
*
* @package framework
* @subpackage tests
*/ */
class PolymorphicHasManyListTest extends SapphireTest { class PolymorphicHasManyListTest extends SapphireTest {
// Borrow the model from DataObjectTest // Borrow the model from DataObjectTest
protected static $fixture_file = 'DataObjectTest.yml'; protected static $fixture_file = 'DataObjectTest.yml';
public function setUpOnce() { protected function getExtraDataObjects()
$this->extraDataObjects = DataObjectTest::$extra_data_objects; {
parent::setUpOnce(); return array_merge(
DataObjectTest::$extra_data_objects,
ManyManyListTest::$extra_data_objects
);
} }
public function testRelationshipEmptyOnNewRecords() { public function testRelationshipEmptyOnNewRecords() {
@ -38,7 +36,6 @@ class PolymorphicHasManyListTest extends SapphireTest {
* Test that DataList::relation works with PolymorphicHasManyList * Test that DataList::relation works with PolymorphicHasManyList
*/ */
public function testFilterRelation() { public function testFilterRelation() {
// Check that expected teams exist // Check that expected teams exist
$list = Team::get(); $list = Team::get();
$this->assertEquals( $this->assertEquals(
@ -51,8 +48,8 @@ class PolymorphicHasManyListTest extends SapphireTest {
$this->assertEquals(array('Damian', 'Mitch', 'Richard'), $fans->sort('Name')->column('Name')); $this->assertEquals(array('Damian', 'Mitch', 'Richard'), $fans->sort('Name')->column('Name'));
// Modify list of fans and retest // Modify list of fans and retest
$team1 = $this->objFromFixture('DataObjectTest_Team', 'team1'); $team1 = $this->objFromFixture(DataObjectTest\Team::class, 'team1');
$subteam1 = $this->objFromFixture('DataObjectTest_SubTeam', 'subteam1'); $subteam1 = $this->objFromFixture(DataObjectTest\SubTeam::class, 'subteam1');
$newFan1 = Fan::create(); $newFan1 = Fan::create();
$newFan1->Name = 'Bobby'; $newFan1->Name = 'Bobby';
$newFan1->write(); $newFan1->write();
@ -80,26 +77,26 @@ class PolymorphicHasManyListTest extends SapphireTest {
); );
// Test that each team has the correct fans // Test that each team has the correct fans
$team1 = $this->objFromFixture('DataObjectTest_Team', 'team1'); $team1 = $this->objFromFixture(DataObjectTest\Team::class, 'team1');
$subteam1 = $this->objFromFixture('DataObjectTest_SubTeam', 'subteam1'); $subteam1 = $this->objFromFixture(DataObjectTest\SubTeam::class, 'subteam1');
$this->assertEquals(array('Damian', 'Richard'), $team1->Fans()->sort('Name')->column('Name')); $this->assertEquals(array('Damian', 'Richard'), $team1->Fans()->sort('Name')->column('Name'));
$this->assertEquals(array('Mitch'), $subteam1->Fans()->sort('Name')->column('Name')); $this->assertEquals(array('Mitch'), $subteam1->Fans()->sort('Name')->column('Name'));
// Test that removing items from unrelated team has no effect // Test that removing items from unrelated team has no effect
$team1fan = $this->objFromFixture('DataObjectTest_Fan', 'fan1'); $team1fan = $this->objFromFixture(DataObjectTest\Fan::class, 'fan1');
$subteam1fan = $this->objFromFixture('DataObjectTest_Fan', 'fan4'); $subteam1fan = $this->objFromFixture(DataObjectTest\Fan::class, 'fan4');
$team1->Fans()->remove($subteam1fan); $team1->Fans()->remove($subteam1fan);
$subteam1->Fans()->remove($team1fan); $subteam1->Fans()->remove($team1fan);
$this->assertEquals(array('Damian', 'Richard'), $team1->Fans()->sort('Name')->column('Name')); $this->assertEquals(array('Damian', 'Richard'), $team1->Fans()->sort('Name')->column('Name'));
$this->assertEquals(array('Mitch'), $subteam1->Fans()->sort('Name')->column('Name')); $this->assertEquals(array('Mitch'), $subteam1->Fans()->sort('Name')->column('Name'));
$this->assertEquals($team1->ID, $team1fan->FavouriteID); $this->assertEquals($team1->ID, $team1fan->FavouriteID);
$this->assertEquals('DataObjectTest_Team', $team1fan->FavouriteClass); $this->assertEquals(DataObjectTest\Team::class, $team1fan->FavouriteClass);
$this->assertEquals($subteam1->ID, $subteam1fan->FavouriteID); $this->assertEquals($subteam1->ID, $subteam1fan->FavouriteID);
$this->assertEquals('DataObjectTest_SubTeam', $subteam1fan->FavouriteClass); $this->assertEquals(DataObjectTest\SubTeam::class, $subteam1fan->FavouriteClass);
// Test that removing items from the related team resets the has_one relations on the fan // Test that removing items from the related team resets the has_one relations on the fan
$team1fan = $this->objFromFixture('DataObjectTest_Fan', 'fan1'); $team1fan = $this->objFromFixture(DataObjectTest\Fan::class, 'fan1');
$subteam1fan = $this->objFromFixture('DataObjectTest_Fan', 'fan4'); $subteam1fan = $this->objFromFixture(DataObjectTest\Fan::class, 'fan4');
$team1->Fans()->remove($team1fan); $team1->Fans()->remove($team1fan);
$subteam1->Fans()->remove($subteam1fan); $subteam1->Fans()->remove($subteam1fan);
$this->assertEquals(array('Richard'), $team1->Fans()->sort('Name')->column('Name')); $this->assertEquals(array('Richard'), $team1->Fans()->sort('Name')->column('Name'));

View File

@ -14,6 +14,8 @@ use SilverStripe\ORM\ManyManyList;
*/ */
class TestObject extends DataObject implements TestOnly class TestObject extends DataObject implements TestOnly
{ {
private static $table_name = 'UnsavedRelationListTest_DataObject';
private static $db = array( private static $db = array(
'Name' => 'Varchar', 'Name' => 'Varchar',
); );

View File

@ -32,10 +32,9 @@ class VersionedTest extends SapphireTest {
VersionedTest\CustomTable::class, VersionedTest\CustomTable::class,
]; ];
public function setUpOnce() protected function getExtraDataObjects()
{ {
$this->extraDataObjects = static::$extra_data_objects; return static::$extra_data_objects;
parent::setUpOnce();
} }
public function testUniqueIndexes() { public function testUniqueIndexes() {
@ -139,9 +138,10 @@ class VersionedTest extends SapphireTest {
$obj = new VersionedTest\Subclass(); $obj = new VersionedTest\Subclass();
$obj->ExtraField = 'Foo'; // ensure that child version table gets written $obj->ExtraField = 'Foo'; // ensure that child version table gets written
$obj->write(); $obj->write();
$class = VersionedTest\TestObject::class;
$this->setExpectedException( $this->setExpectedException(
'InvalidArgumentException', 'InvalidArgumentException',
"Can't find VersionedTest_DataObject#{$obj->ID} in stage Live" "Can't find {$class}#{$obj->ID} in stage Live"
); );
// Fail publishing from live to stage // Fail publishing from live to stage
@ -198,14 +198,14 @@ class VersionedTest extends SapphireTest {
$targetPage->delete(); $targetPage->delete();
// Get all items, ignoring deleted // Get all items, ignoring deleted
$remainingPages = DataObject::get("VersionedTest_DataObject", "\"ParentID\" = 0", $remainingPages = DataObject::get(VersionedTest\TestObject::class, "\"ParentID\" = 0",
"\"VersionedTest_DataObject\".\"ID\" ASC"); "\"VersionedTest_DataObject\".\"ID\" ASC");
// Check that page 3 has gone // Check that page 3 has gone
$this->assertNotNull($remainingPages); $this->assertNotNull($remainingPages);
$this->assertEquals(array("Page 1", "Page 2", "Subclass Page 1"), $remainingPages->column('Title')); $this->assertEquals(array("Page 1", "Page 2", "Subclass Page 1"), $remainingPages->column('Title'));
// Get all including deleted // Get all including deleted
$allPages = Versioned::get_including_deleted("VersionedTest_DataObject", "\"ParentID\" = 0", $allPages = Versioned::get_including_deleted(VersionedTest\TestObject::class, "\"ParentID\" = 0",
"\"VersionedTest_DataObject\".\"ID\" ASC"); "\"VersionedTest_DataObject\".\"ID\" ASC");
// Check that page 3 is still there // Check that page 3 is still there
$this->assertEquals(array("Page 1", "Page 2", "Page 3", "Subclass Page 1"), $allPages->column('Title')); $this->assertEquals(array("Page 1", "Page 2", "Page 3", "Subclass Page 1"), $allPages->column('Title'));
@ -215,7 +215,7 @@ class VersionedTest extends SapphireTest {
// Check that this still works if we switch to reading the other stage // Check that this still works if we switch to reading the other stage
Versioned::set_stage(Versioned::LIVE); Versioned::set_stage(Versioned::LIVE);
$allPages = Versioned::get_including_deleted("VersionedTest_DataObject", "\"ParentID\" = 0", $allPages = Versioned::get_including_deleted(VersionedTest\TestObject::class, "\"ParentID\" = 0",
"\"VersionedTest_DataObject\".\"ID\" ASC"); "\"VersionedTest_DataObject\".\"ID\" ASC");
$this->assertEquals(array("Page 1", "Page 2", "Page 3", "Subclass Page 1"), $allPages->column('Title')); $this->assertEquals(array("Page 1", "Page 2", "Page 3", "Subclass Page 1"), $allPages->column('Title'));
@ -540,22 +540,22 @@ class VersionedTest extends SapphireTest {
$obj->Name = "test"; $obj->Name = "test";
$obj->write(); $obj->write();
$obj->Name = "test2"; $obj->Name = "test2";
$obj->ClassName = "VersionedTest_Subclass"; $obj->ClassName = VersionedTest\Subclass::class;
$obj->write(); $obj->write();
$subclassVersion = $obj->Version; $subclassVersion = $obj->Version;
$obj->Name = "test3"; $obj->Name = "test3";
$obj->ClassName = "VersionedTest_DataObject"; $obj->ClassName = VersionedTest\TestObject::class;
$obj->write(); $obj->write();
// We should be able to pass the subclass and still get the correct class back // We should be able to pass the subclass and still get the correct class back
$obj2 = Versioned::get_version("VersionedTest_Subclass", $obj->ID, $subclassVersion); $obj2 = Versioned::get_version(VersionedTest\Subclass::class, $obj->ID, $subclassVersion);
$this->assertInstanceOf("VersionedTest_Subclass", $obj2); $this->assertInstanceOf(VersionedTest\Subclass::class, $obj2);
$this->assertEquals("test2", $obj2->Name); $this->assertEquals("test2", $obj2->Name);
$obj3 = Versioned::get_latest_version("VersionedTest_Subclass", $obj->ID); $obj3 = Versioned::get_latest_version(VersionedTest\Subclass::class, $obj->ID);
$this->assertEquals("test3", $obj3->Name); $this->assertEquals("test3", $obj3->Name);
$this->assertInstanceOf("VersionedTest_DataObject", $obj3); $this->assertInstanceOf(VersionedTest\TestObject::class, $obj3);
} }
@ -588,7 +588,7 @@ class VersionedTest extends SapphireTest {
singleton(VersionedTest\Subclass::class)->flushCache(true); singleton(VersionedTest\Subclass::class)->flushCache(true);
Versioned::set_reading_mode('Archive.2006-01-01 00:00:00'); Versioned::set_reading_mode('Archive.2006-01-01 00:00:00');
$testPage2006 = DataObject::get(VersionedTest\Subclass::class)->filter(array('Title' => 'Archived page'))->first(); $testPage2006 = DataObject::get(VersionedTest\Subclass::class)->filter(array('Title' => 'Archived page'))->first();
$this->assertInstanceOf("VersionedTest_Subclass", $testPage2006); $this->assertInstanceOf(VersionedTest\Subclass::class, $testPage2006);
$this->assertEquals("2005", $testPage2006->ExtraField); $this->assertEquals("2005", $testPage2006->ExtraField);
$this->assertEquals("This is the content from 2005", $testPage2006->Content); $this->assertEquals("This is the content from 2005", $testPage2006->Content);
@ -596,7 +596,7 @@ class VersionedTest extends SapphireTest {
singleton(VersionedTest\Subclass::class)->flushCache(true); singleton(VersionedTest\Subclass::class)->flushCache(true);
Versioned::set_reading_mode('Archive.2008-01-01 00:00:00'); Versioned::set_reading_mode('Archive.2008-01-01 00:00:00');
$testPage2008 = DataObject::get(VersionedTest\Subclass::class)->filter(array('Title' => 'Archived page'))->first(); $testPage2008 = DataObject::get(VersionedTest\Subclass::class)->filter(array('Title' => 'Archived page'))->first();
$this->assertInstanceOf("VersionedTest_Subclass", $testPage2008); $this->assertInstanceOf(VersionedTest\Subclass::class, $testPage2008);
$this->assertEquals("2007", $testPage2008->ExtraField); $this->assertEquals("2007", $testPage2008->ExtraField);
$this->assertEquals("It's 2007 already!", $testPage2008->Content); $this->assertEquals("It's 2007 already!", $testPage2008->Content);
@ -605,7 +605,7 @@ class VersionedTest extends SapphireTest {
Versioned::set_reading_mode('Stage.Stage'); Versioned::set_reading_mode('Stage.Stage');
$testPageCurrent = DataObject::get(VersionedTest\Subclass::class)->filter(array('Title' => 'Archived page')) $testPageCurrent = DataObject::get(VersionedTest\Subclass::class)->filter(array('Title' => 'Archived page'))
->first(); ->first();
$this->assertInstanceOf("VersionedTest_Subclass", $testPageCurrent); $this->assertInstanceOf(VersionedTest\Subclass::class, $testPageCurrent);
$this->assertEquals("2009", $testPageCurrent->ExtraField); $this->assertEquals("2009", $testPageCurrent->ExtraField);
$this->assertEquals("I'm enjoying 2009", $testPageCurrent->Content); $this->assertEquals("I'm enjoying 2009", $testPageCurrent->Content);
} }
@ -872,7 +872,9 @@ class VersionedTest extends SapphireTest {
* @param int $version * @param int $version
*/ */
protected function assertRecordHasLatestVersion($record, $version) { protected function assertRecordHasLatestVersion($record, $version) {
foreach(ClassInfo::ancestry(get_class($record), true) as $table) { $schema = DataObject::getSchema();
foreach(ClassInfo::ancestry(get_class($record), true) as $class) {
$table = $schema->tableName($class);
$versionForClass = DB::prepared_query( $versionForClass = DB::prepared_query(
$sql = "SELECT MAX(\"Version\") FROM \"{$table}_Versions\" WHERE \"RecordID\" = ?", $sql = "SELECT MAX(\"Version\") FROM \"{$table}_Versions\" WHERE \"RecordID\" = ?",
array($record->ID) array($record->ID)
@ -957,7 +959,7 @@ class VersionedTest extends SapphireTest {
$this->assertRecordHasLatestVersion($record, 2); $this->assertRecordHasLatestVersion($record, 2);
} }
public function testVersionedHandlesRenamedDataObjectFields(){ public function testVersionedHandlesRenamedDataObjectFields() {
Config::inst()->remove(VersionedTest\RelatedWithoutversion::class,'db','Name','Varchar'); Config::inst()->remove(VersionedTest\RelatedWithoutversion::class,'db','Name','Varchar');
Config::inst()->update(VersionedTest\RelatedWithoutversion::class,'db',array( Config::inst()->update(VersionedTest\RelatedWithoutversion::class,'db',array(

View File

@ -2,15 +2,10 @@
namespace SilverStripe\Security\Tests; namespace SilverStripe\Security\Tests;
use SilverStripe\Security\GroupCsvBulkLoader; use SilverStripe\Security\GroupCsvBulkLoader;
use SilverStripe\Security\Group; use SilverStripe\Security\Group;
use SilverStripe\Dev\SapphireTest; use SilverStripe\Dev\SapphireTest;
/**
* @package framework
* @subpackage tests
*/
class GroupCsvBulkLoaderTest extends SapphireTest { class GroupCsvBulkLoaderTest extends SapphireTest {
protected static $fixture_file = 'GroupCsvBulkLoaderTest.yml'; protected static $fixture_file = 'GroupCsvBulkLoaderTest.yml';

View File

@ -4,10 +4,6 @@ namespace SilverStripe\Security\Tests\MemberTest;
use SilverStripe\Security\PasswordValidator; use SilverStripe\Security\PasswordValidator;
/**
* @package framework
* @subpackage tests
*/
class TestPasswordValidator extends PasswordValidator class TestPasswordValidator extends PasswordValidator
{ {
public function __construct() public function __construct()

View File

@ -2,12 +2,6 @@
namespace i18nTest; namespace i18nTest;
/**
* Created by PhpStorm.
* User: dmooyman
* Date: 17/06/16
* Time: 12:49 PM
*/
class i18nTestNamespacedClass class i18nTestNamespacedClass
{ {