diff --git a/src/Core/Extensible.php b/src/Core/Extensible.php index 79fe536b6..24b623912 100644 --- a/src/Core/Extensible.php +++ b/src/Core/Extensible.php @@ -388,6 +388,10 @@ trait Extensible if (!$strict && is_subclass_of($extension, $requiredExtension)) { return true; } + $inst = Injector::inst()->get($extension); + if ($inst instanceof $requiredExtension) { + return $strict ? strcasecmp(get_class($inst), $requiredExtension) === 0 : true; + } } return false; diff --git a/src/Forms/GridField/GridFieldLevelup.php b/src/Forms/GridField/GridFieldLevelup.php index d16d41a88..84d92af19 100644 --- a/src/Forms/GridField/GridFieldLevelup.php +++ b/src/Forms/GridField/GridFieldLevelup.php @@ -88,7 +88,7 @@ class GridFieldLevelup implements GridField_HTMLProvider $template = SSViewer::get_templates_by_class($this, '', __CLASS__); return array( 'before' => $forTemplate->renderWith($template), - ); + ); } public function setAttributes($attrs) diff --git a/src/includes/constants.php b/src/includes/constants.php index a619db5f2..277230b3d 100644 --- a/src/includes/constants.php +++ b/src/includes/constants.php @@ -139,11 +139,11 @@ if (!defined('BASE_URL')) { ) { $requestURI = $_SERVER['REQUEST_URI']; // Check if /base/public or /base are in the request - foreach ([$baseURL, dirname($baseURL)] as $candidate) { - if (stripos($requestURI, $candidate) === 0) { - return $candidate; - } + foreach ([$baseURL, dirname($baseURL)] as $candidate) { + if (stripos($requestURI, $candidate) === 0) { + return $candidate; } + } // Ambiguous return ''; } diff --git a/tests/behat/src/CmsUiContext.php b/tests/behat/src/CmsUiContext.php index 6797dc65f..1946f30cc 100644 --- a/tests/behat/src/CmsUiContext.php +++ b/tests/behat/src/CmsUiContext.php @@ -58,9 +58,9 @@ class CmsUiContext implements Context $timeoutMs = $this->getMainContext()->getAjaxTimeout(); $this->getSession()->wait( $timeoutMs, - "(". - "document.getElementsByClassName('cms-content-loading-overlay').length +". - "document.getElementsByClassName('cms-loading-container').length". + "(" . + "document.getElementsByClassName('cms-content-loading-overlay').length +" . + "document.getElementsByClassName('cms-loading-container').length" . ") == 0" ); } diff --git a/tests/php/Core/ObjectTest.php b/tests/php/Core/ObjectTest.php index 886a5cd0a..b3971e987 100644 --- a/tests/php/Core/ObjectTest.php +++ b/tests/php/Core/ObjectTest.php @@ -11,6 +11,7 @@ use SilverStripe\Core\Tests\ObjectTest\ExtendTest1; use SilverStripe\Core\Tests\ObjectTest\ExtendTest2; use SilverStripe\Core\Tests\ObjectTest\ExtendTest3; use SilverStripe\Core\Tests\ObjectTest\ExtendTest4; +use SilverStripe\Core\Tests\ObjectTest\ExtendTest5; use SilverStripe\Core\Tests\ObjectTest\ExtensionRemoveTest; use SilverStripe\Core\Tests\ObjectTest\ExtensionTest; use SilverStripe\Core\Tests\ObjectTest\ExtensionTest2; @@ -289,6 +290,13 @@ class ObjectTest extends SapphireTest $objectTest_ExtensionTest->hasExtension(ExtendTest3::class), "Extensions are detected with instance hasExtension() when added through add_extension()" ); + + // load in a custom implementation + Injector::inst()->registerService(new ExtendTest5(), ExtendTest4::class); + $this->assertTrue( + ExtensionTest3::has_extension(ExtendTest5::class), + "Injected sub-extensions are detected with static has_extension() when added through add_extension()" + ); // @todo At the moment, this does NOT remove the extension due to parameterized naming, // meaning the extension will remain added in further test cases diff --git a/tests/php/Core/ObjectTest/ExtendTest5.php b/tests/php/Core/ObjectTest/ExtendTest5.php new file mode 100644 index 000000000..814c192b7 --- /dev/null +++ b/tests/php/Core/ObjectTest/ExtendTest5.php @@ -0,0 +1,11 @@ +