StringFilterTest.php 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  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. public function testEqualsWithValidParentAssociationMappings()
  65. {
  66. $filter = new StringFilter;
  67. $filter->initialize('field_name', array(
  68. 'format' => '%s',
  69. 'field_name' => 'field_name',
  70. 'parent_association_mappings' => array(
  71. array(
  72. 'fieldName' => 'association_mapping'
  73. ),
  74. array(
  75. 'fieldName' => 'sub_association_mapping'
  76. ),
  77. array(
  78. 'fieldName' => 'sub_sub_association_mapping'
  79. ),
  80. )
  81. ));
  82. $builder = new ProxyQuery(new QueryBuilder);
  83. $this->assertEquals(array(), $builder->query);
  84. $filter->apply($builder, array('type' => ChoiceType::TYPE_EQUAL, 'value' => 'asd'));
  85. $this->assertEquals(array(
  86. 'o.association_mapping',
  87. 's_association_mapping.sub_association_mapping',
  88. 's_association_mapping_sub_association_mapping.sub_sub_association_mapping',
  89. 's_association_mapping_sub_association_mapping_sub_sub_association_mapping.field_name = :field_name_0'
  90. ), $builder->query);
  91. $this->assertEquals(array('field_name_0' => 'asd'), $builder->parameters);
  92. $this->assertEquals(true, $filter->isActive());
  93. }
  94. }