mirror of
https://github.com/silverstripe/silverstripe-userforms.git
synced 2024-10-22 17:05:42 +02:00
API Upgrade test classes, remove tests for obsolete classes
This commit is contained in:
parent
b27fdcb7f0
commit
b8d6ac336f
@ -2,20 +2,13 @@
|
|||||||
|
|
||||||
namespace SilverStripe\UserForms\Test\Form;
|
namespace SilverStripe\UserForms\Test\Form;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
use SilverStripe\UserForms\Model\UserDefinedForm;
|
|
||||||
use SilverStripe\CMS\Controllers\ModelAsController;
|
use SilverStripe\CMS\Controllers\ModelAsController;
|
||||||
use SilverStripe\UserForms\Form\UserForm;
|
|
||||||
use SilverStripe\Dev\SapphireTest;
|
use SilverStripe\Dev\SapphireTest;
|
||||||
|
use SilverStripe\UserForms\Model\UserDefinedForm;
|
||||||
|
use SilverStripe\UserForms\Form\UserForm;
|
||||||
|
|
||||||
|
|
||||||
class UserFormTest extends SapphireTest
|
class UserFormTest extends SapphireTest
|
||||||
{
|
{
|
||||||
|
|
||||||
protected static $fixture_file = 'UserDefinedFormTest.yml';
|
protected static $fixture_file = 'UserDefinedFormTest.yml';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -2,19 +2,14 @@
|
|||||||
|
|
||||||
namespace SilverStripe\UserForms\Test\FormField;
|
namespace SilverStripe\UserForms\Test\FormField;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
use SilverStripe\UserForms\FormField\UserFormsCheckboxSetField;
|
|
||||||
use SilverStripe\Forms\RequiredFields;
|
|
||||||
use SilverStripe\Dev\SapphireTest;
|
use SilverStripe\Dev\SapphireTest;
|
||||||
|
use SilverStripe\Forms\RequiredFields;
|
||||||
|
use SilverStripe\UserForms\FormField\UserFormsCheckboxSetField;
|
||||||
|
|
||||||
class UserFormsCheckboxSetFieldTest extends SapphireTest
|
class UserFormsCheckboxSetFieldTest extends SapphireTest
|
||||||
{
|
{
|
||||||
public function testValidate() {
|
public function testValidate() {
|
||||||
$field = new UserFormsCheckboxSetField('Field', 'My field', array('One' => 'One', 'Two' => 'Two'));
|
$field = new UserFormsCheckboxSetField('Field', 'My field', ['One' => 'One', 'Two' => 'Two']);
|
||||||
$validator = new RequiredFields();
|
$validator = new RequiredFields();
|
||||||
|
|
||||||
// String values
|
// String values
|
||||||
@ -37,4 +32,4 @@ class UserFormsCheckboxSetFieldTest extends SapphireTest
|
|||||||
$field->setValue(array('Three', 'Four'));
|
$field->setValue(array('Three', 'Four'));
|
||||||
$this->assertFalse($field->validate($validator));
|
$this->assertFalse($field->validate($validator));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2,18 +2,15 @@
|
|||||||
|
|
||||||
namespace SilverStripe\UserForms\Test\Model;
|
namespace SilverStripe\UserForms\Test\Model;
|
||||||
|
|
||||||
|
|
||||||
use SilverStripe\UserForms\Model\EditableCustomRule;
|
|
||||||
use SilverStripe\Dev\SapphireTest;
|
use SilverStripe\Dev\SapphireTest;
|
||||||
|
use SilverStripe\UserForms\Model\EditableCustomRule;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Class EditableCustomRulesTest
|
* Class EditableCustomRulesTest
|
||||||
*/
|
*/
|
||||||
class EditableCustomRuleTest extends SapphireTest
|
class EditableCustomRuleTest extends SapphireTest
|
||||||
{
|
{
|
||||||
protected static $fixture_file = 'userforms/tests/EditableCustomRuleTest.yml';
|
protected static $fixture_file = 'EditableCustomRuleTest.yml';
|
||||||
|
|
||||||
public function testBuildExpression()
|
public function testBuildExpression()
|
||||||
{
|
{
|
||||||
@ -24,15 +21,18 @@ class EditableCustomRuleTest extends SapphireTest
|
|||||||
//Dropdowns expect change event
|
//Dropdowns expect change event
|
||||||
$this->assertEquals('change', $result1['event']);
|
$this->assertEquals('change', $result1['event']);
|
||||||
$this->assertNotEmpty($result1['operation']);
|
$this->assertNotEmpty($result1['operation']);
|
||||||
|
|
||||||
//Check for equals sign
|
//Check for equals sign
|
||||||
$this->assertContains('==', $result1['operation']);
|
$this->assertContains('==', $result1['operation']);
|
||||||
|
|
||||||
/** @var EditableCustomRule $rule2 */
|
/** @var EditableCustomRule $rule2 */
|
||||||
$rule2 = $this->objFromFixture(EditableCustomRule::class, 'rule2');
|
$rule2 = $this->objFromFixture(EditableCustomRule::class, 'rule2');
|
||||||
$result2 = $rule2->buildExpression();
|
$result2 = $rule2->buildExpression();
|
||||||
|
|
||||||
//TextField expect change event
|
//TextField expect change event
|
||||||
$this->assertEquals('keyup', $result2['event']);
|
$this->assertEquals('keyup', $result2['event']);
|
||||||
$this->assertNotEmpty($result2['operation']);
|
$this->assertNotEmpty($result2['operation']);
|
||||||
|
|
||||||
//Check for greater than sign
|
//Check for greater than sign
|
||||||
$this->assertContains('>', $result2['operation']);
|
$this->assertContains('>', $result2['operation']);
|
||||||
}
|
}
|
||||||
|
@ -1,30 +1,30 @@
|
|||||||
EditableFormField:
|
SilverStripe\UserForms\Model\EditableFormField:
|
||||||
countryDropdown:
|
countryDropdown:
|
||||||
ClassName: EditableCountryDropdownField
|
ClassName: SilverStripe\UserForms\Model\EditableFormField\EditableCountryDropdownField
|
||||||
Name: CountrySelection
|
Name: CountrySelection
|
||||||
Title: "Choose your country"
|
Title: "Choose your country"
|
||||||
DisplayRulesConjunction: And
|
DisplayRulesConjunction: And
|
||||||
ShowOnLoad: false
|
ShowOnLoad: false
|
||||||
irdNumberField:
|
irdNumberField:
|
||||||
ClassName: EditableTextField
|
ClassName: SilverStripe\UserForms\Model\EditableFormField\EditableTextField
|
||||||
Name: IRDNumber
|
Name: IRDNumber
|
||||||
Title: "Enter your IRD Number"
|
Title: "Enter your IRD Number"
|
||||||
countryTextField:
|
countryTextField:
|
||||||
ClassName: EditableTextField
|
ClassName: SilverStripe\UserForms\Model\EditableFormField\EditableTextField
|
||||||
Name: CountryTextSelection
|
Name: CountryTextSelection
|
||||||
Title: "Enter your country (2 digit prefix)"
|
Title: "Enter your country (2 digit prefix)"
|
||||||
DisplayRulesConjunction: And
|
DisplayRulesConjunction: And
|
||||||
ShowOnLoad: false
|
ShowOnLoad: false
|
||||||
EditableCustomRule:
|
SilverStripe\UserForms\Model\EditableCustomRule:
|
||||||
rule1:
|
rule1:
|
||||||
Display: Show
|
Display: Show
|
||||||
ConditionOption: HasValue
|
ConditionOption: HasValue
|
||||||
FieldValue: NZ
|
FieldValue: NZ
|
||||||
ConditionField: =>EditableFormField.countryDropdown
|
ConditionField: =>SilverStripe\UserForms\Model\EditableFormField.countryDropdown
|
||||||
Parent: =>EditableFormField.irdNumberField
|
Parent: =>SilverStripe\UserForms\Model\EditableFormField.irdNumberField
|
||||||
rule2:
|
rule2:
|
||||||
Display: Show
|
Display: Show
|
||||||
ConditionOption: ValueGreaterThan
|
ConditionOption: ValueGreaterThan
|
||||||
FieldValue: 1
|
FieldValue: 1
|
||||||
ConditionField: =>EditableFormField.countryTextField
|
ConditionField: =>SilverStripe\UserForms\Model\EditableFormField.countryTextField
|
||||||
Parent: =>EditableFormField.irdNumberField
|
Parent: =>SilverStripe\UserForms\Model\EditableFormField.irdNumberField
|
||||||
|
@ -2,25 +2,15 @@
|
|||||||
|
|
||||||
namespace SilverStripe\UserForms\Test\Model\EditableFormField;
|
namespace SilverStripe\UserForms\Test\Model\EditableFormField;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
use SilverStripe\UserForms\Model\EditableFormField\EditableDropdown;
|
use SilverStripe\UserForms\Model\EditableFormField\EditableDropdown;
|
||||||
use SilverStripe\Dev\SapphireTest;
|
use SilverStripe\Dev\SapphireTest;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Tests the {@see EditableDropdown} class
|
* Tests the {@see EditableDropdown} class
|
||||||
*/
|
*/
|
||||||
class EditableDropdownTest extends SapphireTest
|
class EditableDropdownTest extends SapphireTest
|
||||||
{
|
{
|
||||||
|
protected static $fixture_file = '../EditableFormFieldTest.yml';
|
||||||
public static $fixture_file = 'userforms/tests/EditableFormFieldTest.yml';
|
|
||||||
|
|
||||||
public function setUp()
|
|
||||||
{
|
|
||||||
parent::setUp();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Tests that the field sets the empty string if set
|
* Tests that the field sets the empty string if set
|
||||||
@ -45,7 +35,5 @@ class EditableDropdownTest extends SapphireTest
|
|||||||
$alternateDropdown->UseEmptyString = true;
|
$alternateDropdown->UseEmptyString = true;
|
||||||
$alternateDropdown->write();
|
$alternateDropdown->write();
|
||||||
$this->assertEquals($formField->getEmptyString(), '');
|
$this->assertEquals($formField->getEmptyString(), '');
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -2,23 +2,16 @@
|
|||||||
|
|
||||||
namespace SilverStripe\UserForms\Test\Model\EditableFormField;
|
namespace SilverStripe\UserForms\Test\Model\EditableFormField;
|
||||||
|
|
||||||
|
|
||||||
use SilverStripe\UserForms\Model\EditableFormField\EditableFileField;
|
|
||||||
use SilverStripe\ORM\ValidationException;
|
|
||||||
use SilverStripe\Dev\SapphireTest;
|
use SilverStripe\Dev\SapphireTest;
|
||||||
|
use SilverStripe\ORM\ValidationException;
|
||||||
|
use SilverStripe\UserForms\Model\EditableFormField\EditableFileField;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @package userforms
|
* @package userforms
|
||||||
*/
|
*/
|
||||||
class EditableFileFieldTest extends SapphireTest
|
class EditableFileFieldTest extends SapphireTest
|
||||||
{
|
{
|
||||||
|
protected static $fixture_file = '../EditableFormFieldTest.yml';
|
||||||
/**
|
|
||||||
* @var string
|
|
||||||
*/
|
|
||||||
public static $fixture_file = 'userforms/tests/EditableFormFieldTest.yml';
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @var
|
* @var
|
||||||
@ -28,13 +21,12 @@ class EditableFileFieldTest extends SapphireTest
|
|||||||
/**
|
/**
|
||||||
* Hold the server default max file size upload limit for later
|
* Hold the server default max file size upload limit for later
|
||||||
*/
|
*/
|
||||||
public function setUp()
|
protected function setUp()
|
||||||
{
|
{
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
|
|
||||||
$editableFileField = singleton(EditableFileField::class);
|
$editableFileField = singleton(EditableFileField::class);
|
||||||
$this->php_max_file_size = $editableFileField::get_php_max_file_size();
|
$this->php_max_file_size = $editableFileField::get_php_max_file_size();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -73,4 +65,4 @@ class EditableFileFieldTest extends SapphireTest
|
|||||||
$this->assertEquals($formField->getValidator()->getAllowedMaxFileSize(), 262144);
|
$this->assertEquals($formField->getValidator()->getAllowedMaxFileSize(), 262144);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -2,28 +2,22 @@
|
|||||||
|
|
||||||
namespace SilverStripe\UserForms\Test\Model\EditableFormField;
|
namespace SilverStripe\UserForms\Test\Model\EditableFormField;
|
||||||
|
|
||||||
|
|
||||||
use HtmlEditorConfig;
|
|
||||||
|
|
||||||
|
|
||||||
use SilverStripe\UserForms\Model\EditableFormField\EditableLiteralField;
|
|
||||||
use SilverStripe\Core\Config\Config;
|
use SilverStripe\Core\Config\Config;
|
||||||
use SilverStripe\Forms\CompositeField;
|
|
||||||
use SilverStripe\Forms\LiteralField;
|
|
||||||
use SilverStripe\Dev\SapphireTest;
|
use SilverStripe\Dev\SapphireTest;
|
||||||
|
use SilverStripe\Forms\CompositeField;
|
||||||
|
use SilverStripe\Forms\HTMLEditor\HTMLEditorConfig;
|
||||||
|
use SilverStripe\Forms\LiteralField;
|
||||||
|
use SilverStripe\UserForms\Model\EditableFormField\EditableLiteralField;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Tests the {@see EditableLiteralField} class
|
* Tests the {@see EditableLiteralField} class
|
||||||
*/
|
*/
|
||||||
class EditableLiteralFieldTest extends SapphireTest
|
class EditableLiteralFieldTest extends SapphireTest
|
||||||
{
|
{
|
||||||
|
protected function setUp()
|
||||||
public function setUp()
|
|
||||||
{
|
{
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
HtmlEditorConfig::set_active('cms');
|
HTMLEditorConfig::set_active('cms');
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -36,21 +30,21 @@ class EditableLiteralFieldTest extends SapphireTest
|
|||||||
$field = new EditableLiteralField();
|
$field = new EditableLiteralField();
|
||||||
|
|
||||||
// Test with sanitisation enabled
|
// Test with sanitisation enabled
|
||||||
Config::inst()->update('HtmlEditorField', 'sanitise_server_side', true);
|
Config::modify()->update('HtmlEditorField', 'sanitise_server_side', true);
|
||||||
$field->setContent($rawContent);
|
$field->setContent($rawContent);
|
||||||
$this->assertEquals($safeContent, $field->getContent());
|
$this->assertEquals($safeContent, $field->getContent());
|
||||||
|
|
||||||
// Test with sanitisation disabled
|
// Test with sanitisation disabled
|
||||||
Config::inst()->remove('HtmlEditorField', 'sanitise_server_side');
|
Config::modify()->remove('HtmlEditorField', 'sanitise_server_side');
|
||||||
$field->setContent($rawContent);
|
$field->setContent($rawContent);
|
||||||
$this->assertEquals($rawContent, $field->getContent());
|
$this->assertEquals($rawContent, $field->getContent());
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testHideLabel()
|
public function testHideLabel()
|
||||||
{
|
{
|
||||||
$field = new EditableLiteralField(array(
|
$field = new EditableLiteralField([
|
||||||
'Title' => 'Test label'
|
'Title' => 'Test label'
|
||||||
));
|
]);
|
||||||
|
|
||||||
$this->assertContains('Test label', $field->getFormField()->FieldHolder());
|
$this->assertContains('Test label', $field->getFormField()->FieldHolder());
|
||||||
$this->assertEquals('Test label', $field->getFormField()->Title());
|
$this->assertEquals('Test label', $field->getFormField()->Title());
|
||||||
@ -80,7 +74,11 @@ class EditableLiteralFieldTest extends SapphireTest
|
|||||||
$field = new EditableLiteralField;
|
$field = new EditableLiteralField;
|
||||||
$formField = $field->getFormField();
|
$formField = $field->getFormField();
|
||||||
|
|
||||||
$this->assertInstanceOf(CompositeField::class, $formField, 'Literal field is contained within a composite field');
|
$this->assertInstanceOf(
|
||||||
|
CompositeField::class,
|
||||||
|
$formField,
|
||||||
|
'Literal field is contained within a composite field'
|
||||||
|
);
|
||||||
$this->assertInstanceOf(
|
$this->assertInstanceOf(
|
||||||
LiteralField::class,
|
LiteralField::class,
|
||||||
$formField->FieldList()->first(),
|
$formField->FieldList()->first(),
|
||||||
|
@ -2,30 +2,23 @@
|
|||||||
|
|
||||||
namespace SilverStripe\UserForms\Test\Model\EditableFormField;
|
namespace SilverStripe\UserForms\Test\Model\EditableFormField;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
use SilverStripe\Core\Config\Config;
|
|
||||||
use SilverStripe\UserForms\Model\EditableFormField\EditableFileField;
|
|
||||||
use SilverStripe\Assets\Filesystem;
|
use SilverStripe\Assets\Filesystem;
|
||||||
use SilverStripe\Assets\Folder;
|
use SilverStripe\Assets\Folder;
|
||||||
|
use SilverStripe\Core\Config\Config;
|
||||||
use SilverStripe\Dev\SapphireTest;
|
use SilverStripe\Dev\SapphireTest;
|
||||||
|
use SilverStripe\UserForms\Model\EditableFormField\EditableFileField;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Tests integration of EditableFileField with the securefiles module
|
* Tests integration of EditableFileField with the securefiles module
|
||||||
*
|
*
|
||||||
|
* @todo
|
||||||
* @author dmooyman
|
* @author dmooyman
|
||||||
*/
|
*/
|
||||||
class SecureEditableFileFieldTest extends SapphireTest
|
class SecureEditableFileFieldTest extends SapphireTest
|
||||||
{
|
{
|
||||||
|
|
||||||
protected $usesDatabase = true;
|
protected $usesDatabase = true;
|
||||||
|
|
||||||
public function setUp()
|
protected function setUp()
|
||||||
{
|
{
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
|
|
||||||
@ -33,11 +26,11 @@ class SecureEditableFileFieldTest extends SapphireTest
|
|||||||
$this->skipTest = true;
|
$this->skipTest = true;
|
||||||
$this->markTestSkipped(get_class() . ' skipped unless running with securefiles');
|
$this->markTestSkipped(get_class() . ' skipped unless running with securefiles');
|
||||||
}
|
}
|
||||||
Config::inst()->update(EditableFileField::class, 'secure_folder_name', 'SecureEditableFileFieldTest/SecureUploads');
|
Config::modify()->set(EditableFileField::class, 'secure_folder_name', 'SecureEditableFileFieldTest/SecureUploads');
|
||||||
$this->clearPath();
|
$this->clearPath();
|
||||||
}
|
}
|
||||||
|
|
||||||
public function tearDown()
|
protected function tearDown()
|
||||||
{
|
{
|
||||||
$this->clearPath();
|
$this->clearPath();
|
||||||
parent::tearDown();
|
parent::tearDown();
|
||||||
@ -69,7 +62,7 @@ class SecureEditableFileFieldTest extends SapphireTest
|
|||||||
*/
|
*/
|
||||||
public function testCreateInsecure()
|
public function testCreateInsecure()
|
||||||
{
|
{
|
||||||
Config::inst()->update(EditableFileField::class, 'disable_security', true);
|
Config::modify()->set(EditableFileField::class, 'disable_security', true);
|
||||||
|
|
||||||
// Esure folder is created without a folder
|
// Esure folder is created without a folder
|
||||||
$field = new EditableFileField();
|
$field = new EditableFileField();
|
||||||
@ -88,7 +81,7 @@ class SecureEditableFileFieldTest extends SapphireTest
|
|||||||
$this->assertEquals('Inherit', $field->Folder()->CanViewType);
|
$this->assertEquals('Inherit', $field->Folder()->CanViewType);
|
||||||
|
|
||||||
// Enabling security and re-saving will force this field to be made secure (but not changed)
|
// Enabling security and re-saving will force this field to be made secure (but not changed)
|
||||||
Config::inst()->update(EditableFileField::class, 'disable_security', false);
|
Config::modify()->set(EditableFileField::class, 'disable_security', false);
|
||||||
singleton(EditableFileField::class)->requireDefaultRecords();
|
singleton(EditableFileField::class)->requireDefaultRecords();
|
||||||
|
|
||||||
// Reload record from DB
|
// Reload record from DB
|
||||||
|
@ -2,36 +2,26 @@
|
|||||||
|
|
||||||
namespace SilverStripe\UserForms\Test\Model\EditableFormField;
|
namespace SilverStripe\UserForms\Test\Model\EditableFormField;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
use SilverStripe\UserForms\Model\EditableFormField\EditableTextField;
|
|
||||||
use SilverStripe\Security\Member;
|
|
||||||
use SilverStripe\UserForms\Model\UserDefinedForm;
|
|
||||||
use SilverStripe\UserForms\Model\EditableFormField\EditableCheckbox;
|
|
||||||
use SilverStripe\UserForms\Model\EditableFormField\EditableOption;
|
|
||||||
use SilverStripe\UserForms\Model\EditableFormField\EditableDropdown;
|
|
||||||
use SilverStripe\Forms\DropdownField;
|
|
||||||
use SilverStripe\UserForms\Model\EditableFormField\EditableRadioField;
|
|
||||||
use SilverStripe\Forms\OptionsetField;
|
|
||||||
use SilverStripe\UserForms\Model\EditableFormField\EditableFileField;
|
|
||||||
use SilverStripe\Core\Config\Config;
|
use SilverStripe\Core\Config\Config;
|
||||||
use SilverStripe\UserForms\Model\EditableFormField\EditableFormField;
|
|
||||||
use SilverStripe\Dev\FunctionalTest;
|
use SilverStripe\Dev\FunctionalTest;
|
||||||
|
use SilverStripe\Forms\DropdownField;
|
||||||
|
use SilverStripe\Forms\OptionsetField;
|
||||||
|
use SilverStripe\Security\Member;
|
||||||
|
use SilverStripe\UserForms\Model\EditableFormField\EditableCheckbox;
|
||||||
|
use SilverStripe\UserForms\Model\EditableFormField\EditableDropdown;
|
||||||
|
use SilverStripe\UserForms\Model\EditableFormField\EditableFileField;
|
||||||
|
use SilverStripe\UserForms\Model\EditableFormField\EditableFormField;
|
||||||
|
use SilverStripe\UserForms\Model\EditableFormField\EditableOption;
|
||||||
|
use SilverStripe\UserForms\Model\EditableFormField\EditableRadioField;
|
||||||
|
use SilverStripe\UserForms\Model\EditableFormField\EditableTextField;
|
||||||
|
use SilverStripe\UserForms\Model\UserDefinedForm;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @package userforms
|
* @package userforms
|
||||||
*/
|
*/
|
||||||
|
|
||||||
class EditableFormFieldTest extends FunctionalTest
|
class EditableFormFieldTest extends FunctionalTest
|
||||||
{
|
{
|
||||||
|
protected static $fixture_file = 'EditableFormFieldTest.yml';
|
||||||
public static $fixture_file = 'userforms/tests/EditableFormFieldTest.yml';
|
|
||||||
|
|
||||||
public function testFormFieldPermissions()
|
public function testFormFieldPermissions()
|
||||||
{
|
{
|
||||||
@ -54,7 +44,7 @@ class EditableFormFieldTest extends FunctionalTest
|
|||||||
$this->assertTrue($text->canDelete());
|
$this->assertTrue($text->canDelete());
|
||||||
|
|
||||||
$member = Member::currentUser();
|
$member = Member::currentUser();
|
||||||
$member->logout();
|
$member->logOut();
|
||||||
|
|
||||||
$this->logInWithPermission('SITETREE_VIEW_ALL');
|
$this->logInWithPermission('SITETREE_VIEW_ALL');
|
||||||
$this->assertFalse($text->canCreate());
|
$this->assertFalse($text->canCreate());
|
||||||
@ -105,15 +95,15 @@ class EditableFormFieldTest extends FunctionalTest
|
|||||||
$option = $this->objFromFixture(EditableOption::class, 'option-1');
|
$option = $this->objFromFixture(EditableOption::class, 'option-1');
|
||||||
$option->Value = '';
|
$option->Value = '';
|
||||||
|
|
||||||
// Disallow empty values
|
// Disallow empty values
|
||||||
EditableOption::set_allow_empty_values(false);
|
EditableOption::set_allow_empty_values(false);
|
||||||
$this->assertEquals($option->Title, $option->Value);
|
$this->assertEquals($option->Title, $option->Value);
|
||||||
|
|
||||||
$option->Value = 'test';
|
$option->Value = 'test';
|
||||||
$this->assertEquals('test', $option->Value);
|
$this->assertEquals('test', $option->Value);
|
||||||
|
|
||||||
// Allow empty values
|
// Allow empty values
|
||||||
EditableOption::set_allow_empty_values(true);
|
EditableOption::set_allow_empty_values(true);
|
||||||
$option->Value = '';
|
$option->Value = '';
|
||||||
$this->assertEquals('', $option->Value);
|
$this->assertEquals('', $option->Value);
|
||||||
}
|
}
|
||||||
@ -124,11 +114,10 @@ class EditableFormFieldTest extends FunctionalTest
|
|||||||
|
|
||||||
$field = $dropdown->getFormField();
|
$field = $dropdown->getFormField();
|
||||||
|
|
||||||
|
|
||||||
$this->assertThat($field, $this->isInstanceOf(DropdownField::class));
|
$this->assertThat($field, $this->isInstanceOf(DropdownField::class));
|
||||||
$values = $field->getSource();
|
$values = $field->getSource();
|
||||||
|
|
||||||
$this->assertEquals(array('Option 1' => 'Option 1', 'Option 2' => 'Option 2'), $values);
|
$this->assertEquals(['Option 1' => 'Option 1', 'Option 2' => 'Option 2'], $values);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testEditableRadioField()
|
public function testEditableRadioField()
|
||||||
@ -140,7 +129,7 @@ class EditableFormFieldTest extends FunctionalTest
|
|||||||
$this->assertThat($field, $this->isInstanceOf(OptionsetField::class));
|
$this->assertThat($field, $this->isInstanceOf(OptionsetField::class));
|
||||||
$values = $field->getSource();
|
$values = $field->getSource();
|
||||||
|
|
||||||
$this->assertEquals(array('Option 5' => 'Option 5', 'Option 6' => 'Option 6'), $values);
|
$this->assertEquals(['Option 5' => 'Option 5', 'Option 6' => 'Option 6'], $values);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testMultipleOptionDuplication()
|
public function testMultipleOptionDuplication()
|
||||||
@ -169,7 +158,7 @@ class EditableFormFieldTest extends FunctionalTest
|
|||||||
|
|
||||||
public function testFileFieldAllowedExtensionsBlacklist()
|
public function testFileFieldAllowedExtensionsBlacklist()
|
||||||
{
|
{
|
||||||
Config::inst()->update(EditableFileField::class, 'allowed_extensions_blacklist', array('jpg'));
|
Config::modify()->merge(EditableFileField::class, 'allowed_extensions_blacklist', ['jpg']);
|
||||||
$fileField = $this->objFromFixture(EditableFileField::class, 'file-field');
|
$fileField = $this->objFromFixture(EditableFileField::class, 'file-field');
|
||||||
$formField = $fileField->getFormField();
|
$formField = $fileField->getFormField();
|
||||||
|
|
@ -1,15 +1,15 @@
|
|||||||
EditableFormField:
|
SilverStripe\UserForms\Model\EditableFormField:
|
||||||
irdNumberField:
|
irdNumberField:
|
||||||
ClassName: EditableTextField
|
ClassName: SilverStripe\UserForms\Model\EditableFormField\EditableTextField
|
||||||
Name: IRDNumber
|
Name: IRDNumber
|
||||||
Title: "Enter your IRD Number"
|
Title: "Enter your IRD Number"
|
||||||
countryTextField:
|
countryTextField:
|
||||||
ClassName: EditableTextField
|
ClassName: SilverStripe\UserForms\Model\EditableFormField\EditableTextField
|
||||||
Name: CountryTextSelection
|
Name: CountryTextSelection
|
||||||
Title: "Enter your country (2 digit prefix)"
|
Title: "Enter your country (2 digit prefix)"
|
||||||
DisplayRulesConjunction: And
|
DisplayRulesConjunction: And
|
||||||
ShowOnLoad: false
|
ShowOnLoad: false
|
||||||
EditableCustomRule:
|
SilverStripe\UserForms\Model\EditableCustomRule:
|
||||||
rule1:
|
rule1:
|
||||||
Display: Show
|
Display: Show
|
||||||
ConditionOption: HasValue
|
ConditionOption: HasValue
|
||||||
@ -20,7 +20,7 @@ EditableCustomRule:
|
|||||||
Display: Hide
|
Display: Hide
|
||||||
ConditionOption: HasValue
|
ConditionOption: HasValue
|
||||||
FieldValue: 6
|
FieldValue: 6
|
||||||
EditableOption:
|
SilverStripe\UserForms\Model\EditableFormField\EditableOption:
|
||||||
option-1:
|
option-1:
|
||||||
Name: Option1
|
Name: Option1
|
||||||
Title: Option 1
|
Title: Option 1
|
||||||
@ -61,7 +61,7 @@ EditableOption:
|
|||||||
Title: Option 6
|
Title: Option 6
|
||||||
Value: Option 6
|
Value: Option 6
|
||||||
|
|
||||||
UserDefinedForm_EmailRecipient:
|
SilverStripe\UserForms\Model\Recipient\EmailRecipient:
|
||||||
recipient-1:
|
recipient-1:
|
||||||
EmailAddress: test@example.com
|
EmailAddress: test@example.com
|
||||||
EmailSubject: Email Subject
|
EmailSubject: Email Subject
|
||||||
@ -79,7 +79,7 @@ UserDefinedForm_EmailRecipient:
|
|||||||
EmailFrom: no-reply@example.com
|
EmailFrom: no-reply@example.com
|
||||||
HideFormData: true
|
HideFormData: true
|
||||||
|
|
||||||
EditableTextField:
|
SilverStripe\UserForms\Model\EditableFormField\EditableTextField:
|
||||||
basic-text:
|
basic-text:
|
||||||
Name: basic-text-name
|
Name: basic-text-name
|
||||||
Title: Basic Text Field
|
Title: Basic Text Field
|
||||||
@ -94,18 +94,18 @@ EditableTextField:
|
|||||||
CustomErrorMessage: Custom Error Message
|
CustomErrorMessage: Custom Error Message
|
||||||
Required: true
|
Required: true
|
||||||
|
|
||||||
EditableDropdown:
|
SilverStripe\UserForms\Model\EditableFormField\EditableDropdown:
|
||||||
basic-dropdown:
|
basic-dropdown:
|
||||||
Name: basic-dropdown
|
Name: basic-dropdown
|
||||||
Title: Basic Dropdown Field
|
Title: Basic Dropdown Field
|
||||||
Options: =>EditableOption.option-1, =>EditableOption.option-2
|
Options: =>SilverStripe\UserForms\Model\EditableFormField\EditableOption.option-1, =>SilverStripe\UserForms\Model\EditableFormField\EditableOption.option-2
|
||||||
|
|
||||||
department-dropdown:
|
department-dropdown:
|
||||||
Name: department
|
Name: department
|
||||||
Title: Department
|
Title: Department
|
||||||
Options: =>EditableOption.department-1, =>EditableOption.department-2
|
Options: =>SilverStripe\UserForms\Model\EditableFormField\EditableOption.department-1, =>SilverStripe\UserForms\Model\EditableFormField\EditableOption.department-2
|
||||||
|
|
||||||
EditableCheckbox:
|
SilverStripe\UserForms\Model\EditableFormField\EditableCheckbox:
|
||||||
checkbox-1:
|
checkbox-1:
|
||||||
Name: checkbox-1
|
Name: checkbox-1
|
||||||
Title: Checkbox 1
|
Title: Checkbox 1
|
||||||
@ -117,35 +117,35 @@ EditableCheckbox:
|
|||||||
checkbox-with-rule:
|
checkbox-with-rule:
|
||||||
Name: checkbox-with-rule
|
Name: checkbox-with-rule
|
||||||
Title: Checkbox with rule
|
Title: Checkbox with rule
|
||||||
DisplayRules: =>EditableCustomRule.rule-1
|
DisplayRules: =>SilverStripe\UserForms\Model\EditableCustomRule.rule-1
|
||||||
|
|
||||||
EditableCheckboxGroupField:
|
SilverStripe\UserForms\Model\EditableFormField\EditableCheckboxGroupField:
|
||||||
checkbox-group:
|
checkbox-group:
|
||||||
Name: check-box-group
|
Name: check-box-group
|
||||||
Title: Check box group
|
Title: Check box group
|
||||||
Options: =>EditableOption.option-3, =>EditableOption.option-4
|
Options: =>SilverStripe\UserForms\Model\EditableFormField\EditableOption.option-3, =>SilverStripe\UserForms\Model\EditableFormField\EditableOption.option-4
|
||||||
|
|
||||||
EditableEmailField:
|
SilverStripe\UserForms\Model\EditableFormField\EditableEmailField:
|
||||||
email-field:
|
email-field:
|
||||||
Name: email-field
|
Name: email-field
|
||||||
Title: Email
|
Title: Email
|
||||||
|
|
||||||
EditableRadioField:
|
SilverStripe\UserForms\Model\EditableFormField\EditableRadioField:
|
||||||
radio-field:
|
radio-field:
|
||||||
Name: radio-option
|
Name: radio-option
|
||||||
Title: Radio Option
|
Title: Radio Option
|
||||||
Options: =>EditableOption.option-5, =>EditableOption.option-6
|
Options: =>SilverStripe\UserForms\Model\EditableFormField\EditableOption.option-5, =>SilverStripe\UserForms\Model\EditableFormField\EditableOption.option-6
|
||||||
|
|
||||||
EditableFileField:
|
SilverStripe\UserForms\Model\EditableFormField\EditableFileField:
|
||||||
file-field:
|
file-field:
|
||||||
Name: file-uploader
|
Name: file-uploader
|
||||||
Title: Set file
|
Title: Set file
|
||||||
|
|
||||||
UserDefinedForm:
|
SilverStripe\UserForms\Model\UserDefinedForm:
|
||||||
basic-form-page:
|
basic-form-page:
|
||||||
Title: User Defined Form
|
Title: User Defined Form
|
||||||
Fields: =>EditableTextField.basic-text
|
Fields: =>SilverStripe\UserForms\Model\EditableFormField\EditableTextField.basic-text
|
||||||
EmailRecipients: =>UserDefinedForm_EmailRecipient.recipient-1, =>UserDefinedForm_EmailRecipient.no-html, =>UserDefinedForm_EmailRecipient.no-data
|
EmailRecipients: =>SilverStripe\UserForms\Model\Recipient\EmailRecipient.recipient-1, =>SilverStripe\UserForms\Model\Recipient\EmailRecipient.no-html, =>SilverStripe\UserForms\Model\Recipient\EmailRecipient.no-data
|
||||||
|
|
||||||
form-with-reset-and-custom-action:
|
form-with-reset-and-custom-action:
|
||||||
Title: Form with Reset Action
|
Title: Form with Reset Action
|
||||||
@ -154,10 +154,10 @@ UserDefinedForm:
|
|||||||
|
|
||||||
validation-form:
|
validation-form:
|
||||||
Title: Validation Form
|
Title: Validation Form
|
||||||
Fields: =>EditableTextField.required-text
|
Fields: =>SilverStripe\UserForms\Model\EditableFormField\EditableTextField.required-text
|
||||||
|
|
||||||
custom-rules-form:
|
custom-rules-form:
|
||||||
Title: Custom Rules Form
|
Title: Custom Rules Form
|
||||||
Fields: =>EditableCheckbox.checkbox-with-rule, =>EditableTextField.basic-text-2
|
Fields: =>SilverStripe\UserForms\Model\EditableFormField\EditableCheckbox.checkbox-with-rule, =>SilverStripe\UserForms\Model\EditableFormField\EditableTextField.basic-text-2
|
||||||
empty-form:
|
empty-form:
|
||||||
Title: Empty Form
|
Title: Empty Form
|
62
tests/Model/Recipient/EmailRecipientConditionTest.php
Normal file
62
tests/Model/Recipient/EmailRecipientConditionTest.php
Normal file
@ -0,0 +1,62 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace SilverStripe\UserForms\Test\Model\Recipient;
|
||||||
|
|
||||||
|
use SilverStripe\Dev\SapphireTest;
|
||||||
|
use SilverStripe\UserForms\Model\Recipient\EmailRecipientCondition;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class EditableCustomRulesTest
|
||||||
|
*/
|
||||||
|
class EmailRecipientConditionTest extends SapphireTest
|
||||||
|
{
|
||||||
|
protected static $fixture_file = 'EmailRecipientConditionTest.yml';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Various matching tests
|
||||||
|
*/
|
||||||
|
public function testMatches()
|
||||||
|
{
|
||||||
|
$fixtureClass = EmailRecipientCondition::class;
|
||||||
|
|
||||||
|
//Test Blank
|
||||||
|
$blankObj = $this->objFromFixture($fixtureClass, 'blankTest');
|
||||||
|
$this->assertTrue($blankObj->matches(['Name' => null]));
|
||||||
|
$this->assertFalse($blankObj->matches(['Name' => 'Jane']));
|
||||||
|
|
||||||
|
//Test IsNotBlank
|
||||||
|
$blankObj = $this->objFromFixture($fixtureClass, 'isNotBlankTest');
|
||||||
|
$this->assertTrue($blankObj->matches(['Name' => 'Jane']));
|
||||||
|
$this->assertFalse($blankObj->matches(['Name' => null]));
|
||||||
|
|
||||||
|
//Test ValueLessthan
|
||||||
|
$blankObj = $this->objFromFixture($fixtureClass, 'valueLessThanTest');
|
||||||
|
$this->assertTrue($blankObj->matches(['Age' => 17]));
|
||||||
|
$this->assertFalse($blankObj->matches(['Age' => 19]));
|
||||||
|
|
||||||
|
//Test ValueLessThanEquals
|
||||||
|
$blankObj = $this->objFromFixture($fixtureClass, 'valueLessThanEqualTest');
|
||||||
|
$this->assertTrue($blankObj->matches(['Age' => 18]));
|
||||||
|
$this->assertFalse($blankObj->matches(['Age' => 19]));
|
||||||
|
|
||||||
|
//Test ValueGreaterThan
|
||||||
|
$blankObj = $this->objFromFixture($fixtureClass, 'valueGreaterThanTest');
|
||||||
|
$this->assertTrue($blankObj->matches(['Age' => 19]));
|
||||||
|
$this->assertFalse($blankObj->matches(['Age' => 17]));
|
||||||
|
|
||||||
|
//Test ValueGreaterThanEquals
|
||||||
|
$blankObj = $this->objFromFixture($fixtureClass, 'valueGreaterThanEqualTest');
|
||||||
|
$this->assertTrue($blankObj->matches(['Age' => 18]));
|
||||||
|
$this->assertFalse($blankObj->matches(['Age' => 17]));
|
||||||
|
|
||||||
|
//Test Equals
|
||||||
|
$blankObj = $this->objFromFixture($fixtureClass, 'equalsTest');
|
||||||
|
$this->assertTrue($blankObj->matches(['Age' => 18]));
|
||||||
|
$this->assertFalse($blankObj->matches(['Age' => 17]));
|
||||||
|
|
||||||
|
//Test NotEquals
|
||||||
|
$blankObj = $this->objFromFixture($fixtureClass, 'notEqualsTest');
|
||||||
|
$this->assertTrue($blankObj->matches(['Age' => 17]));
|
||||||
|
$this->assertFalse($blankObj->matches(['Age' => 18]));
|
||||||
|
}
|
||||||
|
}
|
39
tests/Model/Recipient/EmailRecipientConditionTest.yml
Normal file
39
tests/Model/Recipient/EmailRecipientConditionTest.yml
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
SilverStripe\UserForms\Model\EditableFormField\EditableTextField:
|
||||||
|
nameField:
|
||||||
|
Name: Name
|
||||||
|
SilverStripe\UserForms\Model\EditableFormField\EditableNumericField:
|
||||||
|
ageField:
|
||||||
|
Name: Age
|
||||||
|
SilverStripe\UserForms\Model\EditableFormField\EmailRecipientCondition:
|
||||||
|
blankTest:
|
||||||
|
ConditionOption: IsBlank
|
||||||
|
ConditionValue: null
|
||||||
|
ConditionField: =>SilverStripe\UserForms\Model\EditableFormField\EditableTextField.nameField
|
||||||
|
isNotBlankTest:
|
||||||
|
ConditionOption: IsNotBlank
|
||||||
|
ConditionValue: null
|
||||||
|
ConditionField: =>SilverStripe\UserForms\Model\EditableFormField\EditableTextField.nameField
|
||||||
|
equalsTest:
|
||||||
|
ConditionOption: Equals
|
||||||
|
ConditionValue: 18
|
||||||
|
ConditionField: =>SilverStripe\UserForms\Model\EditableFormField\EditableNumericField.ageField
|
||||||
|
notEqualsTest:
|
||||||
|
ConditionOption: NotEquals
|
||||||
|
ConditionValue: 18
|
||||||
|
ConditionField: =>SilverStripe\UserForms\Model\EditableFormField\EditableNumericField.ageField
|
||||||
|
valueLessThanTest:
|
||||||
|
ConditionOption: ValueLessThan
|
||||||
|
ConditionValue: 18
|
||||||
|
ConditionField: =>SilverStripe\UserForms\Model\EditableFormField\EditableNumericField.ageField
|
||||||
|
valueLessThanEqualTest:
|
||||||
|
ConditionOption: ValueLessThanEqual
|
||||||
|
ConditionValue: 18
|
||||||
|
ConditionField: =>SilverStripe\UserForms\Model\EditableFormField\EditableNumericField.ageField
|
||||||
|
valueGreaterThanTest:
|
||||||
|
ConditionOption: ValueGreaterThan
|
||||||
|
ConditionValue: 18
|
||||||
|
ConditionField: =>SilverStripe\UserForms\Model\EditableFormField\EditableNumericField.ageField
|
||||||
|
valueGreaterThanEqualTest:
|
||||||
|
ConditionOption: ValueGreaterThanEqual
|
||||||
|
ConditionValue: 18
|
||||||
|
ConditionField: =>SilverStripe\UserForms\Model\EditableFormField\EditableNumericField.ageField
|
@ -1,72 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
namespace SilverStripe\UserForms\Test\Model\Recipient;
|
|
||||||
|
|
||||||
|
|
||||||
use SilverStripe\UserForms\Model\Recipient\UserDefinedForm_EmailRecipientCondition;
|
|
||||||
use SilverStripe\Dev\SapphireTest;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Class EditableCustomRulesTest
|
|
||||||
*/
|
|
||||||
class UserDefinedForm_EmailRecipientConditionTest extends SapphireTest
|
|
||||||
{
|
|
||||||
protected static $fixture_file = 'userforms/tests/UserDefinedForm_EmailRecipientConditionTest.yml';
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Various matching tests
|
|
||||||
*/
|
|
||||||
public function testMatches()
|
|
||||||
{
|
|
||||||
$fixtureClass = UserDefinedForm_EmailRecipientCondition::class;
|
|
||||||
//Test Blank
|
|
||||||
/** @var UserDefinedForm_EmailRecipientCondition $blankObj */
|
|
||||||
$blankObj = $this->objFromFixture($fixtureClass, 'blankTest');
|
|
||||||
$this->assertTrue($blankObj->matches(array('Name' => null)));
|
|
||||||
$this->assertFalse($blankObj->matches(array('Name' => 'Jane')));
|
|
||||||
|
|
||||||
//Test IsNotBlank
|
|
||||||
/** @var UserDefinedForm_EmailRecipientCondition $blankObj */
|
|
||||||
$blankObj = $this->objFromFixture($fixtureClass, 'isNotBlankTest');
|
|
||||||
$this->assertTrue($blankObj->matches(array('Name' => 'Jane')));
|
|
||||||
$this->assertFalse($blankObj->matches(array('Name' => null)));
|
|
||||||
|
|
||||||
//Test ValueLessthan
|
|
||||||
/** @var UserDefinedForm_EmailRecipientCondition $blankObj */
|
|
||||||
$blankObj = $this->objFromFixture($fixtureClass, 'valueLessThanTest');
|
|
||||||
$this->assertTrue($blankObj->matches(array('Age' => 17)));
|
|
||||||
$this->assertFalse($blankObj->matches(array('Age' => 19)));
|
|
||||||
|
|
||||||
//Test ValueLessThanEquals
|
|
||||||
/** @var UserDefinedForm_EmailRecipientCondition $blankObj */
|
|
||||||
$blankObj = $this->objFromFixture($fixtureClass, 'valueLessThanEqualTest');
|
|
||||||
$this->assertTrue($blankObj->matches(array('Age' => 18)));
|
|
||||||
$this->assertFalse($blankObj->matches(array('Age' => 19)));
|
|
||||||
|
|
||||||
//Test ValueGreaterThan
|
|
||||||
/** @var UserDefinedForm_EmailRecipientCondition $blankObj */
|
|
||||||
$blankObj = $this->objFromFixture($fixtureClass, 'valueGreaterThanTest');
|
|
||||||
$this->assertTrue($blankObj->matches(array('Age' => 19)));
|
|
||||||
$this->assertFalse($blankObj->matches(array('Age' => 17)));
|
|
||||||
|
|
||||||
//Test ValueGreaterThanEquals
|
|
||||||
/** @var UserDefinedForm_EmailRecipientCondition $blankObj */
|
|
||||||
$blankObj = $this->objFromFixture($fixtureClass, 'valueGreaterThanEqualTest');
|
|
||||||
$this->assertTrue($blankObj->matches(array('Age' => 18)));
|
|
||||||
$this->assertFalse($blankObj->matches(array('Age' => 17)));
|
|
||||||
|
|
||||||
//Test Equals
|
|
||||||
/** @var UserDefinedForm_EmailRecipientCondition $blankObj */
|
|
||||||
$blankObj = $this->objFromFixture($fixtureClass, 'equalsTest');
|
|
||||||
$this->assertTrue($blankObj->matches(array('Age' => 18)));
|
|
||||||
$this->assertFalse($blankObj->matches(array('Age' => 17)));
|
|
||||||
|
|
||||||
//Test NotEquals
|
|
||||||
/** @var UserDefinedForm_EmailRecipientCondition $blankObj */
|
|
||||||
$blankObj = $this->objFromFixture($fixtureClass, 'notEqualsTest');
|
|
||||||
$this->assertTrue($blankObj->matches(array('Age' => 17)));
|
|
||||||
$this->assertFalse($blankObj->matches(array('Age' => 18)));
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,39 +0,0 @@
|
|||||||
EditableTextField:
|
|
||||||
nameField:
|
|
||||||
Name: Name
|
|
||||||
EditableNumericField:
|
|
||||||
ageField:
|
|
||||||
Name: Age
|
|
||||||
UserDefinedForm_EmailRecipientCondition:
|
|
||||||
blankTest:
|
|
||||||
ConditionOption: IsBlank
|
|
||||||
ConditionValue: null
|
|
||||||
ConditionField: =>EditableTextField.nameField
|
|
||||||
isNotBlankTest:
|
|
||||||
ConditionOption: IsNotBlank
|
|
||||||
ConditionValue: null
|
|
||||||
ConditionField: =>EditableTextField.nameField
|
|
||||||
equalsTest:
|
|
||||||
ConditionOption: Equals
|
|
||||||
ConditionValue: 18
|
|
||||||
ConditionField: =>EditableNumericField.ageField
|
|
||||||
notEqualsTest:
|
|
||||||
ConditionOption: NotEquals
|
|
||||||
ConditionValue: 18
|
|
||||||
ConditionField: =>EditableNumericField.ageField
|
|
||||||
valueLessThanTest:
|
|
||||||
ConditionOption: ValueLessThan
|
|
||||||
ConditionValue: 18
|
|
||||||
ConditionField: =>EditableNumericField.ageField
|
|
||||||
valueLessThanEqualTest:
|
|
||||||
ConditionOption: ValueLessThanEqual
|
|
||||||
ConditionValue: 18
|
|
||||||
ConditionField: =>EditableNumericField.ageField
|
|
||||||
valueGreaterThanTest:
|
|
||||||
ConditionOption: ValueGreaterThan
|
|
||||||
ConditionValue: 18
|
|
||||||
ConditionField: =>EditableNumericField.ageField
|
|
||||||
valueGreaterThanEqualTest:
|
|
||||||
ConditionOption: ValueGreaterThanEqual
|
|
||||||
ConditionValue: 18
|
|
||||||
ConditionField: =>EditableNumericField.ageField
|
|
@ -2,31 +2,18 @@
|
|||||||
|
|
||||||
namespace SilverStripe\UserForms\Test\Model;
|
namespace SilverStripe\UserForms\Test\Model;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
use ResetFormAction;
|
|
||||||
|
|
||||||
|
|
||||||
use UserDefinedForm_Controller;
|
|
||||||
|
|
||||||
use SilverStripe\UserForms\Model\EditableFormField\EditableTextField;
|
|
||||||
use SilverStripe\UserForms\Model\Submission\SubmittedFormField;
|
|
||||||
use SilverStripe\ORM\DataObject;
|
|
||||||
use SilverStripe\Dev\CSSContentParser;
|
use SilverStripe\Dev\CSSContentParser;
|
||||||
use SilverStripe\UserForms\Model\UserDefinedForm;
|
|
||||||
use SilverStripe\Forms\FormAction;
|
|
||||||
use SilverStripe\Forms\FieldList;
|
|
||||||
use SilverStripe\View\ArrayData;
|
|
||||||
use SilverStripe\UserForms\Test\Model\UserDefinedFormControllerTest;
|
|
||||||
use SilverStripe\Security\Member;
|
|
||||||
use SilverStripe\Dev\FunctionalTest;
|
use SilverStripe\Dev\FunctionalTest;
|
||||||
use SilverStripe\Dev\TestOnly;
|
use SilverStripe\Dev\TestOnly;
|
||||||
|
use SilverStripe\Forms\FieldList;
|
||||||
|
use SilverStripe\Forms\FormAction;
|
||||||
|
use SilverStripe\ORM\DataObject;
|
||||||
|
use SilverStripe\Security\Member;
|
||||||
|
use SilverStripe\UserForms\Model\EditableFormField\EditableTextField;
|
||||||
|
use SilverStripe\UserForms\Model\Submission\SubmittedFormField;
|
||||||
|
use SilverStripe\UserForms\Model\UserDefinedForm;
|
||||||
|
use SilverStripe\UserForms\Model\UserDefinedFormController;
|
||||||
|
use SilverStripe\View\ArrayData;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @package userforms
|
* @package userforms
|
||||||
@ -34,14 +21,13 @@ use SilverStripe\Dev\TestOnly;
|
|||||||
|
|
||||||
class UserDefinedFormControllerTest extends FunctionalTest
|
class UserDefinedFormControllerTest extends FunctionalTest
|
||||||
{
|
{
|
||||||
|
protected static $fixture_file = 'UserDefinedFormTest.yml';
|
||||||
public static $fixture_file = 'UserDefinedFormTest.yml';
|
|
||||||
|
|
||||||
public function testProcess()
|
public function testProcess()
|
||||||
{
|
{
|
||||||
$form = $this->setupFormFrontend();
|
$form = $this->setupFormFrontend();
|
||||||
|
|
||||||
$controller = new UserDefinedFormControllerTest_Controller($form);
|
$controller = new UserDefinedFormController($form);
|
||||||
|
|
||||||
$this->autoFollowRedirection = false;
|
$this->autoFollowRedirection = false;
|
||||||
$this->clearEmails();
|
$this->clearEmails();
|
||||||
@ -51,11 +37,18 @@ class UserDefinedFormControllerTest extends FunctionalTest
|
|||||||
|
|
||||||
$field = $this->objFromFixture(EditableTextField::class, 'basic-text');
|
$field = $this->objFromFixture(EditableTextField::class, 'basic-text');
|
||||||
|
|
||||||
$response = $this->submitForm('UserForm_Form_' . $form->ID, null, array($field->Name => 'Basic Value'));
|
$response = $this->submitForm('UserForm_Form_' . $form->ID, null, [$field->Name => 'Basic Value']);
|
||||||
|
|
||||||
// should have a submitted form field now
|
// should have a submitted form field now
|
||||||
$submitted = DataObject::get(SubmittedFormField::class, "\"Name\" = 'basic-text-name'");
|
$submitted = DataObject::get(SubmittedFormField::class, "\"Name\" = 'basic-text-name'");
|
||||||
$this->assertDOSAllMatch(array('Name' => 'basic-text-name', 'Value' => 'Basic Value', 'Title' => 'Basic Text Field'), $submitted);
|
$this->assertDOSAllMatch(
|
||||||
|
[
|
||||||
|
'Name' => 'basic-text-name',
|
||||||
|
'Value' => 'Basic Value',
|
||||||
|
'Title' => 'Basic Text Field'
|
||||||
|
],
|
||||||
|
$submitted
|
||||||
|
);
|
||||||
|
|
||||||
// check emails
|
// check emails
|
||||||
$this->assertEmailSent('test@example.com', 'no-reply@example.com', 'Email Subject');
|
$this->assertEmailSent('test@example.com', 'no-reply@example.com', 'Email Subject');
|
||||||
@ -96,31 +89,31 @@ class UserDefinedFormControllerTest extends FunctionalTest
|
|||||||
|
|
||||||
// Post with no fields
|
// Post with no fields
|
||||||
$this->get($form->URLSegment);
|
$this->get($form->URLSegment);
|
||||||
$response = $this->submitForm('UserForm_Form_' . $form->ID, null, array());
|
$response = $this->submitForm('UserForm_Form_' . $form->ID, null, []);
|
||||||
$this->assertPartialMatchBySelector(
|
$this->assertPartialMatchBySelector(
|
||||||
'.field .message',
|
'.field .message',
|
||||||
array('This field is required')
|
['This field is required']
|
||||||
);
|
);
|
||||||
|
|
||||||
// Post with all fields, but invalid email
|
// Post with all fields, but invalid email
|
||||||
$this->get($form->URLSegment);
|
$this->get($form->URLSegment);
|
||||||
$this->submitForm('UserForm_Form_' . $form->ID, null, array(
|
$this->submitForm('UserForm_Form_' . $form->ID, null, [
|
||||||
'required-email' => 'invalid',
|
'required-email' => 'invalid',
|
||||||
'required-text' => 'bob'
|
'required-text' => 'bob'
|
||||||
));
|
]);
|
||||||
$this->assertPartialMatchBySelector(
|
$this->assertPartialMatchBySelector(
|
||||||
'.field .message',
|
'.field .message',
|
||||||
array('Please enter an email address')
|
['Please enter an email address']
|
||||||
);
|
);
|
||||||
|
|
||||||
// Post with only required
|
// Post with only required
|
||||||
$this->get($form->URLSegment);
|
$this->get($form->URLSegment);
|
||||||
$this->submitForm('UserForm_Form_' . $form->ID, null, array(
|
$this->submitForm('UserForm_Form_' . $form->ID, null, [
|
||||||
'required-text' => 'bob'
|
'required-text' => 'bob'
|
||||||
));
|
]);
|
||||||
$this->assertPartialMatchBySelector(
|
$this->assertPartialMatchBySelector(
|
||||||
'p',
|
'p',
|
||||||
array("Thanks, we've received your submission.")
|
["Thanks, we've received your submission."]
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -129,8 +122,8 @@ class UserDefinedFormControllerTest extends FunctionalTest
|
|||||||
$form = $this->setupFormFrontend();
|
$form = $this->setupFormFrontend();
|
||||||
|
|
||||||
// set formProcessed and SecurityID to replicate the form being filled out
|
// set formProcessed and SecurityID to replicate the form being filled out
|
||||||
$this->session()->inst_set('SecurityID', 1);
|
$this->session()->set('SecurityID', 1);
|
||||||
$this->session()->inst_set('FormProcessed', 1);
|
$this->session()->set('FormProcessed', 1);
|
||||||
|
|
||||||
$response = $this->get($form->URLSegment.'/finished');
|
$response = $this->get($form->URLSegment.'/finished');
|
||||||
|
|
||||||
@ -142,8 +135,8 @@ class UserDefinedFormControllerTest extends FunctionalTest
|
|||||||
$form = $this->setupFormFrontend();
|
$form = $this->setupFormFrontend();
|
||||||
|
|
||||||
// replicate finished being added to the end of the form URL without the form being filled out
|
// replicate finished being added to the end of the form URL without the form being filled out
|
||||||
$this->session()->inst_set('SecurityID', 1);
|
$this->session()->set('SecurityID', 1);
|
||||||
$this->session()->inst_set('FormProcessed', null);
|
$this->session()->set('FormProcessed', null);
|
||||||
|
|
||||||
$response = $this->get($form->URLSegment.'/finished');
|
$response = $this->get($form->URLSegment.'/finished');
|
||||||
|
|
||||||
@ -154,7 +147,7 @@ class UserDefinedFormControllerTest extends FunctionalTest
|
|||||||
{
|
{
|
||||||
$form = $this->objFromFixture(UserDefinedForm::class, 'basic-form-page');
|
$form = $this->objFromFixture(UserDefinedForm::class, 'basic-form-page');
|
||||||
|
|
||||||
$controller = new UserDefinedFormControllerTest_Controller($form);
|
$controller = new UserDefinedFormController($form);
|
||||||
|
|
||||||
// test form
|
// test form
|
||||||
$this->assertEquals($controller->Form()->getName(), 'Form_' . $form->ID, 'The form is referenced as Form');
|
$this->assertEquals($controller->Form()->getName(), 'Form_' . $form->ID, 'The form is referenced as Form');
|
||||||
@ -163,7 +156,7 @@ class UserDefinedFormControllerTest extends FunctionalTest
|
|||||||
$this->assertEquals(count($controller->Form()->getValidator()->getRequired()), 0);
|
$this->assertEquals(count($controller->Form()->getValidator()->getRequired()), 0);
|
||||||
|
|
||||||
$requiredForm = $this->objFromFixture(UserDefinedForm::class, 'validation-form');
|
$requiredForm = $this->objFromFixture(UserDefinedForm::class, 'validation-form');
|
||||||
$controller = new UserDefinedFormControllerTest_Controller($requiredForm);
|
$controller = new UserDefinedFormController($requiredForm);
|
||||||
|
|
||||||
$this->assertEquals($controller->Form()->Fields()->Count(), 1); // disabled SecurityID token fields
|
$this->assertEquals($controller->Form()->Fields()->Count(), 1); // disabled SecurityID token fields
|
||||||
$this->assertEquals($controller->Form()->Actions()->Count(), 1);
|
$this->assertEquals($controller->Form()->Actions()->Count(), 1);
|
||||||
@ -175,7 +168,7 @@ class UserDefinedFormControllerTest extends FunctionalTest
|
|||||||
// generating the fieldset of fields
|
// generating the fieldset of fields
|
||||||
$form = $this->objFromFixture(UserDefinedForm::class, 'basic-form-page');
|
$form = $this->objFromFixture(UserDefinedForm::class, 'basic-form-page');
|
||||||
|
|
||||||
$controller = new UserDefinedFormControllerTest_Controller($form);
|
$controller = new UserDefinedFormController($form);
|
||||||
|
|
||||||
$formSteps = $controller->Form()->getFormFields();
|
$formSteps = $controller->Form()->getFormFields();
|
||||||
$firstStep = $formSteps->first();
|
$firstStep = $formSteps->first();
|
||||||
@ -185,9 +178,9 @@ class UserDefinedFormControllerTest extends FunctionalTest
|
|||||||
|
|
||||||
// custom error message on a form field
|
// custom error message on a form field
|
||||||
$requiredForm = $this->objFromFixture(UserDefinedForm::class, 'validation-form');
|
$requiredForm = $this->objFromFixture(UserDefinedForm::class, 'validation-form');
|
||||||
$controller = new UserDefinedFormControllerTest_Controller($requiredForm);
|
$controller = new UserDefinedFormController($requiredForm);
|
||||||
|
|
||||||
UserDefinedForm::config()->required_identifier = "*";
|
Config::modify()->set(UserDefinedForm::class, 'required_identifier', '*');
|
||||||
|
|
||||||
$formSteps = $controller->Form()->getFormFields();
|
$formSteps = $controller->Form()->getFormFields();
|
||||||
$firstStep = $formSteps->first();
|
$firstStep = $formSteps->first();
|
||||||
@ -201,7 +194,7 @@ class UserDefinedFormControllerTest extends FunctionalTest
|
|||||||
$field->RightTitle = 'Right Title';
|
$field->RightTitle = 'Right Title';
|
||||||
$field->write();
|
$field->write();
|
||||||
|
|
||||||
$controller = new UserDefinedFormControllerTest_Controller($form);
|
$controller = new UserDefinedFormController($form);
|
||||||
$formSteps = $controller->Form()->getFormFields();
|
$formSteps = $controller->Form()->getFormFields();
|
||||||
$firstStep = $formSteps->first();
|
$firstStep = $formSteps->first();
|
||||||
|
|
||||||
@ -209,7 +202,7 @@ class UserDefinedFormControllerTest extends FunctionalTest
|
|||||||
|
|
||||||
// test empty form
|
// test empty form
|
||||||
$emptyForm = $this->objFromFixture(UserDefinedForm::class, 'empty-form');
|
$emptyForm = $this->objFromFixture(UserDefinedForm::class, 'empty-form');
|
||||||
$controller = new UserDefinedFormControllerTest_Controller($emptyForm);
|
$controller = new UserDefinedFormController($emptyForm);
|
||||||
|
|
||||||
$this->assertFalse($controller->Form()->getFormFields()->exists());
|
$this->assertFalse($controller->Form()->getFormFields()->exists());
|
||||||
}
|
}
|
||||||
@ -219,7 +212,7 @@ class UserDefinedFormControllerTest extends FunctionalTest
|
|||||||
// generating the fieldset of actions
|
// generating the fieldset of actions
|
||||||
$form = $this->objFromFixture(UserDefinedForm::class, 'basic-form-page');
|
$form = $this->objFromFixture(UserDefinedForm::class, 'basic-form-page');
|
||||||
|
|
||||||
$controller = new UserDefinedFormControllerTest_Controller($form);
|
$controller = new UserDefinedFormController($form);
|
||||||
$actions = $controller->Form()->getFormActions();
|
$actions = $controller->Form()->getFormActions();
|
||||||
|
|
||||||
// by default will have 1 submit button which links to process
|
// by default will have 1 submit button which links to process
|
||||||
@ -230,7 +223,7 @@ class UserDefinedFormControllerTest extends FunctionalTest
|
|||||||
|
|
||||||
// the custom popup should have a reset button and a custom text
|
// the custom popup should have a reset button and a custom text
|
||||||
$custom = $this->objFromFixture(UserDefinedForm::class, 'form-with-reset-and-custom-action');
|
$custom = $this->objFromFixture(UserDefinedForm::class, 'form-with-reset-and-custom-action');
|
||||||
$controller = new UserDefinedFormControllerTest_Controller($custom);
|
$controller = new UserDefinedFormController($custom);
|
||||||
$actions = $controller->Form()->getFormActions();
|
$actions = $controller->Form()->getFormActions();
|
||||||
|
|
||||||
$expected = new FieldList(new FormAction('process', 'Custom Button'));
|
$expected = new FieldList(new FormAction('process', 'Custom Button'));
|
||||||
@ -247,11 +240,11 @@ class UserDefinedFormControllerTest extends FunctionalTest
|
|||||||
$form->Content = 'This is some content without a form nested between it';
|
$form->Content = 'This is some content without a form nested between it';
|
||||||
$form->doPublish();
|
$form->doPublish();
|
||||||
|
|
||||||
$controller = new UserDefinedFormControllerTest_Controller($form);
|
$controller = new UserDefinedFormController($form);
|
||||||
|
|
||||||
// check to see if $Form is replaced to inside the content
|
// check to see if $Form is replaced to inside the content
|
||||||
$index = new ArrayData($controller->index());
|
$index = new ArrayData($controller->index());
|
||||||
$parser = new CSSContentParser($index->renderWith(array(UserDefinedFormControllerTest::class)));
|
$parser = new CSSContentParser($index->renderWith(__CLASS__));
|
||||||
|
|
||||||
$this->checkTemplateIsCorrect($parser, $form);
|
$this->checkTemplateIsCorrect($parser, $form);
|
||||||
}
|
}
|
||||||
@ -260,11 +253,11 @@ class UserDefinedFormControllerTest extends FunctionalTest
|
|||||||
{
|
{
|
||||||
$form = $this->setupFormFrontend();
|
$form = $this->setupFormFrontend();
|
||||||
|
|
||||||
$controller = new UserDefinedFormControllerTest_Controller($form);
|
$controller = new UserDefinedFormController($form);
|
||||||
|
|
||||||
// check to see if $Form is replaced to inside the content
|
// check to see if $Form is replaced to inside the content
|
||||||
$index = new ArrayData($controller->index());
|
$index = new ArrayData($controller->index());
|
||||||
$parser = new CSSContentParser($index->renderWith(array(UserDefinedFormControllerTest::class)));
|
$parser = new CSSContentParser($index->renderWith(__CLASS__));
|
||||||
|
|
||||||
$this->checkTemplateIsCorrect($parser, $form);
|
$this->checkTemplateIsCorrect($parser, $form);
|
||||||
}
|
}
|
||||||
@ -307,21 +300,3 @@ class UserDefinedFormControllerTest extends FunctionalTest
|
|||||||
$this->assertEquals((string) $action[0]['value'], "Submit", "Submit button has default text");
|
$this->assertEquals((string) $action[0]['value'], "Submit", "Submit button has default text");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
class UserDefinedFormControllerTest_Controller extends UserDefinedForm_Controller implements TestOnly
|
|
||||||
{
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Overloaded to avoid inconsistencies between 2.4.2 and 2.4.3 (disables all security tokens in unit tests by default)
|
|
||||||
*/
|
|
||||||
public function Form()
|
|
||||||
{
|
|
||||||
$form = parent::Form();
|
|
||||||
|
|
||||||
if ($form) {
|
|
||||||
$form->disableSecurityToken();
|
|
||||||
}
|
|
||||||
|
|
||||||
return $form;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
@ -2,47 +2,33 @@
|
|||||||
|
|
||||||
namespace SilverStripe\UserForms\Test\Model;
|
namespace SilverStripe\UserForms\Test\Model;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
use SilverStripe\UserForms\Model\UserDefinedForm;
|
|
||||||
use SilverStripe\Versioned\Versioned;
|
|
||||||
use SilverStripe\Forms\GridField\GridField;
|
|
||||||
use SilverStripe\Forms\GridField\GridFieldDataColumns;
|
|
||||||
use SilverStripe\UserForms\Model\Recipient\UserDefinedForm_EmailRecipient;
|
|
||||||
use SilverStripe\UserForms\Model\EditableFormField\EditableEmailField;
|
|
||||||
use SilverStripe\Forms\DropdownField;
|
|
||||||
use SilverStripe\UserForms\Model\EditableFormField\EditableDropdown;
|
|
||||||
use SilverStripe\Security\Member;
|
|
||||||
use SilverStripe\UserForms\Model\EditableFormField\EditableFormField;
|
|
||||||
use SilverStripe\UserForms\Model\EditableCustomRule;
|
|
||||||
use SilverStripe\ORM\DB;
|
|
||||||
use SilverStripe\UserForms\Extension\UserFormValidator;
|
|
||||||
use SilverStripe\Control\Controller;
|
use SilverStripe\Control\Controller;
|
||||||
use SilverStripe\Forms\Form;
|
|
||||||
use SilverStripe\Forms\FieldList;
|
|
||||||
use SilverStripe\UserForms\Model\EditableFormField\EditableFieldGroup;
|
|
||||||
use SilverStripe\UserForms\Model\EditableFormField\EditableFieldGroupEnd;
|
|
||||||
use SilverStripe\Core\Convert;
|
use SilverStripe\Core\Convert;
|
||||||
use SilverStripe\Dev\FunctionalTest;
|
use SilverStripe\Dev\FunctionalTest;
|
||||||
|
use SilverStripe\Forms\DropdownField;
|
||||||
|
use SilverStripe\Forms\FieldList;
|
||||||
|
use SilverStripe\Forms\Form;
|
||||||
|
use SilverStripe\Forms\GridField\GridField;
|
||||||
|
use SilverStripe\Forms\GridField\GridFieldDataColumns;
|
||||||
|
use SilverStripe\ORM\DB;
|
||||||
|
use SilverStripe\Security\Member;
|
||||||
|
use SilverStripe\UserForms\Extension\UserFormValidator;
|
||||||
|
use SilverStripe\UserForms\Model\EditableCustomRule;
|
||||||
|
use SilverStripe\UserForms\Model\EditableFormField\EditableEmailField;
|
||||||
|
use SilverStripe\UserForms\Model\EditableFormField\EditableDropdown;
|
||||||
|
use SilverStripe\UserForms\Model\EditableFormField\EditableFormField;
|
||||||
|
use SilverStripe\UserForms\Model\EditableFormField\EditableFieldGroup;
|
||||||
|
use SilverStripe\UserForms\Model\EditableFormField\EditableFieldGroupEnd;
|
||||||
|
use SilverStripe\UserForms\Model\Recipient\EmailRecipient;
|
||||||
|
use SilverStripe\UserForms\Model\UserDefinedForm;
|
||||||
|
use SilverStripe\Versioned\Versioned;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @package userforms
|
* @package userforms
|
||||||
*/
|
*/
|
||||||
class UserDefinedFormTest extends FunctionalTest
|
class UserDefinedFormTest extends FunctionalTest
|
||||||
{
|
{
|
||||||
|
protected static $fixture_file = 'UserDefinedFormTest.yml';
|
||||||
public static $fixture_file = 'UserDefinedFormTest.yml';
|
|
||||||
|
|
||||||
public function testRollbackToVersion()
|
public function testRollbackToVersion()
|
||||||
{
|
{
|
||||||
@ -64,12 +50,12 @@ class UserDefinedFormTest extends FunctionalTest
|
|||||||
$form->doPublish();
|
$form->doPublish();
|
||||||
|
|
||||||
// check published site
|
// check published site
|
||||||
$updated = Versioned::get_one_by_stage(UserDefinedForm::class, "Stage", "\"UserDefinedForm\".\"ID\" = $form->ID");
|
$updated = Versioned::get_one_by_stage(UserDefinedForm::class, 'Stage', \"UserDefinedForm\".\"ID\" = $form->ID");
|
||||||
$this->assertEquals($updated->SubmitButtonText, 'Updated Button Text');
|
$this->assertEquals($updated->SubmitButtonText, 'Updated Button Text');
|
||||||
|
|
||||||
$form->doRollbackTo($origVersion);
|
$form->doRollbackTo($origVersion);
|
||||||
|
|
||||||
$orignal = Versioned::get_one_by_stage(UserDefinedForm::class, "Stage", "\"UserDefinedForm\".\"ID\" = $form->ID");
|
$orignal = Versioned::get_one_by_stage(UserDefinedForm::class, 'Stage', "\"UserDefinedForm\".\"ID\" = $form->ID");
|
||||||
$this->assertEquals($orignal->SubmitButtonText, 'Button Text');
|
$this->assertEquals($orignal->SubmitButtonText, 'Button Text');
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -112,7 +98,7 @@ class UserDefinedFormTest extends FunctionalTest
|
|||||||
|
|
||||||
$form = $this->objFromFixture(UserDefinedForm::class, 'basic-form-page');
|
$form = $this->objFromFixture(UserDefinedForm::class, 'basic-form-page');
|
||||||
|
|
||||||
$popup = new UserDefinedForm_EmailRecipient();
|
$popup = new EmailRecipient();
|
||||||
$popup->FormID = $form->ID;
|
$popup->FormID = $form->ID;
|
||||||
|
|
||||||
$fields = $popup->getCMSFields();
|
$fields = $popup->getCMSFields();
|
||||||
@ -145,7 +131,7 @@ class UserDefinedFormTest extends FunctionalTest
|
|||||||
|
|
||||||
public function testGetEmailBodyContent()
|
public function testGetEmailBodyContent()
|
||||||
{
|
{
|
||||||
$recipient = new UserDefinedForm_EmailRecipient();
|
$recipient = new EmailRecipient();
|
||||||
|
|
||||||
$emailBody = 'not html';
|
$emailBody = 'not html';
|
||||||
$emailBodyHtml = '<p>html</p>';
|
$emailBodyHtml = '<p>html</p>';
|
||||||
@ -167,16 +153,16 @@ class UserDefinedFormTest extends FunctionalTest
|
|||||||
|
|
||||||
public function testGetEmailTemplateDropdownValues()
|
public function testGetEmailTemplateDropdownValues()
|
||||||
{
|
{
|
||||||
$recipient = new UserDefinedForm_EmailRecipient();
|
$recipient = new EmailRecipient();
|
||||||
|
|
||||||
$defaultValues = array('SubmittedFormEmail' => 'SubmittedFormEmail');
|
$defaultValues = ['SubmittedFormEmail' => 'SubmittedFormEmail'];
|
||||||
|
|
||||||
$this->assertEquals($recipient->getEmailTemplateDropdownValues(), $defaultValues);
|
$this->assertEquals($recipient->getEmailTemplateDropdownValues(), $defaultValues);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testEmailTemplateExists()
|
public function testEmailTemplateExists()
|
||||||
{
|
{
|
||||||
$recipient = new UserDefinedForm_EmailRecipient();
|
$recipient = new EmailRecipient();
|
||||||
|
|
||||||
// Set the default template
|
// Set the default template
|
||||||
$recipient->EmailTemplate = current(array_keys($recipient->getEmailTemplateDropdownValues()));
|
$recipient->EmailTemplate = current(array_keys($recipient->getEmailTemplateDropdownValues()));
|
||||||
@ -220,7 +206,7 @@ class UserDefinedFormTest extends FunctionalTest
|
|||||||
|
|
||||||
$form->doPublish();
|
$form->doPublish();
|
||||||
|
|
||||||
$live = Versioned::get_one_by_stage(UserDefinedForm::class, "Live", "\"UserDefinedForm_Live\".\"ID\" = $form->ID");
|
$live = Versioned::get_one_by_stage(UserDefinedForm::class, 'Live', "\"UserDefinedForm_Live\".\"ID\" = $form->ID");
|
||||||
|
|
||||||
$this->assertNotNull($live);
|
$this->assertNotNull($live);
|
||||||
$this->assertEquals(2, $live->Fields()->Count()); // one page and one field
|
$this->assertEquals(2, $live->Fields()->Count()); // one page and one field
|
||||||
@ -228,17 +214,17 @@ class UserDefinedFormTest extends FunctionalTest
|
|||||||
$dropdown = $this->objFromFixture(EditableDropdown::class, 'basic-dropdown');
|
$dropdown = $this->objFromFixture(EditableDropdown::class, 'basic-dropdown');
|
||||||
$form->Fields()->add($dropdown);
|
$form->Fields()->add($dropdown);
|
||||||
|
|
||||||
$stage = Versioned::get_one_by_stage(UserDefinedForm::class, "Stage", "\"UserDefinedForm\".\"ID\" = $form->ID");
|
$stage = Versioned::get_one_by_stage(UserDefinedForm::class, 'Stage', "\"UserDefinedForm\".\"ID\" = $form->ID");
|
||||||
$this->assertEquals(3, $stage->Fields()->Count());
|
$this->assertEquals(3, $stage->Fields()->Count());
|
||||||
|
|
||||||
// should not have published the dropdown
|
// should not have published the dropdown
|
||||||
$liveDropdown = Versioned::get_one_by_stage(EditableFormField::class, "Live", "\"EditableFormField_Live\".\"ID\" = $dropdown->ID");
|
$liveDropdown = Versioned::get_one_by_stage(EditableFormField::class, 'Live', "\"EditableFormField_Live\".\"ID\" = $dropdown->ID");
|
||||||
$this->assertNull($liveDropdown);
|
$this->assertNull($liveDropdown);
|
||||||
|
|
||||||
// when publishing it should have added it
|
// when publishing it should have added it
|
||||||
$form->doPublish();
|
$form->doPublish();
|
||||||
|
|
||||||
$live = Versioned::get_one_by_stage(UserDefinedForm::class, "Live", "\"UserDefinedForm_Live\".\"ID\" = $form->ID");
|
$live = Versioned::get_one_by_stage(UserDefinedForm::class, 'Live', "\"UserDefinedForm_Live\".\"ID\" = $form->ID");
|
||||||
$this->assertEquals(3, $live->Fields()->Count());
|
$this->assertEquals(3, $live->Fields()->Count());
|
||||||
|
|
||||||
// edit the title
|
// edit the title
|
||||||
@ -246,12 +232,12 @@ class UserDefinedFormTest extends FunctionalTest
|
|||||||
$text->Title = 'Edited title';
|
$text->Title = 'Edited title';
|
||||||
$text->write();
|
$text->write();
|
||||||
|
|
||||||
$liveText = Versioned::get_one_by_stage(EditableFormField::class, "Live", "\"EditableFormField_Live\".\"ID\" = $text->ID");
|
$liveText = Versioned::get_one_by_stage(EditableFormField::class, 'Live', "\"EditableFormField_Live\".\"ID\" = $text->ID");
|
||||||
$this->assertFalse($liveText->Title == $text->Title);
|
$this->assertFalse($liveText->Title == $text->Title);
|
||||||
|
|
||||||
$form->doPublish();
|
$form->doPublish();
|
||||||
|
|
||||||
$liveText = Versioned::get_one_by_stage(EditableFormField::class, "Live", "\"EditableFormField_Live\".\"ID\" = $text->ID");
|
$liveText = Versioned::get_one_by_stage(EditableFormField::class, 'Live', "\"EditableFormField_Live\".\"ID\" = $text->ID");
|
||||||
$this->assertTrue($liveText->Title == $text->Title);
|
$this->assertTrue($liveText->Title == $text->Title);
|
||||||
|
|
||||||
// Add a display rule to the dropdown
|
// Add a display rule to the dropdown
|
||||||
@ -262,24 +248,24 @@ class UserDefinedFormTest extends FunctionalTest
|
|||||||
$ruleID = $displayRule->ID;
|
$ruleID = $displayRule->ID;
|
||||||
|
|
||||||
// Not live
|
// Not live
|
||||||
$liveRule = Versioned::get_one_by_stage(EditableCustomRule::class, "Live", "\"EditableCustomRule_Live\".\"ID\" = $ruleID");
|
$liveRule = Versioned::get_one_by_stage(EditableCustomRule::class, 'Live', "\"EditableCustomRule_Live\".\"ID\" = $ruleID");
|
||||||
$this->assertEmpty($liveRule);
|
$this->assertEmpty($liveRule);
|
||||||
|
|
||||||
// Publish form, it's now live
|
// Publish form, it's now live
|
||||||
$form->doPublish();
|
$form->doPublish();
|
||||||
$liveRule = Versioned::get_one_by_stage(EditableCustomRule::class, "Live", "\"EditableCustomRule_Live\".\"ID\" = $ruleID");
|
$liveRule = Versioned::get_one_by_stage(EditableCustomRule::class, 'Live', "\"EditableCustomRule_Live\".\"ID\" = $ruleID");
|
||||||
$this->assertNotEmpty($liveRule);
|
$this->assertNotEmpty($liveRule);
|
||||||
|
|
||||||
// Remove rule
|
// Remove rule
|
||||||
$displayRule->delete();
|
$displayRule->delete();
|
||||||
|
|
||||||
// Live rule still exists
|
// Live rule still exists
|
||||||
$liveRule = Versioned::get_one_by_stage(EditableCustomRule::class, "Live", "\"EditableCustomRule_Live\".\"ID\" = $ruleID");
|
$liveRule = Versioned::get_one_by_stage(EditableCustomRule::class, 'Live', "\"EditableCustomRule_Live\".\"ID\" = $ruleID");
|
||||||
$this->assertNotEmpty($liveRule);
|
$this->assertNotEmpty($liveRule);
|
||||||
|
|
||||||
// Publish form, it should remove this rule
|
// Publish form, it should remove this rule
|
||||||
$form->doPublish();
|
$form->doPublish();
|
||||||
$liveRule = Versioned::get_one_by_stage(EditableCustomRule::class, "Live", "\"EditableCustomRule_Live\".\"ID\" = $ruleID");
|
$liveRule = Versioned::get_one_by_stage(EditableCustomRule::class, 'Live', "\"EditableCustomRule_Live\".\"ID\" = $ruleID");
|
||||||
$this->assertEmpty($liveRule);
|
$this->assertEmpty($liveRule);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -292,7 +278,7 @@ class UserDefinedFormTest extends FunctionalTest
|
|||||||
$form->doPublish();
|
$form->doPublish();
|
||||||
|
|
||||||
// assert that it exists and has a field
|
// assert that it exists and has a field
|
||||||
$live = Versioned::get_one_by_stage(UserDefinedForm::class, "Live", "\"UserDefinedForm_Live\".\"ID\" = $form->ID");
|
$live = Versioned::get_one_by_stage(UserDefinedForm::class, 'Live', "\"UserDefinedForm_Live\".\"ID\" = $form->ID");
|
||||||
|
|
||||||
$this->assertTrue(isset($live));
|
$this->assertTrue(isset($live));
|
||||||
$this->assertEquals(2, DB::query("SELECT COUNT(*) FROM \"EditableFormField_Live\"")->value());
|
$this->assertEquals(2, DB::query("SELECT COUNT(*) FROM \"EditableFormField_Live\"")->value());
|
||||||
@ -300,7 +286,7 @@ class UserDefinedFormTest extends FunctionalTest
|
|||||||
// unpublish
|
// unpublish
|
||||||
$form->doUnpublish();
|
$form->doUnpublish();
|
||||||
|
|
||||||
$this->assertNull(Versioned::get_one_by_stage(UserDefinedForm::class, "Live", "\"UserDefinedForm_Live\".\"ID\" = $form->ID"));
|
$this->assertNull(Versioned::get_one_by_stage(UserDefinedForm::class, 'Live', "\"UserDefinedForm_Live\".\"ID\" = $form->ID"));
|
||||||
$this->assertEquals(0, DB::query("SELECT COUNT(*) FROM \"EditableFormField_Live\"")->value());
|
$this->assertEquals(0, DB::query("SELECT COUNT(*) FROM \"EditableFormField_Live\"")->value());
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -319,14 +305,14 @@ class UserDefinedFormTest extends FunctionalTest
|
|||||||
$field->write();
|
$field->write();
|
||||||
|
|
||||||
// check that the published version is not updated
|
// check that the published version is not updated
|
||||||
$live = Versioned::get_one_by_stage(EditableFormField::class, "Live", "\"EditableFormField_Live\".\"ID\" = $field->ID");
|
$live = Versioned::get_one_by_stage(EditableFormField::class, 'Live', "\"EditableFormField_Live\".\"ID\" = $field->ID");
|
||||||
$this->assertEquals('Title', $live->Title);
|
$this->assertEquals('Title', $live->Title);
|
||||||
|
|
||||||
// revert back to the live data
|
// revert back to the live data
|
||||||
$form->doRevertToLive();
|
$form->doRevertToLive();
|
||||||
$form->flushCache();
|
$form->flushCache();
|
||||||
|
|
||||||
$check = Versioned::get_one_by_stage(EditableFormField::class, "Stage", "\"EditableFormField\".\"ID\" = $field->ID");
|
$check = Versioned::get_one_by_stage(EditableFormField::class, 'Stage', "\"EditableFormField\".\"ID\" = $field->ID");
|
||||||
|
|
||||||
$this->assertEquals('Title', $check->Title);
|
$this->assertEquals('Title', $check->Title);
|
||||||
}
|
}
|
||||||
@ -392,85 +378,83 @@ class UserDefinedFormTest extends FunctionalTest
|
|||||||
->sort('EmailAddress')
|
->sort('EmailAddress')
|
||||||
->column('EmailAddress');
|
->column('EmailAddress');
|
||||||
$this->assertEquals(
|
$this->assertEquals(
|
||||||
array(
|
[
|
||||||
'filtered1@example.com',
|
'filtered1@example.com',
|
||||||
'filtered2@example.com',
|
'filtered2@example.com',
|
||||||
'unfiltered@example.com'
|
'unfiltered@example.com'
|
||||||
),
|
],
|
||||||
$result0
|
$result0
|
||||||
);
|
);
|
||||||
|
|
||||||
// check filters based on given data
|
// check filters based on given data
|
||||||
$result1 = $form->FilteredEmailRecipients(
|
$result1 = $form->FilteredEmailRecipients(
|
||||||
array(
|
[
|
||||||
'your-name' => 'Value',
|
'your-name' => 'Value',
|
||||||
'address' => '',
|
'address' => '',
|
||||||
'street' => 'Anything',
|
'street' => 'Anything',
|
||||||
'city' => 'Matches Not Equals',
|
'city' => 'Matches Not Equals',
|
||||||
'colours' => array('Red') // matches 2
|
'colours' => ['Red'] // matches 2
|
||||||
), null
|
], null
|
||||||
)
|
)
|
||||||
->sort('EmailAddress')
|
->sort('EmailAddress')
|
||||||
->column('EmailAddress');
|
->column('EmailAddress');
|
||||||
$this->assertEquals(
|
$this->assertEquals(
|
||||||
array(
|
[
|
||||||
'filtered2@example.com',
|
'filtered2@example.com',
|
||||||
'unfiltered@example.com'
|
'unfiltered@example.com'
|
||||||
),
|
],
|
||||||
$result1
|
$result1
|
||||||
);
|
);
|
||||||
|
|
||||||
// Check all positive matches
|
// Check all positive matches
|
||||||
$result2 = $form->FilteredEmailRecipients(
|
$result2 = $form->FilteredEmailRecipients(
|
||||||
array(
|
[
|
||||||
'your-name' => '',
|
'your-name' => '',
|
||||||
'address' => 'Anything',
|
'address' => 'Anything',
|
||||||
'street' => 'Matches Equals',
|
'street' => 'Matches Equals',
|
||||||
'city' => 'Anything',
|
'city' => 'Anything',
|
||||||
'colours' => array('Red', 'Blue') // matches 2
|
'colours' => ['Red', 'Blue'] // matches 2
|
||||||
), null
|
], null
|
||||||
)
|
)
|
||||||
->sort('EmailAddress')
|
->sort('EmailAddress')
|
||||||
->column('EmailAddress');
|
->column('EmailAddress');
|
||||||
$this->assertEquals(
|
$this->assertEquals(
|
||||||
array(
|
[
|
||||||
'filtered1@example.com',
|
'filtered1@example.com',
|
||||||
'filtered2@example.com',
|
'filtered2@example.com',
|
||||||
'unfiltered@example.com'
|
'unfiltered@example.com'
|
||||||
),
|
],
|
||||||
$result2
|
$result2
|
||||||
);
|
);
|
||||||
|
|
||||||
$result3 = $form->FilteredEmailRecipients(
|
$result3 = $form->FilteredEmailRecipients(
|
||||||
array(
|
[
|
||||||
'your-name' => 'Should be blank but is not',
|
'your-name' => 'Should be blank but is not',
|
||||||
'address' => 'Anything',
|
'address' => 'Anything',
|
||||||
'street' => 'Matches Equals',
|
'street' => 'Matches Equals',
|
||||||
'city' => 'Anything',
|
'city' => 'Anything',
|
||||||
'colours' => array('Blue')
|
'colours' => ['Blue']
|
||||||
), null
|
], null
|
||||||
)->column('EmailAddress');
|
)->column('EmailAddress');
|
||||||
$this->assertEquals(
|
$this->assertEquals(
|
||||||
array(
|
[
|
||||||
'unfiltered@example.com'
|
'unfiltered@example.com'
|
||||||
),
|
],
|
||||||
$result3
|
$result3
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
||||||
$result4 = $form->FilteredEmailRecipients(
|
$result4 = $form->FilteredEmailRecipients(
|
||||||
array(
|
[
|
||||||
'your-name' => '',
|
'your-name' => '',
|
||||||
'address' => 'Anything',
|
'address' => 'Anything',
|
||||||
'street' => 'Wrong value for this field',
|
'street' => 'Wrong value for this field',
|
||||||
'city' => '',
|
'city' => '',
|
||||||
'colours' => array('Blue', 'Green')
|
'colours' => ['Blue', 'Green']
|
||||||
), null
|
], null
|
||||||
)->column('EmailAddress');
|
)->column('EmailAddress');
|
||||||
$this->assertEquals(
|
$this->assertEquals(
|
||||||
array(
|
['unfiltered@example.com'],
|
||||||
'unfiltered@example.com'
|
|
||||||
),
|
|
||||||
$result4
|
$result4
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
@ -497,7 +481,7 @@ class UserDefinedFormTest extends FunctionalTest
|
|||||||
$this->logInWithPermission('ADMIN');
|
$this->logInWithPermission('ADMIN');
|
||||||
|
|
||||||
// test invalid email addresses fail validation
|
// test invalid email addresses fail validation
|
||||||
$recipient = $this->objFromFixture(UserDefinedForm_EmailRecipient::class,
|
$recipient = $this->objFromFixture(EmailRecipient::class,
|
||||||
'invalid-recipient-list');
|
'invalid-recipient-list');
|
||||||
$result = $recipient->validate();
|
$result = $recipient->validate();
|
||||||
$this->assertFalse($result->valid());
|
$this->assertFalse($result->valid());
|
||||||
@ -505,7 +489,7 @@ class UserDefinedFormTest extends FunctionalTest
|
|||||||
$this->assertNotContains('filtered2@example.com', $result->message());
|
$this->assertNotContains('filtered2@example.com', $result->message());
|
||||||
|
|
||||||
// test valid email addresses pass validation
|
// test valid email addresses pass validation
|
||||||
$recipient = $this->objFromFixture(UserDefinedForm_EmailRecipient::class,
|
$recipient = $this->objFromFixture(EmailRecipient::class,
|
||||||
'valid-recipient-list');
|
'valid-recipient-list');
|
||||||
$result = $recipient->validate();
|
$result = $recipient->validate();
|
||||||
$this->assertTrue($result->valid());
|
$this->assertTrue($result->valid());
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
EditableFormStep:
|
SilverStripe\UserForms\Model\EditableFormField\EditableFormStep:
|
||||||
form1step1:
|
form1step1:
|
||||||
Title: 'Step 1'
|
Title: 'Step 1'
|
||||||
form3step1:
|
form3step1:
|
||||||
@ -16,7 +16,7 @@ EditableFormStep:
|
|||||||
form7step1:
|
form7step1:
|
||||||
Title: 'Step 1'
|
Title: 'Step 1'
|
||||||
|
|
||||||
EditableOption:
|
SilverStripe\UserForms\Model\EditableFormField\EditableOption:
|
||||||
option-1:
|
option-1:
|
||||||
Name: Option1
|
Name: Option1
|
||||||
Title: Option 1
|
Title: Option 1
|
||||||
@ -61,7 +61,7 @@ EditableOption:
|
|||||||
Name: Option9
|
Name: Option9
|
||||||
Title: Green
|
Title: Green
|
||||||
|
|
||||||
EditableTextField:
|
SilverStripe\UserForms\Model\EditableFormField\EditableTextField:
|
||||||
basic-text:
|
basic-text:
|
||||||
Name: basic-text-name
|
Name: basic-text-name
|
||||||
Title: Basic Text Field
|
Title: Basic Text Field
|
||||||
@ -117,18 +117,18 @@ EditableTextField:
|
|||||||
Title: Summary Text Field
|
Title: Summary Text Field
|
||||||
ShowInSummary: false
|
ShowInSummary: false
|
||||||
|
|
||||||
EditableDropdown:
|
SilverStripe\UserForms\Model\EditableFormField\EditableDropdown:
|
||||||
basic-dropdown:
|
basic-dropdown:
|
||||||
Name: basic-dropdown
|
Name: basic-dropdown
|
||||||
Title: Basic Dropdown Field
|
Title: Basic Dropdown Field
|
||||||
Options: =>EditableOption.option-1, =>EditableOption.option-2
|
Options: =>SilverStripe\UserForms\Model\EditableFormField\EditableOption.option-1, =>SilverStripe\UserForms\Model\EditableFormField\EditableOption.option-2
|
||||||
|
|
||||||
department-dropdown:
|
department-dropdown:
|
||||||
Name: department
|
Name: department
|
||||||
Title: Department
|
Title: Department
|
||||||
Options: =>EditableOption.department-1, =>EditableOption.department-2
|
Options: =>SilverStripe\UserForms\Model\EditableFormField\EditableOption.department-1, =>SilverStripe\UserForms\Model\EditableFormField\EditableOption.department-2
|
||||||
|
|
||||||
EditableCheckbox:
|
SilverStripe\UserForms\Model\EditableFormField\EditableCheckbox:
|
||||||
checkbox-1:
|
checkbox-1:
|
||||||
Name: checkbox-1
|
Name: checkbox-1
|
||||||
Title: Checkbox 1
|
Title: Checkbox 1
|
||||||
@ -137,18 +137,18 @@ EditableCheckbox:
|
|||||||
Name: checkbox-1
|
Name: checkbox-1
|
||||||
Title: Checkbox 1
|
Title: Checkbox 1
|
||||||
|
|
||||||
EditableCheckboxGroupField:
|
SilverStripe\UserForms\Model\EditableFormField\EditableCheckboxGroupField:
|
||||||
checkbox-group:
|
checkbox-group:
|
||||||
Name: check-box-group
|
Name: check-box-group
|
||||||
Title: Check box group
|
Title: Check box group
|
||||||
Options: =>EditableOption.option-3, =>EditableOption.option-4
|
Options: =>SilverStripe\UserForms\Model\EditableFormField\EditableOption.option-3, =>SilverStripe\UserForms\Model\EditableFormField\EditableOption.option-4
|
||||||
|
|
||||||
colour-checkbox-group:
|
colour-checkbox-group:
|
||||||
Name: colours
|
Name: colours
|
||||||
Title: 'Select Colours'
|
Title: 'Select Colours'
|
||||||
Options: =>EditableOption.option-7, =>EditableOption.option-8, =>EditableOption.option-9
|
Options: =>SilverStripe\UserForms\Model\EditableFormField\EditableOption.option-7, =>SilverStripe\UserForms\Model\EditableFormField\EditableOption.option-8, =>SilverStripe\UserForms\Model\EditableFormField\EditableOption.option-9
|
||||||
|
|
||||||
EditableEmailField:
|
SilverStripe\UserForms\Model\EditableFormField\EditableEmailField:
|
||||||
email-field:
|
email-field:
|
||||||
Name: email-field
|
Name: email-field
|
||||||
Title: Email
|
Title: Email
|
||||||
@ -158,49 +158,49 @@ EditableEmailField:
|
|||||||
Title: Enter your email
|
Title: Enter your email
|
||||||
CustomErrorMessage: 'That email is not valid'
|
CustomErrorMessage: 'That email is not valid'
|
||||||
|
|
||||||
EditableRadioField:
|
SilverStripe\UserForms\Model\EditableFormField\EditableRadioField:
|
||||||
radio-field:
|
radio-field:
|
||||||
Name: radio-option
|
Name: radio-option
|
||||||
Title: Radio Option
|
Title: Radio Option
|
||||||
Options: =>EditableOption.option-5, =>EditableOption.option-6
|
Options: =>SilverStripe\UserForms\Model\EditableFormField\EditableOption.option-5, =>SilverStripe\UserForms\Model\EditableFormField\EditableOption.option-6
|
||||||
|
|
||||||
EditableFieldGroupEnd:
|
SilverStripe\UserForms\Model\EditableFormField\EditableFieldGroupEnd:
|
||||||
group1end:
|
group1end:
|
||||||
Name: group1end
|
Name: group1end
|
||||||
|
|
||||||
EditableFieldGroup:
|
SilverStripe\UserForms\Model\EditableFormField\EditableFieldGroup:
|
||||||
group1start:
|
group1start:
|
||||||
Name: group1start
|
Name: group1start
|
||||||
End: =>EditableFieldGroupEnd.group1end
|
End: =>SilverStripe\UserForms\Model\EditableFormField\EditableFieldGroupEnd.group1end
|
||||||
|
|
||||||
UserDefinedForm_EmailRecipientCondition:
|
SilverStripe\UserForms\Model\Recipient\EmailRecipientCondition:
|
||||||
# filtered recipient 1
|
# filtered recipient 1
|
||||||
blank-rule:
|
blank-rule:
|
||||||
ConditionOption: IsBlank
|
ConditionOption: IsBlank
|
||||||
ConditionField: =>EditableTextField.your-name-field
|
ConditionField: =>SilverStripe\UserForms\Model\EditableFormField\EditableTextField.your-name-field
|
||||||
not-blank-rule:
|
not-blank-rule:
|
||||||
ConditionOption: IsNotBlank
|
ConditionOption: IsNotBlank
|
||||||
ConditionField: =>EditableTextField.address-field
|
ConditionField: =>SilverStripe\UserForms\Model\EditableFormField\EditableTextField.address-field
|
||||||
equals-rule:
|
equals-rule:
|
||||||
ConditionOption: Equals
|
ConditionOption: Equals
|
||||||
ConditionField: =>EditableTextField.street-field
|
ConditionField: =>SilverStripe\UserForms\Model\EditableFormField\EditableTextField.street-field
|
||||||
ConditionValue: 'Matches Equals'
|
ConditionValue: 'Matches Equals'
|
||||||
not-equals-rule:
|
not-equals-rule:
|
||||||
ConditionOption: NotEquals
|
ConditionOption: NotEquals
|
||||||
ConditionField: =>EditableTextField.city-field
|
ConditionField: =>SilverStripe\UserForms\Model\EditableFormField\EditableTextField.city-field
|
||||||
ConditionValue: 'Matches Not Equals'
|
ConditionValue: 'Matches Not Equals'
|
||||||
# filtered recipient 2
|
# filtered recipient 2
|
||||||
group-equals-rule:
|
group-equals-rule:
|
||||||
ConditionOption: Equals
|
ConditionOption: Equals
|
||||||
ConditionField: =>EditableCheckboxGroupField.colour-checkbox-group
|
ConditionField: =>SilverStripe\UserForms\Model\EditableFormField\EditableCheckboxGroupField.colour-checkbox-group
|
||||||
ConditionValue: Red
|
ConditionValue: Red
|
||||||
group-not-equals-rule:
|
group-not-equals-rule:
|
||||||
ConditionOption: NotEquals
|
ConditionOption: NotEquals
|
||||||
ConditionField: =>EditableCheckboxGroupField.colour-checkbox-group
|
ConditionField: =>SilverStripe\UserForms\Model\EditableFormField\EditableCheckboxGroupField.colour-checkbox-group
|
||||||
ConditionValue: Blue
|
ConditionValue: Blue
|
||||||
|
|
||||||
|
|
||||||
UserDefinedForm_EmailRecipient:
|
SilverStripe\UserForms\Model\Recipient\EmailRecipient:
|
||||||
recipient-1:
|
recipient-1:
|
||||||
EmailAddress: test@example.com
|
EmailAddress: test@example.com
|
||||||
EmailSubject: Email Subject
|
EmailSubject: Email Subject
|
||||||
@ -227,14 +227,14 @@ UserDefinedForm_EmailRecipient:
|
|||||||
EmailAddress: filtered1@example.com
|
EmailAddress: filtered1@example.com
|
||||||
EmailSubject: Email Subject
|
EmailSubject: Email Subject
|
||||||
EmailFrom: no-reply@example.com
|
EmailFrom: no-reply@example.com
|
||||||
CustomRules: =>UserDefinedForm_EmailRecipientCondition.blank-rule, =>UserDefinedForm_EmailRecipientCondition.not-blank-rule, =>UserDefinedForm_EmailRecipientCondition.equals-rule, =>UserDefinedForm_EmailRecipientCondition.not-equals-rule
|
CustomRules: =>SilverStripe\UserForms\Model\Recipient\EmailRecipientCondition.blank-rule, =>SilverStripe\UserForms\Model\Recipient\EmailRecipientCondition.not-blank-rule, =>SilverStripe\UserForms\Model\Recipient\EmailRecipientCondition.equals-rule, =>SilverStripe\UserForms\Model\Recipient\EmailRecipientCondition.not-equals-rule
|
||||||
CustomRulesCondition: 'And'
|
CustomRulesCondition: 'And'
|
||||||
|
|
||||||
filtered-recipient-2:
|
filtered-recipient-2:
|
||||||
EmailAddress: filtered2@example.com
|
EmailAddress: filtered2@example.com
|
||||||
EmailSubject: Email Subject
|
EmailSubject: Email Subject
|
||||||
EmailFrom: no-reply@example.com
|
EmailFrom: no-reply@example.com
|
||||||
CustomRules: =>UserDefinedForm_EmailRecipientCondition.group-equals-rule, =>UserDefinedForm_EmailRecipientCondition.group-not-equals-rule
|
CustomRules: =>SilverStripe\UserForms\Model\Recipient\EmailRecipientCondition.group-equals-rule, =>SilverStripe\UserForms\Model\Recipient\EmailRecipientCondition.group-not-equals-rule
|
||||||
CustomRulesCondition: 'Or'
|
CustomRulesCondition: 'Or'
|
||||||
|
|
||||||
valid-recipient-list:
|
valid-recipient-list:
|
||||||
@ -247,17 +247,17 @@ UserDefinedForm_EmailRecipient:
|
|||||||
EmailSubject: Email Subject
|
EmailSubject: Email Subject
|
||||||
EmailFrom: no-reply@example.com
|
EmailFrom: no-reply@example.com
|
||||||
|
|
||||||
UserDefinedForm:
|
SilverStripe\UserForms\Model\UserDefinedForm:
|
||||||
basic-form-page:
|
basic-form-page:
|
||||||
Content: '<p>Here is my form</p><p>$UserDefinedForm</p><p>Thank you for filling it out</p>'
|
Content: '<p>Here is my form</p><p>$UserDefinedForm</p><p>Thank you for filling it out</p>'
|
||||||
Title: User Defined Form
|
Title: User Defined Form
|
||||||
Fields: =>EditableFormStep.form1step1,=>EditableTextField.basic-text
|
Fields: =>SilverStripe\UserForms\Model\EditableFormField\EditableFormStep.form1step1,=>SilverStripe\UserForms\Model\EditableFormField\EditableTextField.basic-text
|
||||||
EmailRecipients: =>UserDefinedForm_EmailRecipient.recipient-1, =>UserDefinedForm_EmailRecipient.no-html, =>UserDefinedForm_EmailRecipient.no-data
|
EmailRecipients: =>SilverStripe\UserForms\Model\Recipient\EmailRecipient.recipient-1, =>SilverStripe\UserForms\Model\Recipient\EmailRecipient.no-html, =>SilverStripe\UserForms\Model\Recipient\EmailRecipient.no-data
|
||||||
|
|
||||||
page-with-group:
|
page-with-group:
|
||||||
Content: 'Page with group'
|
Content: 'Page with group'
|
||||||
Title: 'page with group'
|
Title: 'page with group'
|
||||||
Fields: =>EditableFormStep.form7step1, =>EditableFieldGroup.group1start, =>EditableTextField.some-field, =>EditableFieldGroupEnd.group1end
|
Fields: =>SilverStripe\UserForms\Model\EditableFormField\EditableFormStep.form7step1, =>SilverStripe\UserForms\Model\EditableFormField\EditableFieldGroup.group1start, =>SilverStripe\UserForms\Model\EditableFormField\EditableTextField.some-field, =>SilverStripe\UserForms\Model\EditableFormField\EditableFieldGroupEnd.group1end
|
||||||
|
|
||||||
form-with-reset-and-custom-action:
|
form-with-reset-and-custom-action:
|
||||||
Title: Form with Reset Action
|
Title: Form with Reset Action
|
||||||
@ -266,28 +266,28 @@ UserDefinedForm:
|
|||||||
|
|
||||||
validation-form:
|
validation-form:
|
||||||
Title: Validation Form
|
Title: Validation Form
|
||||||
Fields: =>EditableFormStep.form3step1,=>EditableTextField.required-text
|
Fields: =>SilverStripe\UserForms\Model\EditableFormField\EditableFormStep.form3step1,=>SilverStripe\UserForms\Model\EditableFormField\EditableTextField.required-text
|
||||||
|
|
||||||
custom-rules-form:
|
custom-rules-form:
|
||||||
Title: Custom Rules Form
|
Title: Custom Rules Form
|
||||||
Fields: =>EditableCheckbox.checkbox-2, =>EditableTextField.basic-text-2
|
Fields: =>SilverStripe\UserForms\Model\EditableFormField\EditableCheckbox.checkbox-2, =>SilverStripe\UserForms\Model\EditableFormField\EditableTextField.basic-text-2
|
||||||
|
|
||||||
summary-rules-form:
|
summary-rules-form:
|
||||||
Title: Summary Fields Form
|
Title: Summary Fields Form
|
||||||
Fields: =>EditableTextField.summary-show, =>EditableTextField.summary-hide
|
Fields: =>SilverStripe\UserForms\Model\EditableFormField\EditableTextField.summary-show, =>SilverStripe\UserForms\Model\EditableFormField\EditableTextField.summary-hide
|
||||||
|
|
||||||
empty-form:
|
empty-form:
|
||||||
Title: Empty Form
|
Title: Empty Form
|
||||||
|
|
||||||
filtered-form-page:
|
filtered-form-page:
|
||||||
Title: 'Page with filtered recipients'
|
Title: 'Page with filtered recipients'
|
||||||
Fields: =>EditableFormStep.form5step1,=>EditableCheckboxGroupField.checkbox-group, =>EditableTextField.your-name-field, =>EditableTextField.street-field, =>EditableTextField.city-field
|
Fields: =>SilverStripe\UserForms\Model\EditableFormField\EditableFormStep.form5step1,=>SilverStripe\UserForms\Model\EditableFormField\EditableCheckboxGroupField.checkbox-group, =>SilverStripe\UserForms\Model\EditableFormField\EditableTextField.your-name-field, =>SilverStripe\UserForms\Model\EditableFormField\EditableTextField.street-field, =>SilverStripe\UserForms\Model\EditableFormField\EditableTextField.city-field
|
||||||
EmailRecipients: =>UserDefinedForm_EmailRecipient.unfiltered-recipient-1, =>UserDefinedForm_EmailRecipient.filtered-recipient-1, =>UserDefinedForm_EmailRecipient.filtered-recipient-2
|
EmailRecipients: =>EmailRecipient.unfiltered-recipient-1, =>EmailRecipient.filtered-recipient-1, =>EmailRecipient.filtered-recipient-2
|
||||||
|
|
||||||
empty-page:
|
empty-page:
|
||||||
Title: 'Page with empty step'
|
Title: 'Page with empty step'
|
||||||
Fields: =>EditableFormStep.form6step1, =>EditableTextField.field-1, =>EditableFormStep.form6step2, =>EditableTextField.field-2, =>EditableFormStep.form6step3
|
Fields: =>SilverStripe\UserForms\Model\EditableFormField\EditableFormStep.form6step1, =>SilverStripe\UserForms\Model\EditableFormField\EditableTextField.field-1, =>SilverStripe\UserForms\Model\EditableFormField\EditableFormStep.form6step2, =>SilverStripe\UserForms\Model\EditableFormField\EditableTextField.field-2, =>SilverStripe\UserForms\Model\EditableFormField\EditableFormStep.form6step3
|
||||||
|
|
||||||
email-form:
|
email-form:
|
||||||
Title: 'Page with email field'
|
Title: 'Page with email field'
|
||||||
Fields: =>EditableEmailField.another-email-field, =>EditableTextField.another-required
|
Fields: =>SilverStripe\UserForms\Model\EditableFormField\EditableEmailField.another-email-field, =>SilverStripe\UserForms\Model\EditableFormField\EditableTextField.another-required
|
||||||
|
@ -1,241 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
namespace SilverStripe\UserForms\Test\Task;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
use SilverStripe\Core\Config\Config;
|
|
||||||
use SilverStripe\UserForms\Model\UserDefinedForm;
|
|
||||||
use SilverStripe\UserForms\Model\EditableFormField\EditableTextField;
|
|
||||||
use SilverStripe\UserForms\Model\EditableFormField\EditableNumericField;
|
|
||||||
use SilverStripe\Security\Group;
|
|
||||||
use SilverStripe\UserForms\Model\EditableFormField\EditableMemberListField;
|
|
||||||
use SilverStripe\UserForms\Model\EditableFormField\EditableLiteralField;
|
|
||||||
use SilverStripe\UserForms\Model\EditableFormField\EditableFormHeading;
|
|
||||||
use SilverStripe\Assets\Folder;
|
|
||||||
use SilverStripe\UserForms\Model\EditableFormField\EditableFileField;
|
|
||||||
use SilverStripe\UserForms\Model\EditableFormField\EditableDateField;
|
|
||||||
use SilverStripe\UserForms\Model\EditableFormField\EditableCheckbox;
|
|
||||||
use SilverStripe\UserForms\Task\UserFormsUpgradeService;
|
|
||||||
use SilverStripe\Dev\SapphireTest;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class UserFormsUpgradeServiceTest extends SapphireTest
|
|
||||||
{
|
|
||||||
|
|
||||||
public static $fixture_file = 'UserFormsUpgradeServiceTest.yml';
|
|
||||||
|
|
||||||
public function setUp()
|
|
||||||
{
|
|
||||||
Config::inst()->update(UserDefinedForm::class, 'upgrade_on_build', false);
|
|
||||||
parent::setUp();
|
|
||||||
|
|
||||||
// Assign rules programatically
|
|
||||||
$field1 = $this->objFromFixture(EditableTextField::class, 'text1');
|
|
||||||
$field2 = $this->objFromFixture(EditableTextField::class, 'text2');
|
|
||||||
$field3 = $this->objFromFixture(EditableTextField::class, 'text3');
|
|
||||||
|
|
||||||
$field3->CustomRules = serialize(array(
|
|
||||||
array(
|
|
||||||
'Display' => 'Show',
|
|
||||||
'ConditionField' => $field1->Name,
|
|
||||||
'ConditionOption' => 'IsBlank',
|
|
||||||
'Value' => ''
|
|
||||||
),
|
|
||||||
array(
|
|
||||||
'Display' => 'Hide',
|
|
||||||
'ConditionField' => $field2->Name,
|
|
||||||
'ConditionOption' => 'HasValue',
|
|
||||||
'Value' => 'bob'
|
|
||||||
)
|
|
||||||
));
|
|
||||||
$field3->write();
|
|
||||||
|
|
||||||
// Assign settings programatically
|
|
||||||
$field4 = $this->objFromFixture(EditableTextField::class, 'text4');
|
|
||||||
$field4->CustomSettings = serialize(array(
|
|
||||||
'MinLength' => 20,
|
|
||||||
'MaxLength' => 100,
|
|
||||||
'Rows' => 4,
|
|
||||||
'ExtraClass' => 'special class',
|
|
||||||
'RightTitle' => 'My Field',
|
|
||||||
'ShowOnLoad' => '',
|
|
||||||
'Default' => 'Enter your text here'
|
|
||||||
));
|
|
||||||
$field4->write();
|
|
||||||
|
|
||||||
$numeric1 = $this->objFromFixture(EditableNumericField::class, 'numeric1');
|
|
||||||
$numeric1->CustomSettings = serialize(array(
|
|
||||||
'RightTitle' => 'Number of %',
|
|
||||||
'Default' => 1,
|
|
||||||
'MinValue' => 1,
|
|
||||||
'MaxValue' => 100,
|
|
||||||
'ShowOnLoad' => 'Show'
|
|
||||||
));
|
|
||||||
$numeric1->write();
|
|
||||||
|
|
||||||
$group1 = $this->objFromFixture(Group::class, 'group1');
|
|
||||||
$members1 = $this->objFromFixture(EditableMemberListField::class, 'members1');
|
|
||||||
$members1->CustomSettings = serialize(array(
|
|
||||||
'RightTitle' => 'Select group',
|
|
||||||
'GroupID' => $group1->ID,
|
|
||||||
'ShowOnLoad' => 'Hide'
|
|
||||||
));
|
|
||||||
$members1->write();
|
|
||||||
|
|
||||||
$literal1 = $this->objFromFixture(EditableLiteralField::class, 'literal1');
|
|
||||||
$literal1->CustomSettings = serialize(array(
|
|
||||||
'HideFromReports' => 1,
|
|
||||||
'RightTitle' => 'Literal',
|
|
||||||
'Content' => '<p>Content</p>',
|
|
||||||
'ShowOnLoad' => true
|
|
||||||
));
|
|
||||||
$literal1->write();
|
|
||||||
|
|
||||||
$heading1 = $this->objFromFixture(EditableFormHeading::class, 'heading1');
|
|
||||||
$heading1->CustomSettings = serialize(array(
|
|
||||||
'RightTitle' => 'Right',
|
|
||||||
'Level' => 3,
|
|
||||||
'HideFromReports' => true,
|
|
||||||
'ShowOnLoad' => false
|
|
||||||
));
|
|
||||||
$heading1->write();
|
|
||||||
|
|
||||||
$folder = $this->objFromFixture(Folder::class, 'folder1');
|
|
||||||
$file1 = $this->objFromFixture(EditableFileField::class, 'file1');
|
|
||||||
$file1->CustomSettings = serialize(array(
|
|
||||||
'RightTitle' => 'File field',
|
|
||||||
'Folder' => $folder->ID
|
|
||||||
));
|
|
||||||
$file1->write();
|
|
||||||
|
|
||||||
$date1 = $this->objFromFixture(EditableDateField::class, 'date1');
|
|
||||||
$date1->CustomSettings = serialize(array(
|
|
||||||
'RightTitle' => 'Date field',
|
|
||||||
'DefaultToToday' => '1'
|
|
||||||
));
|
|
||||||
$date1->write();
|
|
||||||
|
|
||||||
$checkbox1 = $this->objFromFixture(EditableCheckbox::class, 'checkbox1');
|
|
||||||
$checkbox1->CustomSettings = serialize(array(
|
|
||||||
'Default' => true,
|
|
||||||
'RightTitle' => 'Check this'
|
|
||||||
));
|
|
||||||
$checkbox1->write();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @return UserFormsUpgradeService;
|
|
||||||
*/
|
|
||||||
protected function getService()
|
|
||||||
{
|
|
||||||
return singleton(UserFormsUpgradeService::class);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Tests migration of custom rules
|
|
||||||
*/
|
|
||||||
public function testCustomRulesMigration()
|
|
||||||
{
|
|
||||||
$service = $this->getService();
|
|
||||||
$service->setQuiet(true);
|
|
||||||
$service->run();
|
|
||||||
|
|
||||||
$field1 = $this->objFromFixture(EditableTextField::class, 'text1');
|
|
||||||
$field2 = $this->objFromFixture(EditableTextField::class, 'text2');
|
|
||||||
$field3 = $this->objFromFixture(EditableTextField::class, 'text3');
|
|
||||||
|
|
||||||
$this->assertDOSEquals(array(
|
|
||||||
array(
|
|
||||||
'Display' => 'Show',
|
|
||||||
'ConditionFieldID' => $field1->ID,
|
|
||||||
'ConditionOption' => 'IsBlank'
|
|
||||||
),
|
|
||||||
array(
|
|
||||||
'Display' => 'Hide',
|
|
||||||
'ConditionFieldID' => $field2->ID,
|
|
||||||
'ConditionOption' => 'HasValue',
|
|
||||||
'FieldValue' => 'bob'
|
|
||||||
)
|
|
||||||
), $field3->DisplayRules());
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Tests migration of all custom settings
|
|
||||||
*/
|
|
||||||
public function testCustomSettingsMigration()
|
|
||||||
{
|
|
||||||
$service = $this->getService();
|
|
||||||
$service->setQuiet(true);
|
|
||||||
$service->run();
|
|
||||||
|
|
||||||
$group1 = $this->objFromFixture(Group::class, 'group1');
|
|
||||||
$form = $this->objFromFixture(UserDefinedForm::class, 'form-with-settings');
|
|
||||||
$folder = $this->objFromFixture(Folder::class, 'folder1');
|
|
||||||
|
|
||||||
$this->assertDOSEquals(array(
|
|
||||||
array(
|
|
||||||
'ClassName' => EditableTextField::class,
|
|
||||||
'Title' => 'Text with rule',
|
|
||||||
'MinLength' => 20,
|
|
||||||
'MaxLength' => 100,
|
|
||||||
'Rows' => 4,
|
|
||||||
'ExtraClass' => 'special class',
|
|
||||||
'RightTitle' => 'My Field',
|
|
||||||
'ShowOnLoad' => true,
|
|
||||||
'Default' => 'Enter your text here',
|
|
||||||
),
|
|
||||||
array(
|
|
||||||
'ClassName' => EditableNumericField::class,
|
|
||||||
'Title' => 'Numeric 1',
|
|
||||||
'RightTitle' => 'Number of %',
|
|
||||||
'Default' => 1,
|
|
||||||
'MinValue' => 1,
|
|
||||||
'MaxValue' => 100,
|
|
||||||
'ShowOnLoad' => true,
|
|
||||||
),
|
|
||||||
array(
|
|
||||||
'ClassName' => EditableMemberListField::class,
|
|
||||||
'Title' => 'Members 1',
|
|
||||||
'RightTitle' => 'Select group',
|
|
||||||
'GroupID' => $group1->ID,
|
|
||||||
'ShowOnLoad' => false,
|
|
||||||
),
|
|
||||||
array(
|
|
||||||
'ClassName' => EditableLiteralField::class,
|
|
||||||
'Title' => 'Literal 1',
|
|
||||||
'HideFromReports' => true,
|
|
||||||
'RightTitle' => 'Literal',
|
|
||||||
'Content' => '<p>Content</p>',
|
|
||||||
'ShowOnLoad' => true,
|
|
||||||
),
|
|
||||||
array(
|
|
||||||
'ClassName' => EditableFormHeading::class,
|
|
||||||
'Title' => 'Heading 1',
|
|
||||||
'RightTitle' => 'Right',
|
|
||||||
'Level' => 3,
|
|
||||||
'HideFromReports' => true,
|
|
||||||
'ShowOnLoad' => false,
|
|
||||||
),
|
|
||||||
array(
|
|
||||||
'ClassName' => EditableFileField::class,
|
|
||||||
'Title' => 'File 1',
|
|
||||||
'RightTitle' => 'File field',
|
|
||||||
'FolderID' => $folder->ID,
|
|
||||||
),
|
|
||||||
array(
|
|
||||||
'ClassName' => EditableDateField::class,
|
|
||||||
'Title' => 'Date 1',
|
|
||||||
'RightTitle' => 'Date field',
|
|
||||||
'DefaultToToday' => true,
|
|
||||||
),
|
|
||||||
array(
|
|
||||||
'ClassName' => EditableCheckbox::class,
|
|
||||||
'Title' => 'Checkbox 1',
|
|
||||||
'CheckedDefault' => true,
|
|
||||||
'RightTitle' => 'Check this',
|
|
||||||
),
|
|
||||||
), $form->Fields());
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,57 +0,0 @@
|
|||||||
Group:
|
|
||||||
group1:
|
|
||||||
Title: 'Awesome Group'
|
|
||||||
|
|
||||||
Folder:
|
|
||||||
folder1:
|
|
||||||
Title: 'Folder 1'
|
|
||||||
|
|
||||||
EditableTextField:
|
|
||||||
text1:
|
|
||||||
Name: text1
|
|
||||||
Title: 'First field'
|
|
||||||
text2:
|
|
||||||
Name: text2
|
|
||||||
Title: 'Second field'
|
|
||||||
text3:
|
|
||||||
Name: text3
|
|
||||||
Title: 'Third field'
|
|
||||||
text4:
|
|
||||||
Name: textwithrule
|
|
||||||
Title: 'Text with rule'
|
|
||||||
EditableNumericField:
|
|
||||||
numeric1:
|
|
||||||
Name: numeric1
|
|
||||||
Title: 'Numeric 1'
|
|
||||||
EditableMemberListField:
|
|
||||||
members1:
|
|
||||||
Name: members1
|
|
||||||
Title: 'Members 1'
|
|
||||||
EditableLiteralField:
|
|
||||||
literal1:
|
|
||||||
Name: literal1
|
|
||||||
Title: 'Literal 1'
|
|
||||||
EditableFormHeading:
|
|
||||||
heading1:
|
|
||||||
Name: heading1
|
|
||||||
Title: 'Heading 1'
|
|
||||||
EditableFileField:
|
|
||||||
file1:
|
|
||||||
Name: file1
|
|
||||||
Title: 'File 1'
|
|
||||||
EditableDateField:
|
|
||||||
date1:
|
|
||||||
Name: date1
|
|
||||||
Title: 'Date 1'
|
|
||||||
EditableCheckbox:
|
|
||||||
checkbox1:
|
|
||||||
Name: checkbox1
|
|
||||||
Title: 'Checkbox 1'
|
|
||||||
|
|
||||||
UserDefinedForm:
|
|
||||||
form-with-rules:
|
|
||||||
Title: 'User Defined Form'
|
|
||||||
Fields: =>EditableTextField.text1,=>EditableTextField.text2,=>EditableTextField.text3
|
|
||||||
form-with-settings:
|
|
||||||
Title: 'Form with custom settings'
|
|
||||||
Fields: =>EditableTextField.text4,=>EditableNumericField.numeric1,=>EditableMemberListField.members1,=>EditableLiteralField.literal1,=>EditableFormHeading.heading1,=>EditableFileField.file1,=>EditableDateField.date1,=>EditableCheckbox.checkbox1
|
|
@ -1,62 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
namespace SilverStripe\UserForms\Test\Task;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
use SilverStripe\Versioned\Versioned;
|
|
||||||
use SilverStripe\UserForms\Model\UserDefinedForm;
|
|
||||||
use SilverStripe\UserForms\Model\EditableFormField\EditableOption;
|
|
||||||
use SilverStripe\UserForms\Model\EditableFormField\EditableCheckboxGroupField;
|
|
||||||
use SilverStripe\Dev\SapphireTest;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class UserFormsVersionedTaskTest extends SapphireTest
|
|
||||||
{
|
|
||||||
protected static $fixture_file = 'UserDefinedFormTest.yml';
|
|
||||||
|
|
||||||
public function setUp()
|
|
||||||
{
|
|
||||||
parent::setUp();
|
|
||||||
Versioned::reading_stage('Stage');
|
|
||||||
}
|
|
||||||
|
|
||||||
public function testPublishing()
|
|
||||||
{
|
|
||||||
/** @var UserDefinedForm $form */
|
|
||||||
$form = $this->objFromFixture(UserDefinedForm::class, 'filtered-form-page');
|
|
||||||
|
|
||||||
// Get id of options
|
|
||||||
$optionID = $this->idFromFixture(EditableOption::class, 'option-3');
|
|
||||||
$this->assertEmpty(Versioned::get_one_by_stage(EditableOption::class, 'Live', array('"ID" = ?' => $optionID)));
|
|
||||||
|
|
||||||
// Publishing writes this to live
|
|
||||||
$form->doPublish();
|
|
||||||
$liveVersion = Versioned::get_versionnumber_by_stage(EditableOption::class, 'Live', $optionID, false);
|
|
||||||
$this->assertNotEmpty($liveVersion);
|
|
||||||
|
|
||||||
// Add new option, and repeat publish process
|
|
||||||
/** @var EditableCheckboxGroupField $list */
|
|
||||||
$list = $this->objFromFixture(EditableCheckboxGroupField::class, 'checkbox-group');
|
|
||||||
$newOption = new EditableOption();
|
|
||||||
$newOption->Title = 'New option';
|
|
||||||
$newOption->Value = 'ok';
|
|
||||||
$newOption->write();
|
|
||||||
$newOptionID = $newOption->ID;
|
|
||||||
$list->Options()->add($newOption);
|
|
||||||
|
|
||||||
$form->doPublish();
|
|
||||||
|
|
||||||
// Un-modified option should not create a new version
|
|
||||||
$newLiveVersion = Versioned::get_versionnumber_by_stage(EditableOption::class, 'Live', $optionID, false);
|
|
||||||
$this->assertNotEmpty($newLiveVersion);
|
|
||||||
$this->assertEquals($liveVersion, $newLiveVersion);
|
|
||||||
|
|
||||||
// New option is successfully published
|
|
||||||
$newOptionLiveVersion = Versioned::get_versionnumber_by_stage(EditableOption::class, 'Live', $newOptionID, false);
|
|
||||||
$this->assertNotEmpty($newOptionLiveVersion);
|
|
||||||
}
|
|
||||||
}
|
|
Loading…
Reference in New Issue
Block a user