class DateTimeValidatorTest in Zircon Profile 8
Same name and namespace in other branches
- 8.0 vendor/symfony/validator/Tests/Constraints/DateTimeValidatorTest.php \Symfony\Component\Validator\Tests\Constraints\DateTimeValidatorTest
Hierarchy
- class \Symfony\Component\Validator\Tests\Constraints\AbstractConstraintValidatorTest extends \Symfony\Component\Validator\Tests\Constraints\PHPUnit_Framework_TestCase
- class \Symfony\Component\Validator\Tests\Constraints\DateTimeValidatorTest
Expanded class hierarchy of DateTimeValidatorTest
File
- vendor/
symfony/ validator/ Tests/ Constraints/ DateTimeValidatorTest.php, line 18
Namespace
Symfony\Component\Validator\Tests\ConstraintsView source
class DateTimeValidatorTest extends AbstractConstraintValidatorTest {
protected function getApiVersion() {
return Validation::API_VERSION_2_5;
}
protected function createValidator() {
return new DateTimeValidator();
}
public function testNullIsValid() {
$this->validator
->validate(null, new DateTime());
$this
->assertNoViolation();
}
public function testEmptyStringIsValid() {
$this->validator
->validate('', new DateTime());
$this
->assertNoViolation();
}
public function testDateTimeClassIsValid() {
$this->validator
->validate(new \DateTime(), new DateTime());
$this
->assertNoViolation();
}
/**
* @expectedException \Symfony\Component\Validator\Exception\UnexpectedTypeException
*/
public function testExpectsStringCompatibleType() {
$this->validator
->validate(new \stdClass(), new DateTime());
}
/**
* @dataProvider getValidDateTimes
*/
public function testValidDateTimes($dateTime) {
$this->validator
->validate($dateTime, new DateTime());
$this
->assertNoViolation();
}
public function getValidDateTimes() {
return array(
array(
'2010-01-01 01:02:03',
),
array(
'1955-12-12 00:00:00',
),
array(
'2030-05-31 23:59:59',
),
);
}
/**
* @dataProvider getInvalidDateTimes
*/
public function testInvalidDateTimes($dateTime, $code) {
$constraint = new DateTime(array(
'message' => 'myMessage',
));
$this->validator
->validate($dateTime, $constraint);
$this
->buildViolation('myMessage')
->setParameter('{{ value }}', '"' . $dateTime . '"')
->setCode($code)
->assertRaised();
}
public function getInvalidDateTimes() {
return array(
array(
'foobar',
DateTime::INVALID_FORMAT_ERROR,
),
array(
'2010-01-01',
DateTime::INVALID_FORMAT_ERROR,
),
array(
'00:00:00',
DateTime::INVALID_FORMAT_ERROR,
),
array(
'2010-01-01 00:00',
DateTime::INVALID_FORMAT_ERROR,
),
array(
'2010-13-01 00:00:00',
DateTime::INVALID_DATE_ERROR,
),
array(
'2010-04-32 00:00:00',
DateTime::INVALID_DATE_ERROR,
),
array(
'2010-02-29 00:00:00',
DateTime::INVALID_DATE_ERROR,
),
array(
'2010-01-01 24:00:00',
DateTime::INVALID_TIME_ERROR,
),
array(
'2010-01-01 00:60:00',
DateTime::INVALID_TIME_ERROR,
),
array(
'2010-01-01 00:00:60',
DateTime::INVALID_TIME_ERROR,
),
);
}
}