Version 1
[yaffs-website] / vendor / symfony / validator / Tests / Constraints / DateTimeValidatorTest.php
diff --git a/vendor/symfony/validator/Tests/Constraints/DateTimeValidatorTest.php b/vendor/symfony/validator/Tests/Constraints/DateTimeValidatorTest.php
new file mode 100644 (file)
index 0000000..25d88aa
--- /dev/null
@@ -0,0 +1,110 @@
+<?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\Component\Validator\Tests\Constraints;
+
+use Symfony\Component\Validator\Constraints\DateTime;
+use Symfony\Component\Validator\Constraints\DateTimeValidator;
+use Symfony\Component\Validator\Validation;
+
+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),
+        );
+    }
+}