mirror of
https://github.com/kamilwylegala/cakephp2-php8.git
synced 2024-11-29 18:27:19 +00:00
198 lines
5.2 KiB
PHP
198 lines
5.2 KiB
PHP
<?php
|
|
/**
|
|
* CakeValidationRuleTest file
|
|
*
|
|
* CakePHP(tm) Tests <https://book.cakephp.org/view/1196/Testing>
|
|
* 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.
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testCustomMethodMissingError() {
|
|
$this->expectWarning();
|
|
$this->expectWarningMessage('Could not find validation handler totallyMissing for fieldName');
|
|
$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");
|
|
}
|
|
|
|
}
|