mirror of
https://github.com/silverstripe/silverstripe-spamprotection.git
synced 2024-10-22 14:05:59 +02:00
136 lines
4.0 KiB
PHP
136 lines
4.0 KiB
PHP
<?php
|
|
|
|
class EditableSpamProtectionFieldTest extends SapphireTest
|
|
{
|
|
|
|
protected $usesDatabase = true;
|
|
|
|
public function setUp()
|
|
{
|
|
parent::setUp();
|
|
|
|
if (!class_exists('EditableSpamProtectionField')) {
|
|
$this->markTestSkipped('"userforms" module not installed');
|
|
}
|
|
|
|
Config::inst()->update(
|
|
'FormSpamProtectionExtension',
|
|
'default_spam_protector',
|
|
'EditableSpamProtectionFieldTest_Protector'
|
|
);
|
|
}
|
|
|
|
public function testValidateFieldDoesntAddErrorOnSuccess()
|
|
{
|
|
$formMock = $this->getFormMock();
|
|
$formFieldMock = $this->getEditableFormFieldMock();
|
|
|
|
$formFieldMock
|
|
->getFormField() // mock
|
|
->expects($this->once())
|
|
->method('validate')
|
|
->will($this->returnValue(true));
|
|
|
|
$formMock
|
|
->expects($this->never())
|
|
->method('addErrorMessage');
|
|
|
|
$formFieldMock->validateField(array('MyField' => null), $formMock);
|
|
}
|
|
|
|
public function testValidateFieldAddsErrorFromField()
|
|
{
|
|
$formMock = $this->getFormMock();
|
|
$formFieldMock = $this->getEditableFormFieldMock();
|
|
|
|
$formFieldMock
|
|
->getFormField() // mock
|
|
->expects($this->once())
|
|
->method('validate')
|
|
->will($this->returnValue(false));
|
|
|
|
$formMock->getValidator()->validationError('MyField', 'some field message', 'required');
|
|
|
|
$formMock
|
|
->expects($this->once())
|
|
->method('addErrorMessage')
|
|
->with($this->anything(), $this->stringContains('some field message'), $this->anything(), $this->anything());
|
|
;
|
|
|
|
$formFieldMock->validateField(array('MyField' => null), $formMock);
|
|
}
|
|
|
|
public function testValidateFieldAddsDefaultError()
|
|
{
|
|
$formMock = $this->getFormMock();
|
|
$formFieldMock = $this->getEditableFormFieldMock();
|
|
|
|
$formFieldMock
|
|
->getFormField() // mock
|
|
->expects($this->once())
|
|
->method('validate')
|
|
->will($this->returnValue(false));
|
|
|
|
// field doesn't set any validation errors here
|
|
|
|
$formMock
|
|
->expects($this->once())
|
|
->method('addErrorMessage')
|
|
->with($this->anything(), $this->stringContains('default error message'), $this->anything(), $this->anything());
|
|
|
|
$formFieldMock->validateField(array('MyField' => null), $formMock);
|
|
}
|
|
|
|
public function testSpamConfigurationShowsInCms()
|
|
{
|
|
$field = $this->getEditableFormFieldMock();
|
|
$fields = $field->getCMSFields();
|
|
|
|
$this->assertInstanceOf('FieldGroup', $fields->fieldByName('Root.Main.SpamFieldMapping'));
|
|
}
|
|
|
|
public function testSpamMapSettingsAreSerialised()
|
|
{
|
|
$field = $this->getEditableFormFieldMock();
|
|
$field->SpamFieldSettings = json_encode(array('foo' => 'bar', 'bar' => 'baz'));
|
|
$field->write();
|
|
|
|
$this->assertJson($field->SpamFieldSettings);
|
|
$this->assertSame('bar', $field->spamMapValue('foo'));
|
|
$this->assertSame('baz', $field->spamMapValue('bar'));
|
|
}
|
|
|
|
protected function getFormMock()
|
|
{
|
|
$formMock = $this->getMockBuilder('Form', array('addErrorMessage'))
|
|
->disableOriginalConstructor()
|
|
->getMock();
|
|
$formMock
|
|
->expects($this->any())
|
|
->method('getValidator')
|
|
->will($this->returnValue(new RequiredFields()));
|
|
|
|
return $formMock;
|
|
}
|
|
|
|
protected function getEditableFormFieldMock()
|
|
{
|
|
$page = new UserDefinedForm();
|
|
$page->write();
|
|
|
|
$formFieldMock = $this->getMockBuilder('TextField')
|
|
->disableOriginalConstructor()
|
|
->getMock();
|
|
|
|
$editableFormFieldMock = new EditableSpamProtectionField(array(
|
|
'ParentID' => $page->ID,
|
|
'Name' => 'MyField',
|
|
'CustomErrorMessage' => 'default error message'
|
|
));
|
|
$editableFormFieldMock->write();
|
|
$editableFormFieldMock->setFormField($formFieldMock);
|
|
|
|
return $editableFormFieldMock;
|
|
}
|
|
}
|