View source
<?php
namespace Symfony\Component\Validator\Tests\Constraints;
use Symfony\Component\Validator\Constraints\Date;
use Symfony\Component\Validator\Constraints\DateValidator;
use Symfony\Component\Validator\Validation;
class DateValidatorTest extends AbstractConstraintValidatorTest {
protected function getApiVersion() {
return Validation::API_VERSION_2_5;
}
protected function createValidator() {
return new DateValidator();
}
public function testNullIsValid() {
$this->validator
->validate(null, new Date());
$this
->assertNoViolation();
}
public function testEmptyStringIsValid() {
$this->validator
->validate('', new Date());
$this
->assertNoViolation();
}
public function testDateTimeClassIsValid() {
$this->validator
->validate(new \DateTime(), new Date());
$this
->assertNoViolation();
}
public function testExpectsStringCompatibleType() {
$this->validator
->validate(new \stdClass(), new Date());
}
public function testValidDates($date) {
$this->validator
->validate($date, new Date());
$this
->assertNoViolation();
}
public function getValidDates() {
return array(
array(
'2010-01-01',
),
array(
'1955-12-12',
),
array(
'2030-05-31',
),
);
}
public function testInvalidDates($date, $code) {
$constraint = new Date(array(
'message' => 'myMessage',
));
$this->validator
->validate($date, $constraint);
$this
->buildViolation('myMessage')
->setParameter('{{ value }}', '"' . $date . '"')
->setCode($code)
->assertRaised();
}
public function getInvalidDates() {
return array(
array(
'foobar',
Date::INVALID_FORMAT_ERROR,
),
array(
'foobar 2010-13-01',
Date::INVALID_FORMAT_ERROR,
),
array(
'2010-13-01 foobar',
Date::INVALID_FORMAT_ERROR,
),
array(
'2010-13-01',
Date::INVALID_DATE_ERROR,
),
array(
'2010-04-32',
Date::INVALID_DATE_ERROR,
),
array(
'2010-02-29',
Date::INVALID_DATE_ERROR,
),
);
}
}