mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 14:05:37 +02:00
FIX Harden hasMethod() against invalid values
This method should typehint the incoming value once union types are available, but for now this ensures that method_exists() is not called on scalar values, which is unsupported in PHP 8.
This commit is contained in:
parent
91f831cd0b
commit
e89ae93ac9
@ -400,7 +400,7 @@ class ClassInfo
|
|||||||
*/
|
*/
|
||||||
public static function hasMethod($object, $method)
|
public static function hasMethod($object, $method)
|
||||||
{
|
{
|
||||||
if (empty($object)) {
|
if (empty($object) || (!is_object($object) && !is_string($object))) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (method_exists($object, $method)) {
|
if (method_exists($object, $method)) {
|
||||||
|
@ -2,6 +2,7 @@
|
|||||||
|
|
||||||
namespace SilverStripe\Core\Tests;
|
namespace SilverStripe\Core\Tests;
|
||||||
|
|
||||||
|
use DateTime;
|
||||||
use ReflectionException;
|
use ReflectionException;
|
||||||
use SilverStripe\Core\ClassInfo;
|
use SilverStripe\Core\ClassInfo;
|
||||||
use SilverStripe\Core\Tests\ClassInfoTest\BaseClass;
|
use SilverStripe\Core\Tests\ClassInfoTest\BaseClass;
|
||||||
@ -15,6 +16,7 @@ use SilverStripe\Core\Tests\ClassInfoTest\ExtensionTest1;
|
|||||||
use SilverStripe\Core\Tests\ClassInfoTest\ExtensionTest2;
|
use SilverStripe\Core\Tests\ClassInfoTest\ExtensionTest2;
|
||||||
use SilverStripe\Core\Tests\ClassInfoTest\GrandChildClass;
|
use SilverStripe\Core\Tests\ClassInfoTest\GrandChildClass;
|
||||||
use SilverStripe\Core\Tests\ClassInfoTest\HasFields;
|
use SilverStripe\Core\Tests\ClassInfoTest\HasFields;
|
||||||
|
use SilverStripe\Core\Tests\ClassInfoTest\HasMethod;
|
||||||
use SilverStripe\Core\Tests\ClassInfoTest\NoFields;
|
use SilverStripe\Core\Tests\ClassInfoTest\NoFields;
|
||||||
use SilverStripe\Core\Tests\ClassInfoTest\WithCustomTable;
|
use SilverStripe\Core\Tests\ClassInfoTest\WithCustomTable;
|
||||||
use SilverStripe\Core\Tests\ClassInfoTest\WithRelation;
|
use SilverStripe\Core\Tests\ClassInfoTest\WithRelation;
|
||||||
@ -266,9 +268,57 @@ class ClassInfoTest extends SapphireTest
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/** @dataProvider provideHasMethodCases */
|
||||||
* @dataProvider provideClassSpecCases
|
public function testHasMethod($object, $method, $output)
|
||||||
*/
|
{
|
||||||
|
$this->assertEquals(
|
||||||
|
$output,
|
||||||
|
ClassInfo::hasMethod($object, $method)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function provideHasMethodCases()
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'Basic object' => [
|
||||||
|
new DateTime(),
|
||||||
|
'format',
|
||||||
|
true,
|
||||||
|
],
|
||||||
|
'CustomMethod object' => [
|
||||||
|
new HasMethod(),
|
||||||
|
'example',
|
||||||
|
true,
|
||||||
|
],
|
||||||
|
'Class Name' => [
|
||||||
|
'DateTime',
|
||||||
|
'format',
|
||||||
|
true,
|
||||||
|
],
|
||||||
|
'FQCN' => [
|
||||||
|
'\DateTime',
|
||||||
|
'format',
|
||||||
|
true,
|
||||||
|
],
|
||||||
|
'Invalid FQCN' => [
|
||||||
|
'--GreatTime',
|
||||||
|
'format',
|
||||||
|
false,
|
||||||
|
],
|
||||||
|
'Integer' => [
|
||||||
|
1,
|
||||||
|
'format',
|
||||||
|
false,
|
||||||
|
],
|
||||||
|
'Array' => [
|
||||||
|
['\DateTime'],
|
||||||
|
'format',
|
||||||
|
false,
|
||||||
|
],
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
/** @dataProvider provideClassSpecCases */
|
||||||
public function testParseClassSpec($input, $output)
|
public function testParseClassSpec($input, $output)
|
||||||
{
|
{
|
||||||
$this->assertEquals(
|
$this->assertEquals(
|
||||||
|
19
tests/php/Core/ClassInfoTest/HasMethod.php
Normal file
19
tests/php/Core/ClassInfoTest/HasMethod.php
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace SilverStripe\Core\Tests\ClassInfoTest;
|
||||||
|
|
||||||
|
use SilverStripe\Core\CustomMethods;
|
||||||
|
use SilverStripe\Dev\TestOnly;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Example of class with hasMethod() implementation
|
||||||
|
*/
|
||||||
|
class HasMethod implements TestOnly
|
||||||
|
{
|
||||||
|
use CustomMethods;
|
||||||
|
|
||||||
|
public function example()
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user