2012-04-23 11:02:26 +00:00
|
|
|
<?php
|
|
|
|
/**
|
2012-05-11 01:31:44 +00:00
|
|
|
* CakeValidationRuleTest file
|
2012-04-23 11:02:26 +00:00
|
|
|
*
|
|
|
|
* 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)
|
|
|
|
*/
|
|
|
|
|
2012-05-11 01:31:44 +00:00
|
|
|
App::uses('CakeValidationRule', 'Model/Validator');
|
2012-04-23 11:02:26 +00:00
|
|
|
|
|
|
|
/**
|
2012-05-11 01:31:44 +00:00
|
|
|
* CakeValidationRuleTest
|
2012-04-23 11:02:26 +00:00
|
|
|
*
|
|
|
|
* @package Cake.Test.Case.Model.Validator
|
|
|
|
*/
|
2012-05-11 01:31:44 +00:00
|
|
|
class CakeValidationRuleTest extends CakeTestCase {
|
2012-04-23 11:02:26 +00:00
|
|
|
|
|
|
|
/**
|
2012-04-30 00:26:24 +00:00
|
|
|
* 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
|
2012-04-23 11:02:26 +00:00
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function testIsValid() {
|
2012-04-30 00:26:24 +00:00
|
|
|
$def = array('rule' => 'notEmpty', 'message' => 'Can not be empty');
|
|
|
|
$data = array(
|
|
|
|
'fieldName' => ''
|
|
|
|
);
|
|
|
|
$methods = array();
|
|
|
|
|
2012-05-11 01:31:44 +00:00
|
|
|
$Rule = new CakeValidationRule($def);
|
2012-04-30 00:26:24 +00:00
|
|
|
$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'));
|
|
|
|
|
2012-05-11 01:31:44 +00:00
|
|
|
$Rule = new CakeValidationRule($def);
|
2012-04-30 00:26:24 +00:00
|
|
|
$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);
|
2012-05-11 01:31:44 +00:00
|
|
|
$Rule = new CakeValidationRule($def);
|
2012-04-30 00:26:24 +00:00
|
|
|
$this->assertTrue($Rule->isRequired());
|
|
|
|
|
|
|
|
$def = array('rule' => 'notEmpty', 'required' => false);
|
2012-05-11 01:31:44 +00:00
|
|
|
$Rule = new CakeValidationRule($def);
|
2012-04-30 00:26:24 +00:00
|
|
|
$this->assertFalse($Rule->isRequired());
|
|
|
|
|
|
|
|
$def = array('rule' => 'notEmpty', 'required' => 'create');
|
2012-05-11 01:31:44 +00:00
|
|
|
$Rule = new CakeValidationRule($def);
|
2012-04-30 00:26:24 +00:00
|
|
|
$this->assertTrue($Rule->isRequired());
|
|
|
|
|
|
|
|
$def = array('rule' => 'notEmpty', 'required' => 'update');
|
2012-05-11 01:31:44 +00:00
|
|
|
$Rule = new CakeValidationRule($def);
|
2012-04-30 00:26:24 +00:00
|
|
|
$this->assertFalse($Rule->isRequired());
|
2012-04-23 11:02:26 +00:00
|
|
|
|
2012-04-30 00:26:24 +00:00
|
|
|
$Rule->isUpdate(true);
|
|
|
|
$this->assertTrue($Rule->isRequired());
|
2012-04-23 11:02:26 +00:00
|
|
|
}
|
2012-05-11 03:43:45 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Test isEmptyAllowed method
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
2012-06-25 00:06:14 +00:00
|
|
|
public function testIsEmptyAllowed() {
|
2012-05-11 03:43:45 +00:00
|
|
|
$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());
|
|
|
|
}
|
2012-04-23 11:02:26 +00:00
|
|
|
}
|