diff --git a/lib/Doctrine/Common/Collections/Criteria.php b/lib/Doctrine/Common/Collections/Criteria.php index 748a08474..109285ed3 100644 --- a/lib/Doctrine/Common/Collections/Criteria.php +++ b/lib/Doctrine/Common/Collections/Criteria.php @@ -75,6 +75,26 @@ public static function create() return new static(); } + /** + * Creates an instance with same behaviour as criteria parameters passed on ORM find methods. + * + * @param mixed[] $findCriteria Array of different keys and values. Gets the same format as argument expected on + * Doctrine\Common\Persistence\ObjectRepository::findBy and + * Doctrine\Common\Persistence\ObjectRepository::findOneBy methods. + * + * @return Criteria + */ + public static function fromFindCriteria(array $findCriteria) + { + $criteria = static::create(); + + foreach ($findCriteria as $key => $value) { + $criteria->andWhere(static::expr()->eq($key, $value)); + } + + return $criteria; + } + /** * Returns the expression builder. * diff --git a/tests/Doctrine/Tests/Common/Collections/CriteriaTest.php b/tests/Doctrine/Tests/Common/Collections/CriteriaTest.php index 548dbfecc..1a02b4b21 100644 --- a/tests/Doctrine/Tests/Common/Collections/CriteriaTest.php +++ b/tests/Doctrine/Tests/Common/Collections/CriteriaTest.php @@ -16,6 +16,18 @@ public function testCreate() : void $this->assertInstanceOf(Criteria::class, $criteria); } + public function testFromFindCriteria() + { + $criteria = Criteria::fromFindCriteria(['name' => 'test', 'foo' => 42]); + + /** @var CompositeExpression $where */ + $where = $criteria->getWhereExpression(); + $this->assertInstanceOf(CompositeExpression::class, $where); + + $this->assertSame(CompositeExpression::TYPE_AND, $where->getType()); + $this->assertCount(2, $where->getExpressionList()); + } + public function testConstructor() : void { $expr = new Comparison("field", "=", "value");