2009-02-02 00:49:53 +01:00
|
|
|
<?php
|
2014-08-18 05:39:42 +02:00
|
|
|
|
2016-10-14 03:30:05 +02:00
|
|
|
namespace SilverStripe\Core\Tests;
|
|
|
|
|
2017-05-17 07:40:13 +02:00
|
|
|
use ReflectionException;
|
2016-10-14 03:30:05 +02:00
|
|
|
use SilverStripe\Core\Tests\ClassInfoTest\BaseClass;
|
|
|
|
use SilverStripe\Core\Tests\ClassInfoTest\BaseDataClass;
|
|
|
|
use SilverStripe\Core\Tests\ClassInfoTest\ChildClass;
|
|
|
|
use SilverStripe\Core\Tests\ClassInfoTest\GrandChildClass;
|
|
|
|
use SilverStripe\Core\Tests\ClassInfoTest\HasFields;
|
|
|
|
use SilverStripe\Core\Tests\ClassInfoTest\NoFields;
|
|
|
|
use SilverStripe\Core\Tests\ClassInfoTest\WithCustomTable;
|
|
|
|
use SilverStripe\Core\Tests\ClassInfoTest\WithRelation;
|
2016-08-19 00:51:35 +02:00
|
|
|
use SilverStripe\ORM\ArrayLib;
|
|
|
|
use SilverStripe\Core\ClassInfo;
|
|
|
|
use SilverStripe\Dev\SapphireTest;
|
2016-10-14 03:30:05 +02:00
|
|
|
use SilverStripe\ORM\DataObject;
|
|
|
|
use SilverStripe\View\ViewableData;
|
2016-06-15 06:03:16 +02:00
|
|
|
|
2016-12-16 05:34:21 +01:00
|
|
|
class ClassInfoTest extends SapphireTest
|
|
|
|
{
|
|
|
|
|
2017-03-24 12:17:26 +01:00
|
|
|
protected static $extra_dataobjects = array(
|
2016-12-16 05:34:21 +01:00
|
|
|
BaseClass::class,
|
|
|
|
BaseDataClass::class,
|
|
|
|
ChildClass::class,
|
|
|
|
GrandChildClass::class,
|
|
|
|
HasFields::class,
|
|
|
|
NoFields::class,
|
|
|
|
WithCustomTable::class,
|
|
|
|
WithRelation::class,
|
|
|
|
);
|
|
|
|
|
2017-03-24 04:00:54 +01:00
|
|
|
protected function setUp()
|
2016-12-16 05:34:21 +01:00
|
|
|
{
|
|
|
|
parent::setUp();
|
|
|
|
ClassInfo::reset_db_cache();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testExists()
|
|
|
|
{
|
2017-05-17 07:40:13 +02:00
|
|
|
$this->assertTrue(ClassInfo::exists(ClassInfo::class));
|
|
|
|
$this->assertTrue(ClassInfo::exists('SilverStripe\\Core\\classinfo'));
|
2016-12-16 05:34:21 +01:00
|
|
|
$this->assertTrue(ClassInfo::exists('SilverStripe\\Core\\Tests\\ClassInfoTest'));
|
|
|
|
$this->assertTrue(ClassInfo::exists('SilverStripe\\Core\\Tests\\CLASSINFOTEST'));
|
|
|
|
$this->assertTrue(ClassInfo::exists('stdClass'));
|
|
|
|
$this->assertTrue(ClassInfo::exists('stdCLASS'));
|
|
|
|
$this->assertFalse(ClassInfo::exists('SomeNonExistantClass'));
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testSubclassesFor()
|
|
|
|
{
|
|
|
|
$this->assertEquals(
|
|
|
|
array(
|
|
|
|
BaseClass::class => BaseClass::class,
|
|
|
|
ChildClass::class => ChildClass::class,
|
|
|
|
GrandChildClass::class => GrandChildClass::class
|
|
|
|
),
|
|
|
|
ClassInfo::subclassesFor(BaseClass::class),
|
|
|
|
'ClassInfo::subclassesFor() returns only direct subclasses and doesnt include base class'
|
|
|
|
);
|
|
|
|
ClassInfo::reset_db_cache();
|
|
|
|
$this->assertEquals(
|
|
|
|
array(
|
|
|
|
BaseClass::class => BaseClass::class,
|
|
|
|
ChildClass::class => ChildClass::class,
|
|
|
|
GrandChildClass::class => GrandChildClass::class
|
|
|
|
),
|
|
|
|
ClassInfo::subclassesFor('silverstripe\\core\\tests\\classinfotest\\baseclass'),
|
|
|
|
'ClassInfo::subclassesFor() is acting in a case sensitive way when it should not'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testClassName()
|
|
|
|
{
|
|
|
|
$this->assertEquals(
|
|
|
|
ClassInfoTest::class,
|
|
|
|
ClassInfo::class_name($this)
|
|
|
|
);
|
|
|
|
$this->assertEquals(
|
|
|
|
ClassInfoTest::class,
|
|
|
|
ClassInfo::class_name('SilverStripe\\Core\\Tests\\ClassInfoTest')
|
|
|
|
);
|
|
|
|
$this->assertEquals(
|
|
|
|
ClassInfoTest::class,
|
|
|
|
ClassInfo::class_name('SilverStripe\\Core\\TESTS\\CLaSsInfOTEsT')
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testNonClassName()
|
|
|
|
{
|
2017-05-17 07:40:13 +02:00
|
|
|
$this->expectException(ReflectionException::class);
|
|
|
|
$this->expectExceptionMessage('Class IAmAClassThatDoesNotExist does not exist');
|
2016-12-16 05:34:21 +01:00
|
|
|
$this->assertEquals('IAmAClassThatDoesNotExist', ClassInfo::class_name('IAmAClassThatDoesNotExist'));
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testClassesForFolder()
|
|
|
|
{
|
|
|
|
//$baseFolder = Director::baseFolder() . '/' . FRAMEWORK_DIR . '/tests/_ClassInfoTest';
|
|
|
|
//$manifestInfo = ManifestBuilder::get_manifest_info($baseFolder);
|
|
|
|
|
|
|
|
$classes = ClassInfo::classes_for_folder(ltrim(FRAMEWORK_DIR . '/tests', '/'));
|
|
|
|
$this->assertContains(
|
|
|
|
'silverstripe\\core\\tests\\classinfotest',
|
|
|
|
$classes,
|
|
|
|
'ClassInfo::classes_for_folder() returns classes matching the filename'
|
|
|
|
);
|
|
|
|
$this->assertContains(
|
|
|
|
'silverstripe\\core\\tests\\classinfotest\\baseclass',
|
|
|
|
$classes,
|
|
|
|
'ClassInfo::classes_for_folder() returns additional classes not matching the filename'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @covers \SilverStripe\Core\ClassInfo::ancestry()
|
|
|
|
*/
|
|
|
|
public function testAncestry()
|
|
|
|
{
|
|
|
|
$ancestry = ClassInfo::ancestry(ChildClass::class);
|
2017-05-17 07:40:13 +02:00
|
|
|
$expect = ArrayLib::valuekey([
|
2016-12-16 05:34:21 +01:00
|
|
|
ViewableData::class,
|
|
|
|
DataObject::class,
|
|
|
|
BaseClass::class,
|
|
|
|
ChildClass::class,
|
2017-05-17 07:40:13 +02:00
|
|
|
]);
|
2016-12-16 05:34:21 +01:00
|
|
|
$this->assertEquals($expect, $ancestry);
|
|
|
|
|
|
|
|
ClassInfo::reset_db_cache();
|
|
|
|
$this->assertEquals(
|
|
|
|
$expect,
|
|
|
|
ClassInfo::ancestry('silverstripe\\core\\tests\\classINFOtest\\Childclass')
|
|
|
|
);
|
|
|
|
|
|
|
|
ClassInfo::reset_db_cache();
|
|
|
|
$ancestry = ClassInfo::ancestry(ChildClass::class, true);
|
|
|
|
$this->assertEquals(
|
|
|
|
array(BaseClass::class => BaseClass::class),
|
|
|
|
$ancestry,
|
|
|
|
'$tablesOnly option excludes memory-only inheritance classes'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @covers \SilverStripe\Core\ClassInfo::dataClassesFor()
|
|
|
|
*/
|
|
|
|
public function testDataClassesFor()
|
|
|
|
{
|
|
|
|
$expect = array(
|
|
|
|
BaseDataClass::class => BaseDataClass::class,
|
|
|
|
HasFields::class => HasFields::class,
|
|
|
|
WithRelation::class => WithRelation::class,
|
|
|
|
WithCustomTable::class => WithCustomTable::class,
|
|
|
|
);
|
|
|
|
|
|
|
|
$classes = array(
|
|
|
|
BaseDataClass::class,
|
|
|
|
NoFields::class,
|
|
|
|
HasFields::class,
|
|
|
|
);
|
|
|
|
|
|
|
|
ClassInfo::reset_db_cache();
|
|
|
|
$this->assertEquals($expect, ClassInfo::dataClassesFor($classes[0]));
|
|
|
|
ClassInfo::reset_db_cache();
|
|
|
|
$this->assertEquals($expect, ClassInfo::dataClassesFor(strtoupper($classes[0])));
|
|
|
|
ClassInfo::reset_db_cache();
|
|
|
|
$this->assertEquals($expect, ClassInfo::dataClassesFor($classes[1]));
|
|
|
|
|
|
|
|
$expect = array(
|
|
|
|
BaseDataClass::class => BaseDataClass::class,
|
|
|
|
HasFields::class => HasFields::class,
|
|
|
|
);
|
|
|
|
|
|
|
|
ClassInfo::reset_db_cache();
|
|
|
|
$this->assertEquals($expect, ClassInfo::dataClassesFor($classes[2]));
|
|
|
|
ClassInfo::reset_db_cache();
|
|
|
|
$this->assertEquals($expect, ClassInfo::dataClassesFor(strtolower($classes[2])));
|
|
|
|
}
|
2009-02-02 00:49:53 +01:00
|
|
|
}
|