This repository has been archived on 2023-08-20. You can view files and clone it, but cannot push or open issues or pull requests.
symfony/tests/Symfony/Tests/Component/Validator/Constraints/DateTimeValidatorTest.php
stloyd edf4b87dcb Add missing "tearDown" functions, and some missing variable declaration (this saves for me almost 20MB when run all tests)
Force AsseticBundle tests to use TestCase
Fix test for DoctrineBundle to use TestCase
2011-06-16 15:06:36 +02:00

107 lines
2.8 KiB
PHP

<?php
/*
* This file is part of the Symfony package.
*
* (c) Fabien Potencier <fabien@symfony.com>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace Symfony\Tests\Component\Validator\Constraints;
use Symfony\Component\Validator\Constraints\DateTime;
use Symfony\Component\Validator\Constraints\DateTimeValidator;
class DateTimeValidatorTest extends \PHPUnit_Framework_TestCase
{
protected $validator;
protected function setUp()
{
$this->validator = new DateTimeValidator();
}
protected function tearDown()
{
$this->validator = null;
}
public function testNullIsValid()
{
$this->assertTrue($this->validator->isValid(null, new DateTime()));
}
public function testEmptyStringIsValid()
{
$this->assertTrue($this->validator->isValid('', new DateTime()));
}
public function testDateTimeClassIsValid()
{
$this->assertTrue($this->validator->isValid(new \DateTime(), new DateTime()));
}
public function testExpectsStringCompatibleType()
{
$this->setExpectedException('Symfony\Component\Validator\Exception\UnexpectedTypeException');
$this->validator->isValid(new \stdClass(), new DateTime());
}
/**
* @dataProvider getValidDateTimes
*/
public function testValidDateTimes($date)
{
$this->assertTrue($this->validator->isValid($date, new DateTime()));
}
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($date)
{
$this->assertFalse($this->validator->isValid($date, new DateTime()));
}
public function getInvalidDateTimes()
{
return array(
array('foobar'),
array('2010-01-01'),
array('00:00:00'),
array('2010-01-01 00:00'),
array('2010-13-01 00:00:00'),
array('2010-04-32 00:00:00'),
array('2010-02-29 00:00:00'),
array('2010-01-01 24:00:00'),
array('2010-01-01 00:60:00'),
array('2010-01-01 00:00:60'),
);
}
public function testMessageIsSet()
{
$constraint = new DateTime(array(
'message' => 'myMessage'
));
$this->assertFalse($this->validator->isValid('foobar', $constraint));
$this->assertEquals($this->validator->getMessageTemplate(), 'myMessage');
$this->assertEquals($this->validator->getMessageParameters(), array(
'{{ value }}' => 'foobar',
));
}
}