silverstripe-userforms/tests/Model/UserDefinedFormControllerTest.php

328 lines
12 KiB
PHP
Raw Normal View History

<?php
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\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\TestOnly;
/**
* @package userforms
*/
2016-07-21 17:53:59 +12:00
class UserDefinedFormControllerTest extends FunctionalTest
{
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
public static $fixture_file = 'UserDefinedFormTest.yml';
2016-07-21 17:53:59 +12:00
public function testProcess()
{
$form = $this->setupFormFrontend();
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
$controller = new UserDefinedFormControllerTest_Controller($form);
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
$this->autoFollowRedirection = false;
$this->clearEmails();
2015-08-12 08:57:19 +12:00
2016-07-21 17:53:59 +12:00
// load the form
$this->get($form->URLSegment);
2015-08-12 08:57:19 +12:00
$field = $this->objFromFixture(EditableTextField::class, 'basic-text');
2015-08-12 08:57:19 +12:00
$response = $this->submitForm('UserForm_Form_' . $form->ID, null, array($field->Name => 'Basic Value'));
2016-07-21 17:53:59 +12:00
// should have a submitted form field now
$submitted = DataObject::get(SubmittedFormField::class, "\"Name\" = 'basic-text-name'");
2016-07-21 17:53:59 +12:00
$this->assertDOSAllMatch(array('Name' => 'basic-text-name', 'Value' => 'Basic Value', 'Title' => 'Basic Text Field'), $submitted);
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12: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 10:20:06 +12:00
2016-07-21 17:53:59 +12: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 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
$this->assertEquals('Basic Text Field', (string) $title[0], 'Email contains the field name');
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
$value = $parser->getBySelector('dd');
$this->assertEquals('Basic Value', (string) $value[0], 'Email contains the value');
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12: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');
2016-07-21 17:53:59 +12:00
$this->assertContains('Basic Text Field: Basic Value', $nohtml['content'], 'Email contains no html');
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12: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 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
$parser = new CSSContentParser($nodata['content']);
$list = $parser->getBySelector('dl');
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
$this->assertFalse(isset($list[0]), 'Email contains no fields');
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12: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 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
public function testValidation()
{
$form = $this->setupFormFrontend('email-form');
2016-07-21 17:53:59 +12:00
// Post with no fields
$this->get($form->URLSegment);
$response = $this->submitForm('UserForm_Form_' . $form->ID, null, array());
2016-07-21 17:53:59 +12:00
$this->assertPartialMatchBySelector(
'.field .message',
array('This field is required')
);
2016-07-21 17:53:59 +12:00
// Post with all fields, but invalid email
$this->get($form->URLSegment);
$this->submitForm('UserForm_Form_' . $form->ID, null, array(
2016-07-21 17:53:59 +12:00
'required-email' => 'invalid',
'required-text' => 'bob'
));
$this->assertPartialMatchBySelector(
'.field .message',
array('Please enter an email address')
);
2016-07-21 17:53:59 +12:00
// Post with only required
$this->get($form->URLSegment);
$this->submitForm('UserForm_Form_' . $form->ID, null, array(
2016-07-21 17:53:59 +12:00
'required-text' => 'bob'
));
$this->assertPartialMatchBySelector(
'p',
array("Thanks, we've received your submission.")
);
}
2016-07-21 17:53:59 +12:00
public function testFinished()
{
$form = $this->setupFormFrontend();
2016-07-21 17:53:59 +12:00
// set formProcessed and SecurityID to replicate the form being filled out
$this->session()->inst_set('SecurityID', 1);
$this->session()->inst_set('FormProcessed', 1);
2016-07-21 17:53:59 +12:00
$response = $this->get($form->URLSegment.'/finished');
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
$this->assertContains($form->OnCompleteMessage, $response->getBody());
}
2016-07-21 17:53:59 +12:00
public function testAppendingFinished()
{
$form = $this->setupFormFrontend();
2016-07-21 17:53:59 +12:00
// 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()->inst_set('FormProcessed', null);
2016-07-21 17:53:59 +12:00
$response = $this->get($form->URLSegment.'/finished');
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
$this->assertNotContains($form->OnCompleteMessage, $response->getBody());
}
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
public function testForm()
{
$form = $this->objFromFixture(UserDefinedForm::class, 'basic-form-page');
2016-07-21 17:53:59 +12:00
$controller = new UserDefinedFormControllerTest_Controller($form);
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
// test form
$this->assertEquals($controller->Form()->getName(), 'Form_' . $form->ID, 'The form is referenced as Form');
2016-07-21 17:53:59 +12: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);
$requiredForm = $this->objFromFixture(UserDefinedForm::class, 'validation-form');
2016-07-21 17:53:59 +12:00
$controller = new UserDefinedFormControllerTest_Controller($requiredForm);
2016-07-21 17:53:59 +12: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 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
public function testGetFormFields()
{
// generating the fieldset of fields
$form = $this->objFromFixture(UserDefinedForm::class, 'basic-form-page');
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
$controller = new UserDefinedFormControllerTest_Controller($form);
$formSteps = $controller->Form()->getFormFields();
$firstStep = $formSteps->first();
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
$this->assertEquals($formSteps->Count(), 1);
$this->assertEquals($firstStep->getChildren()->Count(), 1);
2016-07-21 17:53:59 +12:00
// custom error message on a form field
$requiredForm = $this->objFromFixture(UserDefinedForm::class, 'validation-form');
2016-07-21 17:53:59 +12:00
$controller = new UserDefinedFormControllerTest_Controller($requiredForm);
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
UserDefinedForm::config()->required_identifier = "*";
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
$formSteps = $controller->Form()->getFormFields();
$firstStep = $formSteps->first();
$firstField = $firstStep->getChildren()->first();
2016-07-21 17:53:59 +12:00
$this->assertEquals('Custom Error Message', $firstField->getCustomValidationMessage());
$this->assertEquals($firstField->Title(), 'Required Text Field <span class=\'required-identifier\'>*</span>');
2016-07-21 17:53:59 +12:00
// test custom right title
$field = $form->Fields()->limit(1, 1)->First();
$field->RightTitle = 'Right Title';
$field->write();
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
$controller = new UserDefinedFormControllerTest_Controller($form);
$formSteps = $controller->Form()->getFormFields();
$firstStep = $formSteps->first();
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
$this->assertEquals($firstStep->getChildren()->First()->RightTitle(), "Right Title");
2016-07-21 17:53:59 +12:00
// test empty form
$emptyForm = $this->objFromFixture(UserDefinedForm::class, 'empty-form');
2016-07-21 17:53:59 +12:00
$controller = new UserDefinedFormControllerTest_Controller($emptyForm);
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
$this->assertFalse($controller->Form()->getFormFields()->exists());
}
2015-07-24 14:37:48 +12:00
2016-07-21 17:53:59 +12:00
public function testGetFormActions()
{
// generating the fieldset of actions
$form = $this->objFromFixture(UserDefinedForm::class, 'basic-form-page');
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
$controller = new UserDefinedFormControllerTest_Controller($form);
$actions = $controller->Form()->getFormActions();
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12: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 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
$this->assertEquals($actions, $expected);
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
// the custom popup should have a reset button and a custom text
$custom = $this->objFromFixture(UserDefinedForm::class, 'form-with-reset-and-custom-action');
2016-07-21 17:53:59 +12:00
$controller = new UserDefinedFormControllerTest_Controller($custom);
$actions = $controller->Form()->getFormActions();
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
$expected = new FieldList(new FormAction('process', 'Custom Button'));
$expected->push(new ResetFormAction("clearForm", "Clear"));
$expected->setForm($controller->Form());
2016-07-21 17:53:59 +12:00
$this->assertEquals($actions, $expected);
}
2015-07-24 14:37:48 +12:00
2016-07-21 17:53:59 +12:00
public function testRenderingIntoFormTemplate()
{
$form = $this->setupFormFrontend();
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
$form->Content = 'This is some content without a form nested between it';
$form->doPublish();
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
$controller = new UserDefinedFormControllerTest_Controller($form);
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
// check to see if $Form is replaced to inside the content
$index = new ArrayData($controller->index());
$parser = new CSSContentParser($index->renderWith(array(UserDefinedFormControllerTest::class)));
2015-09-11 10:20:06 +12:00
$this->checkTemplateIsCorrect($parser, $form);
2016-07-21 17:53:59 +12:00
}
2016-07-21 17:53:59 +12:00
public function testRenderingIntoTemplateWithSubstringReplacement()
{
$form = $this->setupFormFrontend();
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
$controller = new UserDefinedFormControllerTest_Controller($form);
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
// check to see if $Form is replaced to inside the content
$index = new ArrayData($controller->index());
$parser = new CSSContentParser($index->renderWith(array(UserDefinedFormControllerTest::class)));
2015-09-11 10:20:06 +12:00
$this->checkTemplateIsCorrect($parser, $form);
2016-07-21 17:53:59 +12:00
}
/**
* Publish a form for use on the frontend
*
* @param string $fixtureName
* @return UserDefinedForm
*/
protected function setupFormFrontend($fixtureName = 'basic-form-page')
{
$form = $this->objFromFixture(UserDefinedForm::class, $fixtureName);
2016-07-21 17:53:59 +12:00
$this->logInWithPermission('ADMIN');
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
$form->doPublish();
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
$member = Member::currentUser();
$member->logOut();
2016-07-21 17:53:59 +12:00
return $form;
}
2015-09-11 10:20:06 +12:00
public function checkTemplateIsCorrect($parser, $form)
2016-07-21 17:53:59 +12:00
{
$this->assertArrayHasKey(0, $parser->getBySelector('form#UserForm_Form_' . $form->ID));
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
// check for the input
$this->assertArrayHasKey(0, $parser->getBySelector('input.text'));
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
// check for the label and the text
$label = $parser->getBySelector('label.left');
$this->assertArrayHasKey(0, $label);
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
$this->assertEquals((string) $label[0][0], "Basic Text Field", "Label contains correct field name");
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
// check for the action
$action = $parser->getBySelector('input.action');
$this->assertArrayHasKey(0, $action);
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
$this->assertEquals((string) $action[0]['value'], "Submit", "Submit button has default text");
}
}
2016-07-21 17:53:59 +12:00
class UserDefinedFormControllerTest_Controller extends UserDefinedForm_Controller implements TestOnly
{
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
/**
* 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();
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
if ($form) {
$form->disableSecurityToken();
}
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
return $form;
}
}