Revert "[Form] Add default validation to TextType field (and related)"

This reverts commit 49d2685bff.

Conflicts:

	src/Symfony/Component/Form/Extension/Core/DataTransformer/ValueToStringTransformer.php
	src/Symfony/Component/Form/Extension/Core/Type/TextType.php
	src/Symfony/Component/Form/Tests/Extension/Core/DataTransformer/ValueToStringTransformerTest.php
	src/Symfony/Component/Form/Tests/Extension/Core/Type/UrlTypeTest.php
This commit is contained in:
Bernhard Schussek 2012-07-10 11:55:19 +02:00
parent 7f0274462f
commit 87fe4871cd
4 changed files with 1 additions and 170 deletions

View File

@ -1,67 +0,0 @@
<?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\Form\Extension\Core\DataTransformer;
use Symfony\Component\Form\DataTransformerInterface;
use Symfony\Component\Form\Exception\UnexpectedTypeException;
/**
* Transforms between a given value and a string.
*
* @author Joseph Bielawski <stloyd@gmail.com>
*/
class ValueToStringTransformer implements DataTransformerInterface
{
/**
* Transforms a value into a string.
*
* @param mixed $value Mixed value.
*
* @return string String value.
*
* @throws UnexpectedTypeException if the given value is not a string or number
*/
public function transform($value)
{
if (null === $value) {
return '';
}
if (!is_string($value) && !is_numeric($value)) {
throw new UnexpectedTypeException($value, 'string or number');
}
return $value;
}
/**
* Transforms a value into a string.
*
* @param string $value String value.
*
* @return string String value.
*
* @throws UnexpectedTypeException if the given value is not a string
*/
public function reverseTransform($value)
{
if (null === $value) {
return '';
}
if (!is_string($value)) {
throw new UnexpectedTypeException($value, 'string');
}
return $value;
}
}

View File

@ -12,22 +12,10 @@
namespace Symfony\Component\Form\Extension\Core\Type;
use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\FormBuilderInterface;
use Symfony\Component\Form\Extension\Core\DataTransformer\ValueToStringTransformer;
use Symfony\Component\OptionsResolver\OptionsResolverInterface;
class TextType extends AbstractType
{
/**
* {@inheritdoc}
*/
public function buildForm(FormBuilderInterface $builder, array $options)
{
$builder
->addViewTransformer(new ValueToStringTransformer())
;
}
/**
* {@inheritdoc}
*/

View File

@ -1,90 +0,0 @@
<?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\Form\Tests\Extension\Core\DataTransformer;
use Symfony\Component\Form\Extension\Core\DataTransformer\ValueToStringTransformer;
class ValueToStringTransformerTest extends \PHPUnit_Framework_TestCase
{
protected $transformer;
protected function setUp()
{
$this->transformer = new ValueToStringTransformer();
}
protected function tearDown()
{
$this->transformer = null;
}
/**
* @dataProvider validDataProvider
*/
public function testTransform($value, $transformed)
{
$this->assertEquals($transformed, $this->transformer->transform($value));
}
/**
* @dataProvider validDataProvider
*/
public function testReverseTransform($value, $transformed)
{
$this->assertEquals($transformed, $this->transformer->reverseTransform($transformed));
}
public function validDataProvider()
{
return array(
array('test', 'test'),
array('', null),
array(null, null),
array(0, '0'),
array('0', '0'),
array(1, '1'),
array('123', '123'),
array(1.23, '1.23'),
);
}
/**
* @dataProvider invalidDataProvider
*/
public function testTransformExpectsStringOrNumber($value)
{
$this->setExpectedException('Symfony\Component\Form\Exception\UnexpectedTypeException');
$this->transformer->transform($value);
}
/**
* @dataProvider invalidDataProvider
*/
public function testReverseTransformExpectsString($value)
{
$this->setExpectedException('Symfony\Component\Form\Exception\UnexpectedTypeException');
$this->transformer->reverseTransform($value);
}
public function invalidDataProvider()
{
return array(
array(true),
array(false),
array(new \stdClass),
array(array()),
);
}
}

View File

@ -43,7 +43,7 @@ class UrlTypeTest extends LocalizedTestCase
$form->bind('');
$this->assertSame('', $form->getData());
$this->assertNull($form->getData());
$this->assertSame('', $form->getViewData());
}