mirror of
https://github.com/kamilwylegala/cakephp2-php8.git
synced 2025-01-20 03:26:16 +00:00
eb7b66b37c
In 2.1, the default value was null, which does not impart any behavior. In 2.2 this was changed to false, which makes it hard to validate '' with validation methods. Move some tests around and update tests that probably should have been failing before. Fixes #2983
155 lines
4 KiB
PHP
155 lines
4 KiB
PHP
<?php
|
|
/**
|
|
* CakeValidationRuleTest file
|
|
*
|
|
* PHP 5
|
|
*
|
|
* CakePHP(tm) Tests <http://book.cakephp.org/view/1196/Testing>
|
|
* Copyright 2005-2012, Cake Software Foundation, Inc. (http://cakefoundation.org)
|
|
*
|
|
* Licensed under The MIT License
|
|
* Redistributions of files must retain the above copyright notice
|
|
*
|
|
* @copyright Copyright 2005-2012, Cake Software Foundation, Inc. (http://cakefoundation.org)
|
|
* @link http://book.cakephp.org/view/1196/Testing CakePHP(tm) Tests
|
|
* @package Cake.Test.Case.Model.Validator
|
|
* @since CakePHP(tm) v 2.2.0
|
|
* @license MIT License (http://www.opensource.org/licenses/mit-license.php)
|
|
*/
|
|
|
|
App::uses('CakeValidationRule', 'Model/Validator');
|
|
|
|
/**
|
|
* CakeValidationRuleTest
|
|
*
|
|
* @package Cake.Test.Case.Model.Validator
|
|
*/
|
|
class CakeValidationRuleTest extends CakeTestCase {
|
|
|
|
/**
|
|
* Auxiliary method to test custom validators
|
|
*
|
|
* @return boolean
|
|
**/
|
|
public function myTestRule() {
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* Auxiliary method to test custom validators
|
|
*
|
|
* @return boolean
|
|
**/
|
|
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' => 'notEmpty', '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());
|
|
}
|
|
|
|
/**
|
|
* Test isRequired method
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testIsRequired() {
|
|
$def = array('rule' => 'notEmpty', 'required' => true);
|
|
$Rule = new CakeValidationRule($def);
|
|
$this->assertTrue($Rule->isRequired());
|
|
|
|
$def = array('rule' => 'notEmpty', 'required' => false);
|
|
$Rule = new CakeValidationRule($def);
|
|
$this->assertFalse($Rule->isRequired());
|
|
|
|
$def = array('rule' => 'notEmpty', 'required' => 'create');
|
|
$Rule = new CakeValidationRule($def);
|
|
$this->assertTrue($Rule->isRequired());
|
|
|
|
$def = array('rule' => 'notEmpty', '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' => 'notEmpty', 'allowEmpty' => false, 'on' => 'update');
|
|
$Rule = new CakeValidationRule($def);
|
|
$this->assertTrue($Rule->isEmptyAllowed());
|
|
|
|
$Rule->isUpdate(true);
|
|
$this->assertFalse($Rule->isEmptyAllowed());
|
|
|
|
$def = array('rule' => 'notEmpty', 'allowEmpty' => false, 'on' => 'create');
|
|
$Rule = new CakeValidationRule($def);
|
|
$this->assertFalse($Rule->isEmptyAllowed());
|
|
|
|
$Rule->isUpdate(true);
|
|
$this->assertTrue($Rule->isEmptyAllowed());
|
|
}
|
|
}
|