2009-07-24 22:17:14 +00:00
|
|
|
<?php
|
|
|
|
/* SVN FILE: $Id: model.test.php 8225 2009-07-08 03:25:30Z mark_story $ */
|
|
|
|
/**
|
|
|
|
* ModelValidationTest file
|
|
|
|
*
|
|
|
|
* Long description for file
|
|
|
|
*
|
|
|
|
* PHP versions 4 and 5
|
|
|
|
*
|
|
|
|
* CakePHP(tm) Tests <https://trac.cakephp.org/wiki/Developement/TestSuite>
|
2010-01-13 23:47:14 -05:00
|
|
|
* Copyright 2005-2010, Cake Software Foundation, Inc. (http://www.cakefoundation.org)
|
2009-07-24 22:17:14 +00:00
|
|
|
*
|
|
|
|
* Licensed under The Open Group Test Suite License
|
|
|
|
* Redistributions of files must retain the above copyright notice.
|
|
|
|
*
|
|
|
|
* @filesource
|
2010-01-13 23:47:14 -05:00
|
|
|
* @copyright Copyright 2005-2010, Cake Software Foundation, Inc. (http://www.cakefoundation.org)
|
2009-07-24 22:17:14 +00:00
|
|
|
* @link https://trac.cakephp.org/wiki/Developement/TestSuite CakePHP(tm) Tests
|
|
|
|
* @package cake
|
|
|
|
* @subpackage cake.tests.cases.libs.model
|
|
|
|
* @since CakePHP(tm) v 1.2.0.4206
|
|
|
|
* @version $Revision: 8225 $
|
|
|
|
* @modifiedby $LastChangedBy: mark_story $
|
|
|
|
* @lastmodified $Date: 2009-07-07 23:25:30 -0400 (Tue, 07 Jul 2009) $
|
|
|
|
* @license http://www.opensource.org/licenses/opengroup.php The Open Group Test Suite License
|
|
|
|
*/
|
|
|
|
require_once dirname(__FILE__) . DS . 'model.test.php';
|
2009-10-16 09:19:23 -04:00
|
|
|
|
2009-07-24 22:17:14 +00:00
|
|
|
/**
|
|
|
|
* ModelValidationTest
|
|
|
|
*
|
|
|
|
* @package cake
|
|
|
|
* @subpackage cake.tests.cases.libs.model.operations
|
|
|
|
*/
|
|
|
|
class ModelValidationTest extends BaseModelTest {
|
|
|
|
/**
|
|
|
|
* Tests validation parameter order in custom validation methods
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
function testValidationParams() {
|
|
|
|
$TestModel =& new ValidationTest1();
|
|
|
|
$TestModel->validate['title'] = array(
|
|
|
|
'rule' => 'customValidatorWithParams',
|
|
|
|
'required' => true
|
|
|
|
);
|
|
|
|
$TestModel->create(array('title' => 'foo'));
|
|
|
|
$TestModel->invalidFields();
|
|
|
|
|
|
|
|
$expected = array(
|
|
|
|
'data' => array(
|
|
|
|
'title' => 'foo'
|
|
|
|
),
|
|
|
|
'validator' => array(
|
|
|
|
'rule' => 'customValidatorWithParams',
|
|
|
|
'on' => null,
|
|
|
|
'last' => false,
|
|
|
|
'allowEmpty' => false,
|
|
|
|
'required' => true
|
|
|
|
),
|
|
|
|
'or' => true,
|
|
|
|
'ignore_on_same' => 'id'
|
|
|
|
);
|
|
|
|
$this->assertEqual($TestModel->validatorParams, $expected);
|
|
|
|
|
|
|
|
$TestModel->validate['title'] = array(
|
|
|
|
'rule' => 'customValidatorWithMessage',
|
|
|
|
'required' => true
|
|
|
|
);
|
|
|
|
$expected = array(
|
|
|
|
'title' => 'This field will *never* validate! Muhahaha!'
|
|
|
|
);
|
|
|
|
|
|
|
|
$this->assertEqual($TestModel->invalidFields(), $expected);
|
2010-01-01 23:34:11 -05:00
|
|
|
|
|
|
|
$TestModel->validate['title'] = array(
|
|
|
|
'rule' => array('customValidatorWithSixParams', 'one', 'two', null, 'four'),
|
|
|
|
'required' => true
|
|
|
|
);
|
|
|
|
$TestModel->create(array('title' => 'foo'));
|
|
|
|
$TestModel->invalidFields();
|
|
|
|
$expected = array(
|
|
|
|
'data' => array(
|
|
|
|
'title' => 'foo'
|
|
|
|
),
|
|
|
|
'one' => 'one',
|
|
|
|
'two' => 'two',
|
|
|
|
'three' => null,
|
|
|
|
'four' => 'four',
|
|
|
|
'five' => array(
|
|
|
|
'rule' => array(1 => 'one', 2 => 'two', 3 => null, 4 => 'four'),
|
|
|
|
'on' => null,
|
|
|
|
'last' => false,
|
|
|
|
'allowEmpty' => false,
|
|
|
|
'required' => true
|
|
|
|
),
|
|
|
|
'six' => 6
|
|
|
|
);
|
|
|
|
$this->assertEqual($TestModel->validatorParams, $expected);
|
|
|
|
|
|
|
|
$TestModel->validate['title'] = array(
|
|
|
|
'rule' => array('customValidatorWithSixParams', 'one', array('two'), null, 'four', array('five' => 5)),
|
|
|
|
'required' => true
|
|
|
|
);
|
|
|
|
$TestModel->create(array('title' => 'foo'));
|
|
|
|
$TestModel->invalidFields();
|
|
|
|
$expected = array(
|
|
|
|
'data' => array(
|
|
|
|
'title' => 'foo'
|
|
|
|
),
|
|
|
|
'one' => 'one',
|
|
|
|
'two' => array('two'),
|
|
|
|
'three' => null,
|
|
|
|
'four' => 'four',
|
|
|
|
'five' => array('five' => 5),
|
|
|
|
'six' => array(
|
|
|
|
'rule' => array(1 => 'one', 2 => array('two'), 3 => null, 4 => 'four', 5 => array('five' => 5)),
|
|
|
|
'on' => null,
|
|
|
|
'last' => false,
|
|
|
|
'allowEmpty' => false,
|
|
|
|
'required' => true
|
|
|
|
)
|
|
|
|
);
|
|
|
|
$this->assertEqual($TestModel->validatorParams, $expected);
|
2009-07-24 22:17:14 +00:00
|
|
|
}
|
|
|
|
/**
|
|
|
|
* Tests validation parameter fieldList in invalidFields
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
function testInvalidFieldsWithFieldListParams() {
|
|
|
|
$TestModel =& new ValidationTest1();
|
|
|
|
$TestModel->validate = $validate = array(
|
|
|
|
'title' => array(
|
|
|
|
'rule' => 'customValidator',
|
|
|
|
'required' => true
|
|
|
|
),
|
|
|
|
'name' => array(
|
|
|
|
'rule' => 'allowEmpty',
|
|
|
|
'required' => true
|
|
|
|
));
|
|
|
|
$TestModel->invalidFields(array('fieldList' => array('title')));
|
|
|
|
$expected = array(
|
|
|
|
'title' => 'This field cannot be left blank'
|
|
|
|
);
|
|
|
|
$this->assertEqual($TestModel->validationErrors, $expected);
|
|
|
|
$TestModel->validationErrors = array();
|
|
|
|
|
|
|
|
$TestModel->invalidFields(array('fieldList' => array('name')));
|
|
|
|
$expected = array(
|
|
|
|
'name' => 'This field cannot be left blank'
|
|
|
|
);
|
|
|
|
$this->assertEqual($TestModel->validationErrors, $expected);
|
|
|
|
$TestModel->validationErrors = array();
|
|
|
|
|
|
|
|
$TestModel->invalidFields(array('fieldList' => array('name', 'title')));
|
|
|
|
$expected = array(
|
|
|
|
'name' => 'This field cannot be left blank',
|
|
|
|
'title' => 'This field cannot be left blank'
|
|
|
|
);
|
|
|
|
$this->assertEqual($TestModel->validationErrors, $expected);
|
|
|
|
$TestModel->validationErrors = array();
|
|
|
|
|
|
|
|
$TestModel->whitelist = array('name');
|
|
|
|
$TestModel->invalidFields();
|
|
|
|
$expected = array('name' => 'This field cannot be left blank');
|
|
|
|
$this->assertEqual($TestModel->validationErrors, $expected);
|
|
|
|
$TestModel->validationErrors = array();
|
|
|
|
|
|
|
|
$this->assertEqual($TestModel->validate, $validate);
|
|
|
|
}
|
2009-12-14 23:21:26 -05:00
|
|
|
/**
|
|
|
|
* test that validates() checks all the 'with' associations as well for validation
|
|
|
|
* as this can cause partial/wrong data insertion.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
function testValidatesWithAssociations() {
|
|
|
|
$data = array(
|
|
|
|
'Something' => array(
|
|
|
|
'id' => 5,
|
|
|
|
'title' => 'Extra Fields',
|
|
|
|
'body' => 'Extra Fields Body',
|
|
|
|
'published' => '1'
|
|
|
|
),
|
|
|
|
'SomethingElse' => array(
|
|
|
|
array('something_else_id' => 1, 'doomed' => '')
|
|
|
|
)
|
|
|
|
);
|
|
|
|
|
|
|
|
$Something =& new Something();
|
|
|
|
$JoinThing =& $Something->JoinThing;
|
|
|
|
|
|
|
|
$JoinThing->validate = array('doomed' => array('rule' => 'notEmpty'));
|
|
|
|
|
|
|
|
$expectedError = array('doomed' => 'This field cannot be left blank');
|
|
|
|
|
|
|
|
$Something->create();
|
|
|
|
$result = $Something->save($data);
|
|
|
|
$this->assertFalse($result, 'Save occured even when with models failed. %s');
|
|
|
|
$this->assertEqual($JoinThing->validationErrors, $expectedError);
|
|
|
|
$count = $Something->find('count', array('conditions' => array('Something.id' => $data['Something']['id'])));
|
|
|
|
$this->assertIdentical($count, 0);
|
|
|
|
|
|
|
|
$data = array(
|
|
|
|
'Something' => array(
|
|
|
|
'id' => 5,
|
|
|
|
'title' => 'Extra Fields',
|
|
|
|
'body' => 'Extra Fields Body',
|
|
|
|
'published' => '1'
|
|
|
|
),
|
|
|
|
'SomethingElse' => array(
|
|
|
|
array('something_else_id' => 1, 'doomed' => 1),
|
|
|
|
array('something_else_id' => 1, 'doomed' => '')
|
|
|
|
)
|
|
|
|
);
|
|
|
|
$Something->create();
|
|
|
|
$result = $Something->save($data);
|
|
|
|
$this->assertFalse($result, 'Save occured even when with models failed. %s');
|
|
|
|
|
|
|
|
$joinRecords = $JoinThing->find('count', array(
|
|
|
|
'conditions' => array('JoinThing.something_id' => $data['Something']['id'])
|
|
|
|
));
|
|
|
|
$this->assertEqual($joinRecords, 0, 'Records were saved on the join table. %s');
|
|
|
|
}
|
|
|
|
/**
|
|
|
|
* test that saveAll and with models with validation interact well
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
function testValidatesWithModelsAndSaveAll() {
|
|
|
|
$data = array(
|
|
|
|
'Something' => array(
|
|
|
|
'id' => 5,
|
|
|
|
'title' => 'Extra Fields',
|
|
|
|
'body' => 'Extra Fields Body',
|
|
|
|
'published' => '1'
|
|
|
|
),
|
|
|
|
'SomethingElse' => array(
|
|
|
|
array('something_else_id' => 1, 'doomed' => '')
|
|
|
|
)
|
|
|
|
);
|
|
|
|
$Something =& new Something();
|
|
|
|
$JoinThing =& $Something->JoinThing;
|
|
|
|
|
|
|
|
$JoinThing->validate = array('doomed' => array('rule' => 'notEmpty'));
|
|
|
|
$expectedError = array('doomed' => 'This field cannot be left blank');
|
|
|
|
|
|
|
|
$Something->create();
|
|
|
|
$result = $Something->saveAll($data, array('validate' => 'only'));
|
|
|
|
$this->assertFalse($result);
|
|
|
|
$this->assertEqual($JoinThing->validationErrors, $expectedError);
|
|
|
|
|
|
|
|
$Something->create();
|
|
|
|
$result = $Something->saveAll($data, array('validate' => 'first'));
|
|
|
|
$this->assertFalse($result);
|
|
|
|
$this->assertEqual($JoinThing->validationErrors, $expectedError);
|
2009-07-24 22:17:14 +00:00
|
|
|
|
2009-12-14 23:21:26 -05:00
|
|
|
$count = $Something->find('count', array('conditions' => array('Something.id' => $data['Something']['id'])));
|
|
|
|
$this->assertIdentical($count, 0);
|
|
|
|
|
|
|
|
$joinRecords = $JoinThing->find('count', array(
|
|
|
|
'conditions' => array('JoinThing.something_id' => $data['Something']['id'])
|
|
|
|
));
|
|
|
|
$this->assertEqual($joinRecords, 0, 'Records were saved on the join table. %s');
|
|
|
|
}
|
2009-07-24 22:17:14 +00:00
|
|
|
}
|
|
|
|
?>
|