ModelFilterTest.php 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156
  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\ModelFilter;
  12. use Doctrine\ORM\Mapping\ClassMetadataInfo;
  13. use Sonata\AdminBundle\Form\Type\EqualType;
  14. use Sonata\DoctrineORMAdminBundle\Datagrid\ProxyQuery;
  15. class ModelFilterTest extends \PHPUnit_Framework_TestCase
  16. {
  17. /**
  18. * @param array $options
  19. * @return \Sonata\AdminBundle\Admin\FieldDescriptionInterface
  20. */
  21. public function getFieldDescription(array $options)
  22. {
  23. $fieldDescription = $this->getMock('Sonata\AdminBundle\Admin\FieldDescriptionInterface');
  24. $fieldDescription->expects($this->once())->method('getOptions')->will($this->returnValue($options));
  25. $fieldDescription->expects($this->once())->method('getName')->will($this->returnValue('field_name'));
  26. return $fieldDescription;
  27. }
  28. public function testFilterEmpty()
  29. {
  30. $filter = new ModelFilter;
  31. $filter->initialize('field_name', array('field_options' => array('class' => 'FooBar')));
  32. $builder = new ProxyQuery(new QueryBuilder);
  33. $filter->filter($builder, 'alias', 'field', null);
  34. $filter->filter($builder, 'alias', 'field', array());
  35. $this->assertEquals(array(), $builder->query);
  36. $this->assertEquals(false, $filter->isActive());
  37. }
  38. public function testFilterArray()
  39. {
  40. $filter = new ModelFilter;
  41. $filter->initialize('field_name', array('field_options' => array('class' => 'FooBar')));
  42. $builder = new ProxyQuery(new QueryBuilder);
  43. $filter->filter($builder, 'alias', 'field', array(
  44. 'type' => EqualType::TYPE_IS_EQUAL,
  45. 'value' => array('1', '2')
  46. ));
  47. // the alias is now computer by the entityJoin method
  48. $this->assertEquals(array('in_alias', 'in_alias IN :field_name_0'), $builder->query);
  49. $this->assertEquals(true, $filter->isActive());
  50. }
  51. public function testFilterScalar()
  52. {
  53. $filter = new ModelFilter;
  54. $filter->initialize('field_name', array('field_options' => array('class' => 'FooBar')));
  55. $builder = new ProxyQuery(new QueryBuilder);
  56. $filter->filter($builder, 'alias', 'field', array('type' => EqualType::TYPE_IS_EQUAL, 'value' => 2));
  57. $this->assertEquals(array('alias = :field_name_0'), $builder->query);
  58. $this->assertEquals(array('field_name_0' => 2), $builder->parameters);
  59. $this->assertEquals(true, $filter->isActive());
  60. }
  61. /**
  62. * @expectedException RuntimeException
  63. */
  64. public function testAssociationWithInvalidMapping()
  65. {
  66. $filter = new ModelFilter;
  67. $filter->initialize('field_name', array('mapping_type' => 'foo'));
  68. $builder = new ProxyQuery(new QueryBuilder);
  69. $filter->apply($builder, 'asd');
  70. }
  71. /**
  72. * @expectedException RuntimeException
  73. */
  74. public function testAssociationWithValidMappingAndEmptyFieldName()
  75. {
  76. $filter = new ModelFilter;
  77. $filter->initialize('field_name', array('mapping_type' => ClassMetadataInfo::ONE_TO_ONE));
  78. $builder = new ProxyQuery(new QueryBuilder);
  79. $filter->apply($builder, 'asd');
  80. $this->assertEquals(true, $filter->isActive());
  81. }
  82. public function testAssociationWithValidMapping()
  83. {
  84. $filter = new ModelFilter;
  85. $filter->initialize('field_name', array(
  86. 'mapping_type' => ClassMetadataInfo::ONE_TO_ONE,
  87. 'field_name' => 'field_name',
  88. 'association_mapping' => array(
  89. 'fieldName' => 'association_mapping'
  90. )
  91. ));
  92. $builder = new ProxyQuery(new QueryBuilder);
  93. $filter->apply($builder, array('type' => EqualType::TYPE_IS_EQUAL, 'value' => 'asd'));
  94. $this->assertEquals(array('o.association_mapping', 's_association_mapping = :field_name_0'), $builder->query);
  95. $this->assertEquals(true, $filter->isActive());
  96. }
  97. public function testAssociationWithValidParentAssociationMappings()
  98. {
  99. $filter = new ModelFilter;
  100. $filter->initialize('field_name', array(
  101. 'mapping_type' => ClassMetadataInfo::ONE_TO_ONE,
  102. 'field_name' => 'field_name',
  103. 'parent_association_mappings' => array(
  104. array(
  105. 'fieldName' => 'association_mapping'
  106. ),
  107. array(
  108. 'fieldName' => 'sub_association_mapping'
  109. ),
  110. ),
  111. 'association_mapping' => array(
  112. 'fieldName' => 'sub_sub_association_mapping'
  113. )
  114. ));
  115. $builder = new ProxyQuery(new QueryBuilder);
  116. $filter->apply($builder, array('type' => EqualType::TYPE_IS_EQUAL, 'value' => 'asd'));
  117. $this->assertEquals(array(
  118. 'o.association_mapping',
  119. 's_association_mapping.sub_association_mapping',
  120. 's_association_mapping_sub_association_mapping.sub_sub_association_mapping',
  121. 's_association_mapping_sub_association_mapping_sub_sub_association_mapping = :field_name_0'
  122. ), $builder->query);
  123. $this->assertEquals(true, $filter->isActive());
  124. }
  125. }