diff --git a/src/Handler/EmbeddedShortcodeHandler.php b/src/Handler/EmbeddedShortcodeHandler.php index d42fbd2..4c1509e 100644 --- a/src/Handler/EmbeddedShortcodeHandler.php +++ b/src/Handler/EmbeddedShortcodeHandler.php @@ -103,7 +103,7 @@ private function validateControllerName(string $controllerName): void } $callableFragments = explode('::', $controllerName); - if (!\is_array($callableFragments) || !isset($callableFragments[1]) || !method_exists($callableFragments[0], $callableFragments[1])) { + if (!\is_array($callableFragments) || count($callableFragments) !== 2 || !method_exists($callableFragments[0], $callableFragments[1])) { throw new InvalidArgumentException('The controller method: "'.$controllerName.'" does not exist.'); } } diff --git a/tests/Functional/EmbeddedShortcodeHandlerTest.php b/tests/Functional/EmbeddedShortcodeHandlerTest.php index b814d63..23a7476 100644 --- a/tests/Functional/EmbeddedShortcodeHandlerTest.php +++ b/tests/Functional/EmbeddedShortcodeHandlerTest.php @@ -93,6 +93,7 @@ public static function provideControllerNames(): Generator yield 'Missing method name' => [ShortcodeTestController::class]; yield 'Not existing method' => [ShortcodeTestController::class.'_notExistingMethod']; yield 'Missing class' => ['ThisClassDoesNotExist']; + yield 'Valid reference followed by a second scope resolution operator' => [ShortcodeTestController::class.'::test::']; } private function processShortcodes(string $content, ?Request $request = null): string