mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 14:05:37 +02:00
Fix tests
This commit is contained in:
parent
39a29fa2f6
commit
aa491d9294
@ -365,12 +365,13 @@ class Director implements TemplateGlobalProvider
|
|||||||
};
|
};
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
$start = time();
|
||||||
// Call the handler with the configured middlewares
|
// Call the handler with the configured middlewares
|
||||||
$response = $this->callMiddleware($request, $handler);
|
$response = $this->callMiddleware($request, $handler);
|
||||||
|
$end = time();
|
||||||
// Note that if a different request was previously registered, this will now be lost
|
// Note that if a different request was previously registered, this will now be lost
|
||||||
// In these cases it's better to use Kernel::nest() prior to kicking off a nested request
|
// In these cases it's better to use Kernel::nest() prior to kicking off a nested request
|
||||||
|
$elapsed = $end - $start;
|
||||||
Injector::inst()->unregisterNamedObject(HTTPRequest::class);
|
Injector::inst()->unregisterNamedObject(HTTPRequest::class);
|
||||||
|
|
||||||
return $response;
|
return $response;
|
||||||
|
@ -54,12 +54,21 @@ trait HTTPMiddlewareAware
|
|||||||
*/
|
*/
|
||||||
protected function callMiddleware(HTTPRequest $request, callable $last)
|
protected function callMiddleware(HTTPRequest $request, callable $last)
|
||||||
{
|
{
|
||||||
|
$classes = array_map(function ($middle) {
|
||||||
|
return get_class($middle);
|
||||||
|
}, $this->getMiddlewares());
|
||||||
|
|
||||||
|
|
||||||
// Reverse middlewares
|
// Reverse middlewares
|
||||||
$next = $last;
|
$next = $last;
|
||||||
/** @var HTTPMiddleware $middleware */
|
/** @var HTTPMiddleware $middleware */
|
||||||
foreach (array_reverse($this->getMiddlewares()) as $middleware) {
|
foreach (array_reverse($this->getMiddlewares()) as $middleware) {
|
||||||
$next = function ($request) use ($middleware, $next) {
|
$next = function ($request) use ($middleware, $next) {
|
||||||
return $middleware->process($request, $next);
|
$start = time();
|
||||||
|
$value = $middleware->process($request, $next);
|
||||||
|
$end = time();
|
||||||
|
$elapsed = $end - $start;
|
||||||
|
return $value;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
return $next($request);
|
return $next($request);
|
||||||
|
@ -388,8 +388,9 @@ trait Extensible
|
|||||||
if (!$strict && is_subclass_of($extension, $requiredExtension)) {
|
if (!$strict && is_subclass_of($extension, $requiredExtension)) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
if (Injector::inst()->get($extension) instanceof $requiredExtension) {
|
$inst = Injector::inst()->get($extension);
|
||||||
return true;
|
if ($inst instanceof $requiredExtension) {
|
||||||
|
return $strict ? get_class($inst) === $requiredExtension : true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -11,6 +11,7 @@ use SilverStripe\Core\Tests\ObjectTest\ExtendTest1;
|
|||||||
use SilverStripe\Core\Tests\ObjectTest\ExtendTest2;
|
use SilverStripe\Core\Tests\ObjectTest\ExtendTest2;
|
||||||
use SilverStripe\Core\Tests\ObjectTest\ExtendTest3;
|
use SilverStripe\Core\Tests\ObjectTest\ExtendTest3;
|
||||||
use SilverStripe\Core\Tests\ObjectTest\ExtendTest4;
|
use SilverStripe\Core\Tests\ObjectTest\ExtendTest4;
|
||||||
|
use SilverStripe\Core\Tests\ObjectTest\ExtendTest5;
|
||||||
use SilverStripe\Core\Tests\ObjectTest\ExtensionRemoveTest;
|
use SilverStripe\Core\Tests\ObjectTest\ExtensionRemoveTest;
|
||||||
use SilverStripe\Core\Tests\ObjectTest\ExtensionTest;
|
use SilverStripe\Core\Tests\ObjectTest\ExtensionTest;
|
||||||
use SilverStripe\Core\Tests\ObjectTest\ExtensionTest2;
|
use SilverStripe\Core\Tests\ObjectTest\ExtensionTest2;
|
||||||
@ -290,6 +291,13 @@ class ObjectTest extends SapphireTest
|
|||||||
"Extensions are detected with instance hasExtension() when added through add_extension()"
|
"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,
|
// @todo At the moment, this does NOT remove the extension due to parameterized naming,
|
||||||
// meaning the extension will remain added in further test cases
|
// meaning the extension will remain added in further test cases
|
||||||
ExtensionTest::remove_extension(ExtendTest3::class);
|
ExtensionTest::remove_extension(ExtendTest3::class);
|
||||||
|
11
tests/php/Core/ObjectTest/ExtendTest5.php
Normal file
11
tests/php/Core/ObjectTest/ExtendTest5.php
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace SilverStripe\Core\Tests\ObjectTest;
|
||||||
|
|
||||||
|
class ExtendTest5 extends ExtendTest4
|
||||||
|
{
|
||||||
|
public function extendableMethod($argument = null)
|
||||||
|
{
|
||||||
|
return "ExtendTest5($argument)";
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user