Skip to content
This repository has been archived by the owner on Jan 30, 2020. It is now read-only.

Commit

Permalink
Required Validator
Browse files Browse the repository at this point in the history
  • Loading branch information
Maks3w committed Sep 3, 2015
1 parent 76ef192 commit dfca132
Show file tree
Hide file tree
Showing 6 changed files with 158 additions and 15 deletions.
8 changes: 3 additions & 5 deletions src/ArrayInput.php
Original file line number Diff line number Diff line change
Expand Up @@ -63,24 +63,22 @@ public function isValid($context = null)
$hasValue = $this->hasValue();
$required = $this->isRequired();
$hasFallback = $this->hasFallback();
$values = $this->getValue();

if (! $hasValue && $hasFallback) {
$this->setValue($this->getFallbackValue());
return true;
}

if (! $hasValue && $required) {
if ($this->errorMessage === null) {
$this->setErrorMessage('Value is required');
}
return false;
$this->injectRequiredValidator();
$values = [$this];
}

if (!$this->continueIfEmpty() && !$this->allowEmpty()) {
$this->injectNotEmptyValidator();
}
$validator = $this->getValidatorChain();
$values = $this->getValue();
$result = true;
foreach ($values as $value) {
$empty = ($value === null || $value === '' || $value === []);
Expand Down
8 changes: 3 additions & 5 deletions src/FileInput.php
Original file line number Diff line number Diff line change
Expand Up @@ -118,16 +118,15 @@ public function isValid($context = null)
$required = $this->isRequired();
$allowEmpty = $this->allowEmpty();
$continueIfEmpty = $this->continueIfEmpty();
$validator = $this->getValidatorChain();

if (! $hasValue && ! $required) {
return true;
}

if (! $hasValue && $required && ! $this->hasFallback()) {
if ($this->errorMessage === null) {
$this->setErrorMessage('Value is required');
}
return false;
$this->injectRequiredValidator();
return $validator->isValid($this);
}

if ($empty && ! $required && ! $continueIfEmpty) {
Expand All @@ -139,7 +138,6 @@ public function isValid($context = null)
}

$this->injectUploadValidator();
$validator = $this->getValidatorChain();
//$value = $this->getValue(); // Do not run the filters yet for File uploads (see getValue())

if (!is_array($rawValue)) {
Expand Down
32 changes: 28 additions & 4 deletions src/Input.php
Original file line number Diff line number Diff line change
Expand Up @@ -59,6 +59,11 @@ class Input implements
*/
protected $notEmptyValidator = false;

/**
* @var bool If required validator is in the validator chain.
*/
protected $requiredValidator = false;

/**
* @var bool
*/
Expand Down Expand Up @@ -403,10 +408,8 @@ public function isValid($context = null)
}

if (! $hasValue && $required) {
if ($this->errorMessage === null) {
$this->setErrorMessage('Value is required');
}
return false;
$this->injectRequiredValidator();
$value = $this;
}

if ($empty && ! $required && ! $continueIfEmpty) {
Expand Down Expand Up @@ -483,4 +486,25 @@ protected function injectNotEmptyValidator()

$chain->prependValidator(new NotEmpty(), true);
}

/**
* @return void
*/
protected function injectRequiredValidator()
{
$chain = $this->getValidatorChain();

// Check if Required validator is already in chain
$validators = $chain->getValidators();
foreach ($validators as $validator) {
if ($validator['instance'] instanceof Validator\Required) {
$this->requiredValidator = true;
return;
}
}

$this->requiredValidator = true;

$chain->prependValidator(new Validator\Required(), true);
}
}
41 changes: 41 additions & 0 deletions src/Validator/Required.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
<?php

namespace Zend\InputFilter\Validator;

use Zend\InputFilter\Input;
use Zend\Validator\AbstractValidator;

class Required extends AbstractValidator
{
const INVALID = 'inputInvalid';
const REQUIRED = 'inputRequired';

/**
* @var string[]
*/
protected $messageTemplates = [
self::INVALID => 'Invalid type given. Zend\InputFilter\Input is required',
self::REQUIRED => 'Value is required',
];

public function isValid($value)
{
if (!($value instanceof Input)) {
$this->error(self::INVALID);
return false;
}

$input = $value;

if ($input->hasValue()) { // If has value then all is ok
return true;
}

if ($input->isRequired()) { // It's Required and value was not set.
$this->error(self::REQUIRED);
return false;
}

return true;
}
}
6 changes: 5 additions & 1 deletion test/InputTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -168,11 +168,15 @@ public function testRequiredWithoutFallbackAndValueNotSetThenFail()
$input = $this->input;
$input->setRequired(true);

$expectedMessages = [
'inputRequired' => 'Value is required',
];

$this->assertFalse(
$input->isValid(),
'isValid() should be return always false when no fallback value, is required, and not data is set.'
);
$this->assertEquals(['Value is required'], $input->getMessages(), 'getMessages() value not match');
$this->assertEquals($expectedMessages, $input->getMessages(), 'getMessages() value not match');
}

public function testRequiredWithoutFallbackAndValueNotSetThenFailWithCustomErrorMessage()
Expand Down
78 changes: 78 additions & 0 deletions test/Validator/RequiredTest.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,78 @@
<?php

namespace ZendTest\InputFilter\Validator;

use PHPUnit_Framework_MockObject_MockObject as MockObject;
use PHPUnit_Framework_TestCase as TestCase;
use Zend\InputFilter\Input;
use Zend\InputFilter\Validator\Required;

class RequiredTest extends TestCase
{
/**
* @var Required
*/
protected $validator;

protected function setUp()
{
$this->validator = new Required();
}

/**
* @dataProvider inputProvider
*/
public function testValid($input, $expectedIsValid, $expectedMessages)
{
$this->assertEquals(
$expectedIsValid,
$this->validator->isValid($input),
'isValid() value not match. Detail: ' . json_encode($this->validator->getMessages())
);

$this->assertEquals(
$expectedMessages,
$this->validator->getMessages(),
'getMessages() value not match.'
);
}

public function inputProvider()
{
$requiredMsg = [
Required::REQUIRED => 'Value is required',
];

// @codingStandardsIgnoreStart
return [
// Description => [$input, isValid, getMessages]
'Required: T. Value: Set' => [$this->createInputMock(true, true) , true , []],
'Required: T. Value: Not set' => [$this->createInputMock(true, false) , false, $requiredMsg],
'Required: F. Value: set' => [$this->createInputMock(false, true) , true , []],
'Required: F. Value: Not set' => [$this->createInputMock(false, false), true , []],
];
// @codingStandardsIgnoreEnd
}

/**
* @param bool $required
* @param bool $hasValue
*
* @return Input|MockObject
*/
protected function createInputMock($required, $hasValue)
{
/** @var Input|MockObject $input */
$input = $this->getMock(Input::class);

$input->method('isRequired')
->willReturn($required)
;

$input->method('hasValue')
->willReturn($hasValue)
;

return $input;
}
}

0 comments on commit dfca132

Please sign in to comment.