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/LanguageValidatorTest.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

94 lines
2.3 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\Language;
use Symfony\Component\Validator\Constraints\LanguageValidator;
class LanguageValidatorTest extends \PHPUnit_Framework_TestCase
{
protected $validator;
protected function setUp()
{
$this->validator = new LanguageValidator();
}
protected function tearDown()
{
$this->validator = null;
}
public function testNullIsValid()
{
$this->assertTrue($this->validator->isValid(null, new Language()));
}
public function testEmptyStringIsValid()
{
$this->assertTrue($this->validator->isValid('', new Language()));
}
public function testExpectsStringCompatibleType()
{
$this->setExpectedException('Symfony\Component\Validator\Exception\UnexpectedTypeException');
$this->validator->isValid(new \stdClass(), new Language());
}
/**
* @dataProvider getValidLanguages
*/
public function testValidLanguages($date)
{
$this->assertTrue($this->validator->isValid($date, new Language()));
}
public function getValidLanguages()
{
return array(
array('en'),
array('en_US'),
array('my'),
);
}
/**
* @dataProvider getInvalidLanguages
*/
public function testInvalidLanguages($date)
{
$this->assertFalse($this->validator->isValid($date, new Language()));
}
public function getInvalidLanguages()
{
return array(
array('EN'),
array('foobar'),
);
}
public function testMessageIsSet()
{
$constraint = new Language(array(
'message' => 'myMessage'
));
$this->assertFalse($this->validator->isValid('foobar', $constraint));
$this->assertEquals($this->validator->getMessageTemplate(), 'myMessage');
$this->assertEquals($this->validator->getMessageParameters(), array(
'{{ value }}' => 'foobar',
));
}
}