-
Notifications
You must be signed in to change notification settings - Fork 102
/
Copy pathqueryBuilderExtraMethod.php
49 lines (36 loc) · 1.15 KB
/
queryBuilderExtraMethod.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
<?php declare(strict_types = 1);
namespace PHPStan\DoctrineIntegration\ORM\QueryBuilder;
use Doctrine\ORM\EntityManager;
use Doctrine\ORM\Query;
use Doctrine\ORM\QueryBuilder;
use PHPStan\DoctrineIntegration\ORM\CustomRepositoryUsage\MyEntity;
class Foo
{
/**
* @var EntityManager
*/
private $entityManager;
public function __construct(EntityManager $entityManager)
{
$this->entityManager = $entityManager;
}
public function doFoo(): Query
{
$queryBuilder = $this->entityManager->createQueryBuilder()
->select('e')
->from(MyEntity::class, 'e');
// @todo it works when the extra where is here
//$queryBuilder->andWhere('e.id != :excludedId');
// but it does not work when the where is added in extra method
$this->addExtraCondition($queryBuilder);
$query = $queryBuilder->getQuery();
$expectedDql = 'SELECT e FROM PHPStan\DoctrineIntegration\ORM\CustomRepositoryUsage\MyEntity e WHERE e.id != :excludedId';
$query->getDQL() === $expectedDql;
$queryBuilder->getDQL() === $expectedDql;
return $query;
}
private function addExtraCondition(QueryBuilder $queryBuilder): void
{
$queryBuilder->andWhere('e.id != :excludedId');
}
}