diff --git a/code/Extension/FormSpamProtectionExtension.php b/code/Extension/FormSpamProtectionExtension.php index f365f45..3ff2422 100644 --- a/code/Extension/FormSpamProtectionExtension.php +++ b/code/Extension/FormSpamProtectionExtension.php @@ -2,6 +2,7 @@ namespace SilverStripe\SpamProtection\Extension; +use LogicException; use SilverStripe\Core\Config\Configurable; use SilverStripe\Core\Extension; use SilverStripe\Core\Injector\Injector; @@ -84,6 +85,7 @@ public static function get_protector($options = null) * Activates the spam protection module. * * @param array $options + * @throws LogicException when get_protector method returns NULL. * @return Object */ public function enableSpamProtection($options = array()) @@ -106,7 +108,11 @@ public function enableSpamProtection($options = array()) // set custom mapping on this form $protector = self::get_protector($options); - if (isset($options['mapping'])) { + if ($protector === null) { + throw new LogicException('No spam protector has been set. Null is not valid value.'); + } + + if ($protector && isset($options['mapping'])) { $protector->setFieldMapping($options['mapping']); } diff --git a/tests/FormSpamProtectionExtensionTest.php b/tests/FormSpamProtectionExtensionTest.php index 38d6071..2a24729 100644 --- a/tests/FormSpamProtectionExtensionTest.php +++ b/tests/FormSpamProtectionExtensionTest.php @@ -38,6 +38,14 @@ protected function setUp(): void $this->form->disableSecurityToken(); } + public function testEnableSpamProtectionThrowsException() + { + $this->expectException(LogicException::class); + $this->expectExceptionMessage('No spam protector has been set. Null is not valid value.'); + + $this->form->enableSpamProtection(); + } + public function testEnableSpamProtection() { Config::modify()->set(