2010-09-03 07:06:13 +02:00
|
|
|
<?php
|
|
|
|
|
2017-08-09 01:55:09 +02:00
|
|
|
namespace SilverStripe\UserForms\Test\Model;
|
|
|
|
|
2017-08-13 23:26:53 +02:00
|
|
|
use SilverStripe\Core\Config\Config;
|
2017-08-11 02:20:12 +02:00
|
|
|
use SilverStripe\Dev\CSSContentParser;
|
|
|
|
use SilverStripe\Dev\FunctionalTest;
|
|
|
|
use SilverStripe\Dev\TestOnly;
|
|
|
|
use SilverStripe\Forms\FieldList;
|
|
|
|
use SilverStripe\Forms\FormAction;
|
|
|
|
use SilverStripe\ORM\DataObject;
|
|
|
|
use SilverStripe\Security\Member;
|
2017-08-09 01:55:09 +02:00
|
|
|
use SilverStripe\UserForms\Model\EditableFormField\EditableTextField;
|
|
|
|
use SilverStripe\UserForms\Model\Submission\SubmittedFormField;
|
|
|
|
use SilverStripe\UserForms\Model\UserDefinedForm;
|
2017-08-11 02:20:12 +02:00
|
|
|
use SilverStripe\UserForms\Model\UserDefinedFormController;
|
2017-08-09 01:55:09 +02:00
|
|
|
use SilverStripe\View\ArrayData;
|
|
|
|
|
2010-09-03 07:06:13 +02:00
|
|
|
/**
|
|
|
|
* @package userforms
|
|
|
|
*/
|
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
class UserDefinedFormControllerTest extends FunctionalTest
|
|
|
|
{
|
2017-08-11 02:20:12 +02:00
|
|
|
protected static $fixture_file = 'UserDefinedFormTest.yml';
|
2010-09-03 07:06:13 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
public function testProcess()
|
|
|
|
{
|
|
|
|
$form = $this->setupFormFrontend();
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2017-08-11 02:20:12 +02:00
|
|
|
$controller = new UserDefinedFormController($form);
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
$this->autoFollowRedirection = false;
|
|
|
|
$this->clearEmails();
|
2015-08-11 22:57:19 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
// load the form
|
|
|
|
$this->get($form->URLSegment);
|
2015-08-11 22:57:19 +02:00
|
|
|
|
2017-08-09 01:55:09 +02:00
|
|
|
$field = $this->objFromFixture(EditableTextField::class, 'basic-text');
|
2015-08-11 22:57:19 +02:00
|
|
|
|
2017-08-11 02:20:12 +02:00
|
|
|
$response = $this->submitForm('UserForm_Form_' . $form->ID, null, [$field->Name => 'Basic Value']);
|
2010-09-03 07:06:13 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
// should have a submitted form field now
|
2017-08-09 01:55:09 +02:00
|
|
|
$submitted = DataObject::get(SubmittedFormField::class, "\"Name\" = 'basic-text-name'");
|
2017-08-11 02:20:12 +02:00
|
|
|
$this->assertDOSAllMatch(
|
|
|
|
[
|
|
|
|
'Name' => 'basic-text-name',
|
|
|
|
'Value' => 'Basic Value',
|
|
|
|
'Title' => 'Basic Text Field'
|
|
|
|
],
|
|
|
|
$submitted
|
|
|
|
);
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
// check emails
|
|
|
|
$this->assertEmailSent('test@example.com', 'no-reply@example.com', 'Email Subject');
|
|
|
|
$email = $this->findEmail('test@example.com', 'no-reply@example.com', 'Email Subject');
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
// assert that the email has the field title and the value html email
|
|
|
|
$parser = new CSSContentParser($email['content']);
|
|
|
|
$title = $parser->getBySelector('strong');
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
$this->assertEquals('Basic Text Field', (string) $title[0], 'Email contains the field name');
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
$value = $parser->getBySelector('dd');
|
|
|
|
$this->assertEquals('Basic Value', (string) $value[0], 'Email contains the value');
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
// no html
|
|
|
|
$this->assertEmailSent('nohtml@example.com', 'no-reply@example.com', 'Email Subject');
|
|
|
|
$nohtml = $this->findEmail('nohtml@example.com', 'no-reply@example.com', 'Email Subject');
|
2010-09-03 07:06:13 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
$this->assertContains('Basic Text Field: Basic Value', $nohtml['content'], 'Email contains no html');
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
// no data
|
|
|
|
$this->assertEmailSent('nodata@example.com', 'no-reply@example.com', 'Email Subject');
|
|
|
|
$nodata = $this->findEmail('nodata@example.com', 'no-reply@example.com', 'Email Subject');
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
$parser = new CSSContentParser($nodata['content']);
|
|
|
|
$list = $parser->getBySelector('dl');
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
$this->assertFalse(isset($list[0]), 'Email contains no fields');
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
// check to see if the user was redirected (301)
|
|
|
|
$this->assertEquals($response->getStatusCode(), 302);
|
|
|
|
$this->assertStringEndsWith('finished#uff', $response->getHeader('Location'));
|
|
|
|
}
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
public function testValidation()
|
|
|
|
{
|
|
|
|
$form = $this->setupFormFrontend('email-form');
|
2015-12-11 05:38:31 +01:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
// Post with no fields
|
|
|
|
$this->get($form->URLSegment);
|
2017-08-11 02:20:12 +02:00
|
|
|
$response = $this->submitForm('UserForm_Form_' . $form->ID, null, []);
|
2016-07-21 07:53:59 +02:00
|
|
|
$this->assertPartialMatchBySelector(
|
|
|
|
'.field .message',
|
2017-08-11 02:20:12 +02:00
|
|
|
['This field is required']
|
2016-07-21 07:53:59 +02:00
|
|
|
);
|
2015-12-11 05:38:31 +01:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
// Post with all fields, but invalid email
|
|
|
|
$this->get($form->URLSegment);
|
2017-08-11 02:20:12 +02:00
|
|
|
$this->submitForm('UserForm_Form_' . $form->ID, null, [
|
2016-07-21 07:53:59 +02:00
|
|
|
'required-email' => 'invalid',
|
|
|
|
'required-text' => 'bob'
|
2017-08-11 02:20:12 +02:00
|
|
|
]);
|
2016-07-21 07:53:59 +02:00
|
|
|
$this->assertPartialMatchBySelector(
|
|
|
|
'.field .message',
|
2017-08-11 02:20:12 +02:00
|
|
|
['Please enter an email address']
|
2016-07-21 07:53:59 +02:00
|
|
|
);
|
2015-12-11 05:38:31 +01:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
// Post with only required
|
|
|
|
$this->get($form->URLSegment);
|
2017-08-11 02:20:12 +02:00
|
|
|
$this->submitForm('UserForm_Form_' . $form->ID, null, [
|
2016-07-21 07:53:59 +02:00
|
|
|
'required-text' => 'bob'
|
2017-08-11 02:20:12 +02:00
|
|
|
]);
|
2016-07-21 07:53:59 +02:00
|
|
|
$this->assertPartialMatchBySelector(
|
|
|
|
'p',
|
2017-08-11 02:20:12 +02:00
|
|
|
["Thanks, we've received your submission."]
|
2016-07-21 07:53:59 +02:00
|
|
|
);
|
|
|
|
}
|
2015-12-11 05:38:31 +01:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
public function testFinished()
|
|
|
|
{
|
|
|
|
$form = $this->setupFormFrontend();
|
2014-01-06 03:15:01 +01:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
// set formProcessed and SecurityID to replicate the form being filled out
|
2017-08-11 02:20:12 +02:00
|
|
|
$this->session()->set('SecurityID', 1);
|
|
|
|
$this->session()->set('FormProcessed', 1);
|
2014-01-06 03:15:01 +01:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
$response = $this->get($form->URLSegment.'/finished');
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
$this->assertContains($form->OnCompleteMessage, $response->getBody());
|
|
|
|
}
|
2014-01-06 03:15:01 +01:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
public function testAppendingFinished()
|
|
|
|
{
|
|
|
|
$form = $this->setupFormFrontend();
|
2014-01-06 03:15:01 +01:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
// replicate finished being added to the end of the form URL without the form being filled out
|
2017-08-11 02:20:12 +02:00
|
|
|
$this->session()->set('SecurityID', 1);
|
|
|
|
$this->session()->set('FormProcessed', null);
|
2014-01-06 03:15:01 +01:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
$response = $this->get($form->URLSegment.'/finished');
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
$this->assertNotContains($form->OnCompleteMessage, $response->getBody());
|
|
|
|
}
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
public function testForm()
|
|
|
|
{
|
2017-08-09 01:55:09 +02:00
|
|
|
$form = $this->objFromFixture(UserDefinedForm::class, 'basic-form-page');
|
2015-08-10 07:03:36 +02:00
|
|
|
|
2017-08-11 02:20:12 +02:00
|
|
|
$controller = new UserDefinedFormController($form);
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
// test form
|
2017-04-18 03:11:32 +02:00
|
|
|
$this->assertEquals($controller->Form()->getName(), 'Form_' . $form->ID, 'The form is referenced as Form');
|
2016-07-21 07:53:59 +02:00
|
|
|
$this->assertEquals($controller->Form()->Fields()->Count(), 1); // disabled SecurityID token fields
|
|
|
|
$this->assertEquals($controller->Form()->Actions()->Count(), 1);
|
|
|
|
$this->assertEquals(count($controller->Form()->getValidator()->getRequired()), 0);
|
2010-09-03 07:06:13 +02:00
|
|
|
|
2017-08-09 01:55:09 +02:00
|
|
|
$requiredForm = $this->objFromFixture(UserDefinedForm::class, 'validation-form');
|
2017-08-11 02:20:12 +02:00
|
|
|
$controller = new UserDefinedFormController($requiredForm);
|
2010-09-03 07:06:13 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
$this->assertEquals($controller->Form()->Fields()->Count(), 1); // disabled SecurityID token fields
|
|
|
|
$this->assertEquals($controller->Form()->Actions()->Count(), 1);
|
|
|
|
$this->assertEquals(count($controller->Form()->getValidator()->getRequired()), 1);
|
|
|
|
}
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
public function testGetFormFields()
|
|
|
|
{
|
|
|
|
// generating the fieldset of fields
|
2017-08-09 01:55:09 +02:00
|
|
|
$form = $this->objFromFixture(UserDefinedForm::class, 'basic-form-page');
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2017-08-11 02:20:12 +02:00
|
|
|
$controller = new UserDefinedFormController($form);
|
2016-07-21 07:53:59 +02:00
|
|
|
|
|
|
|
$formSteps = $controller->Form()->getFormFields();
|
|
|
|
$firstStep = $formSteps->first();
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
$this->assertEquals($formSteps->Count(), 1);
|
|
|
|
$this->assertEquals($firstStep->getChildren()->Count(), 1);
|
2015-08-10 07:03:36 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
// custom error message on a form field
|
2017-08-09 01:55:09 +02:00
|
|
|
$requiredForm = $this->objFromFixture(UserDefinedForm::class, 'validation-form');
|
2017-08-11 02:20:12 +02:00
|
|
|
$controller = new UserDefinedFormController($requiredForm);
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2017-08-11 02:20:12 +02:00
|
|
|
Config::modify()->set(UserDefinedForm::class, 'required_identifier', '*');
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
$formSteps = $controller->Form()->getFormFields();
|
|
|
|
$firstStep = $formSteps->first();
|
|
|
|
$firstField = $firstStep->getChildren()->first();
|
2015-08-10 07:03:36 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
$this->assertEquals('Custom Error Message', $firstField->getCustomValidationMessage());
|
|
|
|
$this->assertEquals($firstField->Title(), 'Required Text Field <span class=\'required-identifier\'>*</span>');
|
2015-08-10 07:03:36 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
// test custom right title
|
|
|
|
$field = $form->Fields()->limit(1, 1)->First();
|
|
|
|
$field->RightTitle = 'Right Title';
|
|
|
|
$field->write();
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2017-08-11 02:20:12 +02:00
|
|
|
$controller = new UserDefinedFormController($form);
|
2016-07-21 07:53:59 +02:00
|
|
|
$formSteps = $controller->Form()->getFormFields();
|
|
|
|
$firstStep = $formSteps->first();
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
$this->assertEquals($firstStep->getChildren()->First()->RightTitle(), "Right Title");
|
2010-09-08 00:44:43 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
// test empty form
|
2017-08-09 01:55:09 +02:00
|
|
|
$emptyForm = $this->objFromFixture(UserDefinedForm::class, 'empty-form');
|
2017-08-11 02:20:12 +02:00
|
|
|
$controller = new UserDefinedFormController($emptyForm);
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
$this->assertFalse($controller->Form()->getFormFields()->exists());
|
|
|
|
}
|
2015-07-24 04:37:48 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
public function testGetFormActions()
|
|
|
|
{
|
|
|
|
// generating the fieldset of actions
|
2017-08-09 01:55:09 +02:00
|
|
|
$form = $this->objFromFixture(UserDefinedForm::class, 'basic-form-page');
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2017-08-11 02:20:12 +02:00
|
|
|
$controller = new UserDefinedFormController($form);
|
2016-07-21 07:53:59 +02:00
|
|
|
$actions = $controller->Form()->getFormActions();
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
// by default will have 1 submit button which links to process
|
|
|
|
$expected = new FieldList(new FormAction('process', 'Submit'));
|
|
|
|
$expected->setForm($controller->Form());
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
$this->assertEquals($actions, $expected);
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
// the custom popup should have a reset button and a custom text
|
2017-08-09 01:55:09 +02:00
|
|
|
$custom = $this->objFromFixture(UserDefinedForm::class, 'form-with-reset-and-custom-action');
|
2017-08-11 02:20:12 +02:00
|
|
|
$controller = new UserDefinedFormController($custom);
|
2016-07-21 07:53:59 +02:00
|
|
|
$actions = $controller->Form()->getFormActions();
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
$expected = new FieldList(new FormAction('process', 'Custom Button'));
|
2017-08-13 23:26:53 +02:00
|
|
|
$expected->push(FormAction::create('clearForm', 'Clear')->setAttribute('type', 'reset'));
|
2016-07-21 07:53:59 +02:00
|
|
|
$expected->setForm($controller->Form());
|
2010-09-03 07:06:13 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
$this->assertEquals($actions, $expected);
|
|
|
|
}
|
2015-07-24 04:37:48 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
public function testRenderingIntoFormTemplate()
|
|
|
|
{
|
|
|
|
$form = $this->setupFormFrontend();
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2017-08-13 23:26:53 +02:00
|
|
|
$this->logInWithPermission('ADMIN');
|
2016-07-21 07:53:59 +02:00
|
|
|
$form->Content = 'This is some content without a form nested between it';
|
2017-08-13 23:26:53 +02:00
|
|
|
$form->publishRecursive();
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2017-08-11 02:20:12 +02:00
|
|
|
$controller = new UserDefinedFormController($form);
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
// check to see if $Form is replaced to inside the content
|
|
|
|
$index = new ArrayData($controller->index());
|
2017-08-11 02:20:12 +02:00
|
|
|
$parser = new CSSContentParser($index->renderWith(__CLASS__));
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2017-04-18 03:11:32 +02:00
|
|
|
$this->checkTemplateIsCorrect($parser, $form);
|
2016-07-21 07:53:59 +02:00
|
|
|
}
|
2010-09-03 07:06:13 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
public function testRenderingIntoTemplateWithSubstringReplacement()
|
|
|
|
{
|
|
|
|
$form = $this->setupFormFrontend();
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2017-08-11 02:20:12 +02:00
|
|
|
$controller = new UserDefinedFormController($form);
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
// check to see if $Form is replaced to inside the content
|
|
|
|
$index = new ArrayData($controller->index());
|
2017-08-11 02:20:12 +02:00
|
|
|
$parser = new CSSContentParser($index->renderWith(__CLASS__));
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2017-04-18 03:11:32 +02:00
|
|
|
$this->checkTemplateIsCorrect($parser, $form);
|
2016-07-21 07:53:59 +02:00
|
|
|
}
|
|
|
|
/**
|
|
|
|
* Publish a form for use on the frontend
|
|
|
|
*
|
|
|
|
* @param string $fixtureName
|
|
|
|
* @return UserDefinedForm
|
|
|
|
*/
|
|
|
|
protected function setupFormFrontend($fixtureName = 'basic-form-page')
|
|
|
|
{
|
2017-08-09 01:55:09 +02:00
|
|
|
$form = $this->objFromFixture(UserDefinedForm::class, $fixtureName);
|
2016-07-21 07:53:59 +02:00
|
|
|
$this->logInWithPermission('ADMIN');
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2017-08-13 23:26:53 +02:00
|
|
|
$form->publishRecursive();
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
$member = Member::currentUser();
|
|
|
|
$member->logOut();
|
2010-09-03 07:06:13 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
return $form;
|
|
|
|
}
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2017-04-18 03:11:32 +02:00
|
|
|
public function checkTemplateIsCorrect($parser, $form)
|
2016-07-21 07:53:59 +02:00
|
|
|
{
|
2017-04-18 03:11:32 +02:00
|
|
|
$this->assertArrayHasKey(0, $parser->getBySelector('form#UserForm_Form_' . $form->ID));
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
// check for the input
|
|
|
|
$this->assertArrayHasKey(0, $parser->getBySelector('input.text'));
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
// check for the label and the text
|
|
|
|
$label = $parser->getBySelector('label.left');
|
|
|
|
$this->assertArrayHasKey(0, $label);
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
$this->assertEquals((string) $label[0][0], "Basic Text Field", "Label contains correct field name");
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
// check for the action
|
|
|
|
$action = $parser->getBySelector('input.action');
|
|
|
|
$this->assertArrayHasKey(0, $action);
|
2015-09-11 00:20:06 +02:00
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
$this->assertEquals((string) $action[0]['value'], "Submit", "Submit button has default text");
|
|
|
|
}
|
2010-11-01 03:22:29 +01:00
|
|
|
}
|