2006-04-14 00:37:28 +04:00
|
|
|
<?php
|
|
|
|
class Doctrine_ValidatorTestCase extends Doctrine_UnitTestCase {
|
2006-06-07 13:07:38 +04:00
|
|
|
public function prepareTables() {
|
2006-09-04 10:27:27 +04:00
|
|
|
$this->tables[] = "ValidatorTest";
|
2006-06-07 13:07:38 +04:00
|
|
|
parent::prepareTables();
|
|
|
|
}
|
2006-09-20 13:35:29 +04:00
|
|
|
|
2006-06-11 16:02:05 +04:00
|
|
|
public function testIsValidType() {
|
|
|
|
$var = "123";
|
|
|
|
$this->assertTrue(Doctrine_Validator::isValidType($var,"string"));
|
|
|
|
$this->assertTrue(Doctrine_Validator::isValidType($var,"integer"));
|
|
|
|
$this->assertTrue(Doctrine_Validator::isValidType($var,"float"));
|
|
|
|
$this->assertFalse(Doctrine_Validator::isValidType($var,"array"));
|
|
|
|
$this->assertFalse(Doctrine_Validator::isValidType($var,"object"));
|
|
|
|
|
|
|
|
$var = 123;
|
|
|
|
$this->assertTrue(Doctrine_Validator::isValidType($var,"string"));
|
|
|
|
$this->assertTrue(Doctrine_Validator::isValidType($var,"integer"));
|
|
|
|
$this->assertTrue(Doctrine_Validator::isValidType($var,"float"));
|
|
|
|
$this->assertFalse(Doctrine_Validator::isValidType($var,"array"));
|
|
|
|
$this->assertFalse(Doctrine_Validator::isValidType($var,"object"));
|
|
|
|
|
|
|
|
$var = 123.12;
|
|
|
|
$this->assertTrue(Doctrine_Validator::isValidType($var,"string"));
|
|
|
|
$this->assertFalse(Doctrine_Validator::isValidType($var,"integer"));
|
|
|
|
$this->assertTrue(Doctrine_Validator::isValidType($var,"float"));
|
|
|
|
$this->assertFalse(Doctrine_Validator::isValidType($var,"array"));
|
|
|
|
$this->assertFalse(Doctrine_Validator::isValidType($var,"object"));
|
|
|
|
|
|
|
|
$var = '123.12';
|
|
|
|
$this->assertTrue(Doctrine_Validator::isValidType($var,"string"));
|
|
|
|
$this->assertFalse(Doctrine_Validator::isValidType($var,"integer"));
|
|
|
|
$this->assertTrue(Doctrine_Validator::isValidType($var,"float"));
|
|
|
|
$this->assertFalse(Doctrine_Validator::isValidType($var,"array"));
|
|
|
|
$this->assertFalse(Doctrine_Validator::isValidType($var,"object"));
|
|
|
|
|
|
|
|
$var = '';
|
|
|
|
$this->assertTrue(Doctrine_Validator::isValidType($var,"string"));
|
|
|
|
$this->assertFalse(Doctrine_Validator::isValidType($var,"integer"));
|
|
|
|
$this->assertFalse(Doctrine_Validator::isValidType($var,"float"));
|
|
|
|
$this->assertFalse(Doctrine_Validator::isValidType($var,"array"));
|
|
|
|
$this->assertFalse(Doctrine_Validator::isValidType($var,"object"));
|
|
|
|
|
|
|
|
$var = null;
|
|
|
|
$this->assertTrue(Doctrine_Validator::isValidType($var,"string"));
|
|
|
|
$this->assertTrue(Doctrine_Validator::isValidType($var,"integer"));
|
|
|
|
$this->assertTrue(Doctrine_Validator::isValidType($var,"float"));
|
|
|
|
$this->assertTrue(Doctrine_Validator::isValidType($var,"array"));
|
|
|
|
$this->assertTrue(Doctrine_Validator::isValidType($var,"object"));
|
|
|
|
|
|
|
|
$var = 'str';
|
|
|
|
$this->assertTrue(Doctrine_Validator::isValidType($var,"string"));
|
|
|
|
$this->assertFalse(Doctrine_Validator::isValidType($var,"integer"));
|
|
|
|
$this->assertFalse(Doctrine_Validator::isValidType($var,"float"));
|
|
|
|
$this->assertFalse(Doctrine_Validator::isValidType($var,"array"));
|
|
|
|
$this->assertFalse(Doctrine_Validator::isValidType($var,"object"));
|
|
|
|
|
|
|
|
$var = array();
|
|
|
|
$this->assertFalse(Doctrine_Validator::isValidType($var,"string"));
|
|
|
|
$this->assertFalse(Doctrine_Validator::isValidType($var,"integer"));
|
|
|
|
$this->assertFalse(Doctrine_Validator::isValidType($var,"float"));
|
|
|
|
$this->assertTrue(Doctrine_Validator::isValidType($var,"array"));
|
|
|
|
$this->assertFalse(Doctrine_Validator::isValidType($var,"object"));
|
|
|
|
|
|
|
|
$var = new Exception();
|
|
|
|
$this->assertFalse(Doctrine_Validator::isValidType($var,"string"));
|
|
|
|
$this->assertFalse(Doctrine_Validator::isValidType($var,"integer"));
|
|
|
|
$this->assertFalse(Doctrine_Validator::isValidType($var,"float"));
|
|
|
|
$this->assertFalse(Doctrine_Validator::isValidType($var,"array"));
|
|
|
|
$this->assertTrue(Doctrine_Validator::isValidType($var,"object"));
|
|
|
|
}
|
|
|
|
|
2006-06-07 13:07:38 +04:00
|
|
|
public function testValidate2() {
|
2006-09-04 10:27:27 +04:00
|
|
|
$test = new ValidatorTest();
|
2006-06-07 13:07:38 +04:00
|
|
|
$test->mymixed = "message";
|
2006-09-04 10:55:16 +04:00
|
|
|
$test->myrange = 1;
|
|
|
|
$test->myregexp = '123a';
|
|
|
|
|
2006-06-07 13:07:38 +04:00
|
|
|
$validator = new Doctrine_Validator();
|
|
|
|
$validator->validateRecord($test);
|
|
|
|
|
|
|
|
$stack = $validator->getErrorStack();
|
|
|
|
|
|
|
|
$this->assertTrue(is_array($stack));
|
2006-09-04 10:27:27 +04:00
|
|
|
$this->assertTrue(isset($stack['ValidatorTest'][0]));
|
|
|
|
$stack = $stack['ValidatorTest'][0];
|
2006-06-07 13:07:38 +04:00
|
|
|
|
2006-08-16 01:32:59 +04:00
|
|
|
|
2006-06-07 13:07:38 +04:00
|
|
|
$this->assertEqual($stack['mystring'], Doctrine_Validator::ERR_NOTNULL);
|
2006-08-16 01:32:59 +04:00
|
|
|
$this->assertEqual($stack['myemail2'], Doctrine_Validator::ERR_NOTBLANK);
|
2006-09-04 10:55:16 +04:00
|
|
|
$this->assertEqual($stack['myrange'], Doctrine_Validator::ERR_RANGE);
|
|
|
|
$this->assertEqual($stack['myregexp'], Doctrine_Validator::ERR_REGEXP);
|
2006-06-07 13:07:38 +04:00
|
|
|
$test->mystring = 'str';
|
|
|
|
|
2006-08-20 22:52:07 +04:00
|
|
|
|
2006-06-07 13:07:38 +04:00
|
|
|
$test->save();
|
|
|
|
}
|
2006-08-20 22:52:07 +04:00
|
|
|
public function testEmailValidation() {
|
|
|
|
}
|
2006-05-15 16:15:20 +04:00
|
|
|
|
2006-04-14 00:37:28 +04:00
|
|
|
public function testValidate() {
|
2006-08-22 03:20:33 +04:00
|
|
|
$user = $this->connection->getTable("User")->find(4);
|
2006-04-14 00:37:28 +04:00
|
|
|
|
|
|
|
$set = array("password" => "this is an example of too long password",
|
|
|
|
"loginname" => "this is an example of too long loginname",
|
|
|
|
"name" => "valid name",
|
|
|
|
"created" => "invalid");
|
2006-05-15 16:15:20 +04:00
|
|
|
$user->setArray($set);
|
|
|
|
$email = $user->Email;
|
2006-04-14 00:37:28 +04:00
|
|
|
$email->address = "zYne@invalid";
|
|
|
|
|
2006-05-15 16:15:20 +04:00
|
|
|
$this->assertTrue($user->getModified() == $set);
|
2006-04-14 00:37:28 +04:00
|
|
|
|
|
|
|
$validator = new Doctrine_Validator();
|
2006-05-15 16:15:20 +04:00
|
|
|
$validator->validateRecord($user);
|
2006-04-14 00:37:28 +04:00
|
|
|
$validator->validateRecord($email);
|
|
|
|
|
|
|
|
$stack = $validator->getErrorStack();
|
|
|
|
|
|
|
|
$this->assertTrue(is_array($stack));
|
|
|
|
$this->assertEqual($stack["User"][0]["loginname"], Doctrine_Validator::ERR_LENGTH);
|
|
|
|
$this->assertEqual($stack["User"][0]["password"], Doctrine_Validator::ERR_LENGTH);
|
|
|
|
$this->assertEqual($stack["User"][0]["created"], Doctrine_Validator::ERR_TYPE);
|
|
|
|
|
|
|
|
$this->assertEqual($stack["Email"][0]["address"], Doctrine_Validator::ERR_VALID);
|
|
|
|
$email->address = "arnold@example.com";
|
|
|
|
|
|
|
|
$validator->validateRecord($email);
|
|
|
|
$stack = $validator->getErrorStack();
|
|
|
|
$this->assertEqual($stack["Email"][1]["address"], Doctrine_Validator::ERR_UNIQUE);
|
|
|
|
|
|
|
|
}
|
2006-05-15 16:15:20 +04:00
|
|
|
|
2006-04-14 00:37:28 +04:00
|
|
|
public function testIsValidEmail() {
|
|
|
|
|
|
|
|
$validator = new Doctrine_Validator_Email();
|
|
|
|
|
2006-08-22 03:20:33 +04:00
|
|
|
$email = $this->connection->create("Email");
|
2006-05-25 02:33:48 +04:00
|
|
|
$this->assertFalse($validator->validate($email,"address","example@example",null));
|
|
|
|
$this->assertFalse($validator->validate($email,"address","example@@example",null));
|
|
|
|
$this->assertFalse($validator->validate($email,"address","example@example.",null));
|
|
|
|
$this->assertFalse($validator->validate($email,"address","example@e..",null));
|
2006-04-14 00:37:28 +04:00
|
|
|
|
2006-05-25 02:33:48 +04:00
|
|
|
$this->assertFalse($validator->validate($email,"address","example@e..",null));
|
2006-09-04 10:27:27 +04:00
|
|
|
|
2006-10-02 05:23:23 +04:00
|
|
|
$this->assertTrue($validator->validate($email,"address","null@pookey.co.uk",null));
|
|
|
|
$this->assertTrue($validator->validate($email,"address","null@pookey.com",null));
|
|
|
|
$this->assertTrue($validator->validate($email,"address","null@users.doctrine.pengus.net",null));
|
2006-04-14 00:37:28 +04:00
|
|
|
|
|
|
|
}
|
2006-09-20 13:35:29 +04:00
|
|
|
|
2006-04-14 00:37:28 +04:00
|
|
|
public function testSave() {
|
|
|
|
$this->manager->setAttribute(Doctrine::ATTR_VLD, true);
|
2006-08-22 03:20:33 +04:00
|
|
|
$user = $this->connection->getTable("User")->find(4);
|
2006-04-14 00:37:28 +04:00
|
|
|
try {
|
2006-05-15 16:15:20 +04:00
|
|
|
$user->name = "this is an example of too long name not very good example but an example nevertheless";
|
|
|
|
$user->save();
|
2006-04-14 00:37:28 +04:00
|
|
|
} catch(Doctrine_Validator_Exception $e) {
|
|
|
|
$this->assertEqual($e->getErrorStack(),array("User" => array(array("name" => 0))));
|
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
2006-08-22 03:20:33 +04:00
|
|
|
$user = $this->connection->create("User");
|
2006-04-14 00:37:28 +04:00
|
|
|
$user->Email->address = "jackdaniels@drinkmore.info...";
|
|
|
|
$user->name = "this is an example of too long user name not very good example but an example nevertheles";
|
|
|
|
$user->save();
|
|
|
|
} catch(Doctrine_Validator_Exception $e) {
|
|
|
|
$a = $e->getErrorStack();
|
|
|
|
}
|
|
|
|
$this->assertTrue(is_array($a));
|
|
|
|
$this->assertEqual($a["Email"][0]["address"], Doctrine_Validator::ERR_VALID);
|
|
|
|
$this->assertEqual($a["User"][0]["name"], Doctrine_Validator::ERR_LENGTH);
|
2006-05-15 16:15:20 +04:00
|
|
|
$this->manager->setAttribute(Doctrine::ATTR_VLD, false);
|
2006-04-14 00:37:28 +04:00
|
|
|
}
|
2006-06-20 01:31:22 +04:00
|
|
|
|
2006-04-14 00:37:28 +04:00
|
|
|
}
|
|
|
|
?>
|