* Copyright (c) Cake Software Foundation, Inc. (https://cakefoundation.org) * * Licensed under The MIT License * For full copyright and license information, please see the LICENSE.txt * Redistributions of files must retain the above copyright notice * * @copyright Copyright (c) Cake Software Foundation, Inc. (https://cakefoundation.org) * @link https://book.cakephp.org/view/1196/Testing CakePHP(tm) Tests * @package Cake.Test.Case.Model.Validator * @since CakePHP(tm) v 2.2.0 * @license https://opensource.org/licenses/mit-license.php MIT License */ App::uses('CakeValidationRule', 'Model/Validator'); /** * CakeValidationRuleTest * * @package Cake.Test.Case.Model.Validator */ class CakeValidationRuleTest extends CakeTestCase { /** * Auxiliary method to test custom validators * * @return bool */ public function myTestRule() { return false; } /** * Auxiliary method to test custom validators * * @return bool */ public function myTestRule2() { return true; } /** * Auxiliary method to test custom validators * * @return string */ public function myTestRule3() { return 'string'; } /** * Test isValid method * * @return void */ public function testIsValid() { $def = array('rule' => 'notBlank', 'message' => 'Can not be empty'); $data = array( 'fieldName' => '' ); $methods = array(); $Rule = new CakeValidationRule($def); $Rule->process('fieldName', $data, $methods); $this->assertFalse($Rule->isValid()); $data = array('fieldName' => 'not empty'); $Rule->process('fieldName', $data, $methods); $this->assertTrue($Rule->isValid()); } /** * tests that passing custom validation methods work * * @return void */ public function testCustomMethods() { $def = array('rule' => 'myTestRule'); $data = array( 'fieldName' => 'some data' ); $methods = array('mytestrule' => array($this, 'myTestRule')); $Rule = new CakeValidationRule($def); $Rule->process('fieldName', $data, $methods); $this->assertFalse($Rule->isValid()); $methods = array('mytestrule' => array($this, 'myTestRule2')); $Rule->process('fieldName', $data, $methods); $this->assertTrue($Rule->isValid()); $methods = array('mytestrule' => array($this, 'myTestRule3')); $Rule->process('fieldName', $data, $methods); $this->assertFalse($Rule->isValid()); } /** * Make sure errors are triggered when validation is missing. * * @expectedException PHPUnit_Framework_Error_Warning * @expectedExceptionMessage Could not find validation handler totallyMissing for fieldName * @return void */ public function testCustomMethodMissingError() { $def = array('rule' => array('totallyMissing')); $data = array( 'fieldName' => 'some data' ); $methods = array('mytestrule' => array($this, 'myTestRule')); $Rule = new CakeValidationRule($def); $Rule->process('fieldName', $data, $methods); } /** * Test isRequired method * * @return void */ public function testIsRequired() { $def = array('rule' => 'notBlank', 'required' => true); $Rule = new CakeValidationRule($def); $this->assertTrue($Rule->isRequired()); $def = array('rule' => 'notBlank', 'required' => false); $Rule = new CakeValidationRule($def); $this->assertFalse($Rule->isRequired()); $def = array('rule' => 'notBlank', 'required' => 'create'); $Rule = new CakeValidationRule($def); $this->assertTrue($Rule->isRequired()); $def = array('rule' => 'notBlank', 'required' => 'update'); $Rule = new CakeValidationRule($def); $this->assertFalse($Rule->isRequired()); $Rule->isUpdate(true); $this->assertTrue($Rule->isRequired()); } /** * Test isEmptyAllowed method * * @return void */ public function testIsEmptyAllowed() { $def = array('rule' => 'aRule', 'allowEmpty' => true); $Rule = new CakeValidationRule($def); $this->assertTrue($Rule->isEmptyAllowed()); $def = array('rule' => 'aRule', 'allowEmpty' => false); $Rule = new CakeValidationRule($def); $this->assertFalse($Rule->isEmptyAllowed()); $def = array('rule' => 'notBlank', 'allowEmpty' => false, 'on' => 'update'); $Rule = new CakeValidationRule($def); $this->assertTrue($Rule->isEmptyAllowed()); $Rule->isUpdate(true); $this->assertFalse($Rule->isEmptyAllowed()); $def = array('rule' => 'notBlank', 'allowEmpty' => false, 'on' => 'create'); $Rule = new CakeValidationRule($def); $this->assertFalse($Rule->isEmptyAllowed()); $Rule->isUpdate(true); $this->assertTrue($Rule->isEmptyAllowed()); } /** * Test checkRequired method * * @return void */ public function testCheckRequiredWhenRequiredAndAllowEmpty() { $Rule = $this->getMock('CakeValidationRule', array('isRequired')); $Rule->expects($this->any()) ->method('isRequired') ->will($this->returnValue(true)); $Rule->allowEmpty = true; $fieldname = 'field'; $data = array( $fieldname => null ); $this->assertFalse($Rule->checkRequired($fieldname, $data), "A null but present field should not fail requirement check if allowEmpty is true"); $Rule->allowEmpty = false; $this->assertTrue($Rule->checkRequired($fieldname, $data), "A null but present field should fail requirement check if allowEmpty is false"); } }