StringFilterTest.php 3.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. <?php
  2. /*
  3. * This file is part of the Sonata package.
  4. *
  5. * (c) Thomas Rabaix <thomas.rabaix@sonata-project.org>
  6. *
  7. * For the full copyright and license information, please view the LICENSE
  8. * file that was distributed with this source code.
  9. */
  10. namespace Sonata\DoctrineORMAdminBundle\Tests\Filter;
  11. use Sonata\DoctrineORMAdminBundle\Filter\StringFilter;
  12. use Sonata\AdminBundle\Form\Type\Filter\ChoiceType;
  13. use Sonata\DoctrineORMAdminBundle\Datagrid\ProxyQuery;
  14. class StringFilterTest extends \PHPUnit_Framework_TestCase
  15. {
  16. public function testEmpty()
  17. {
  18. $filter = new StringFilter;
  19. $filter->initialize('field_name', array('field_options' => array('class' => 'FooBar')));
  20. $builder = new ProxyQuery(new QueryBuilder);
  21. $filter->filter($builder, 'alias', 'field', null);
  22. $filter->filter($builder, 'alias', 'field', '');
  23. $this->assertEquals(array(), $builder->query);
  24. $this->assertEquals(false, $filter->isActive());
  25. }
  26. public function testContains()
  27. {
  28. $filter = new StringFilter;
  29. $filter->initialize('field_name', array('format' => '%s'));
  30. $builder = new ProxyQuery(new QueryBuilder);
  31. $this->assertEquals(array(), $builder->query);
  32. $filter->filter($builder, 'alias', 'field', array('value' => 'asd', 'type' => ChoiceType::TYPE_CONTAINS));
  33. $this->assertEquals(array('alias.field LIKE :field_name_0'), $builder->query);
  34. $this->assertEquals(array('field_name_0' => 'asd'), $builder->parameters);
  35. $builder = new ProxyQuery(new QueryBuilder);
  36. $this->assertEquals(array(), $builder->query);
  37. $filter->filter($builder, 'alias', 'field', array('value' => 'asd', 'type' => null));
  38. $this->assertEquals(array('alias.field LIKE :field_name_0'), $builder->query);
  39. $this->assertEquals(array('field_name_0' => 'asd'), $builder->parameters);
  40. $this->assertEquals(true, $filter->isActive());
  41. }
  42. public function testNotContains()
  43. {
  44. $filter = new StringFilter;
  45. $filter->initialize('field_name', array('format' => '%s'));
  46. $builder = new ProxyQuery(new QueryBuilder);
  47. $this->assertEquals(array(), $builder->query);
  48. $filter->filter($builder, 'alias', 'field', array('value' => 'asd', 'type' => ChoiceType::TYPE_NOT_CONTAINS));
  49. $this->assertEquals(array('alias.field NOT LIKE :field_name_0'), $builder->query);
  50. $this->assertEquals(array('field_name_0' => 'asd'), $builder->parameters);
  51. $this->assertEquals(true, $filter->isActive());
  52. }
  53. public function testEquals()
  54. {
  55. $filter = new StringFilter;
  56. $filter->initialize('field_name', array('format' => '%s'));
  57. $builder = new ProxyQuery(new QueryBuilder);
  58. $this->assertEquals(array(), $builder->query);
  59. $filter->filter($builder, 'alias', 'field', array('value' => 'asd', 'type' => ChoiceType::TYPE_EQUAL));
  60. $this->assertEquals(array('alias.field = :field_name_0'), $builder->query);
  61. $this->assertEquals(array('field_name_0' => 'asd'), $builder->parameters);
  62. $this->assertEquals(true, $filter->isActive());
  63. }
  64. }