Skip to content

Commit

Permalink
AbstractDateFilter::filterRange() applies a WHERE condition separat…
Browse files Browse the repository at this point in the history
…ely for the `start` and `end` values in the case of DateRangeOperatorType::TYPE_NOT_BETWEEN.

This fixes a bug that arises when one of this range borders is not set.
Fixes: #1766
  • Loading branch information
tonyaxo authored and VincentLanglet committed Nov 19, 2023
1 parent b78bf53 commit ba7c36b
Show file tree
Hide file tree
Showing 2 changed files with 52 additions and 1 deletion.
8 changes: 7 additions & 1 deletion src/Filter/AbstractDateFilter.php
Original file line number Diff line number Diff line change
Expand Up @@ -160,7 +160,13 @@ private function filterRange(ProxyQueryInterface $query, string $alias, string $
$endDateParameterName = $this->getNewParameterName($query);

if (DateRangeOperatorType::TYPE_NOT_BETWEEN === $type) {
$this->applyWhere($query, sprintf('%s.%s < :%s OR %s.%s > :%s', $alias, $field, $startDateParameterName, $alias, $field, $endDateParameterName));
if (null !== $value['start']) {
$this->applyWhere($query, sprintf('%s.%s %s :%s', $alias, $field, '<', $startDateParameterName));
}

if (null !== $value['end']) {
$this->applyWhere($query, sprintf('%s.%s %s :%s', $alias, $field, '>', $endDateParameterName));
}
} else {
if (null !== $value['start']) {
$this->applyWhere($query, sprintf('%s.%s %s :%s', $alias, $field, '>=', $startDateParameterName));
Expand Down
45 changes: 45 additions & 0 deletions tests/Filter/DateTimeRangeFilterTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@
namespace Sonata\DoctrineORMAdminBundle\Tests\Filter;

use Sonata\AdminBundle\Filter\Model\FilterData;
use Sonata\AdminBundle\Form\Type\Operator\DateRangeOperatorType;
use Sonata\DoctrineORMAdminBundle\Datagrid\ProxyQuery;
use Sonata\DoctrineORMAdminBundle\Filter\DateTimeRangeFilter;
use Sonata\Form\Type\DateTimeRangeType;
Expand Down Expand Up @@ -43,4 +44,48 @@ public function testGetType(): void

static::assertSame(DateTimeRangeType::class, $filter->getFieldType());
}

public function testFilterNotBetweenStartDate(): void
{
$filter = new DateTimeRangeFilter();
$filter->initialize('field_name', ['field_options' => ['class' => 'FooBar']]);

$proxyQuery = new ProxyQuery($this->createQueryBuilderStub());

$startDateTime = new \DateTime('2023-10-03T12:00:01');

$filter->filter($proxyQuery, 'alias', 'field', FilterData::fromArray([
'type' => DateRangeOperatorType::TYPE_NOT_BETWEEN,
'value' => [
'start' => $startDateTime,
'end' => null,
],
]));

self::assertSameQuery(['WHERE alias.field < :field_name_0'], $proxyQuery);
self::assertSameQueryParameters(['field_name_0' => $startDateTime], $proxyQuery);
static::assertTrue($filter->isActive());
}

public function testFilterNotBetweenEndDate(): void
{
$filter = new DateTimeRangeFilter();
$filter->initialize('field_name', ['field_options' => ['class' => 'FooBar']]);

$proxyQuery = new ProxyQuery($this->createQueryBuilderStub());

$endDateTime = new \DateTime('2023-10-03T12:00:01');

$filter->filter($proxyQuery, 'alias', 'field', FilterData::fromArray([
'type' => DateRangeOperatorType::TYPE_NOT_BETWEEN,
'value' => [
'start' => null,
'end' => $endDateTime,
],
]));

self::assertSameQuery(['WHERE alias.field > :field_name_1'], $proxyQuery);
self::assertSameQueryParameters(['field_name_1' => $endDateTime], $proxyQuery);
static::assertTrue($filter->isActive());
}
}

0 comments on commit ba7c36b

Please sign in to comment.