From 7837481d21f37e6de9876124c014c05620bb6f3b Mon Sep 17 00:00:00 2001 From: Ian Morland Date: Wed, 11 Oct 2023 08:42:49 +0100 Subject: [PATCH] chore: create tests to highlight the conditional instantiation problem --- .../integration/extenders/ConditionalTest.php | 47 ++++++++++++++++++- 1 file changed, 46 insertions(+), 1 deletion(-) diff --git a/framework/core/tests/integration/extenders/ConditionalTest.php b/framework/core/tests/integration/extenders/ConditionalTest.php index ec96423e1f..bed5f6988d 100644 --- a/framework/core/tests/integration/extenders/ConditionalTest.php +++ b/framework/core/tests/integration/extenders/ConditionalTest.php @@ -12,9 +12,12 @@ use Exception; use Flarum\Api\Serializer\ForumSerializer; use Flarum\Extend; +use Flarum\Extend\ExtenderInterface; +use Flarum\Extension\Extension; use Flarum\Extension\ExtensionManager; use Flarum\Testing\integration\RetrievesAuthorizedUsers; use Flarum\Testing\integration\TestCase; +use Illuminate\Contracts\Container\Container; class ConditionalTest extends TestCase { @@ -144,7 +147,7 @@ public function conditional_injects_dependencies_to_condition_callable() $this->extend( (new Extend\Conditional()) ->when(function (?ExtensionManager $extensions) { - if (! $extensions) { + if (!$extensions) { throw new Exception('ExtensionManager not injected'); } }, [ @@ -159,4 +162,46 @@ public function conditional_injects_dependencies_to_condition_callable() $this->app(); } + + /** @test */ + public function conditional_does_not_instantiate_extender_if_condition_is_false() + { + $this->extend( + (new Extend\Conditional()) + ->when(false, [ + new TestExtender() + ]) + ); + + $this->app(); + } + + /** @test */ + public function conditional_does_instantiate_extender_if_condition_is_true() + { + $this->expectException(Exception::class); + $this->expectExceptionMessage('TestExtender was instantiated!'); + + $this->extend( + (new Extend\Conditional()) + ->when(true, [ + new TestExtender() + ]) + ); + + $this->app(); + } +} + +class TestExtender implements ExtenderInterface +{ + public function __construct() + { + throw new Exception('TestExtender was instantiated!'); + } + + public function extend(Container $container, Extension $extension = null) + { + // This method can be left empty for this test. + } }