Commit 436179f0 authored by Marco Pivetta's avatar Marco Pivetta Committed by GitHub

Merge pull request #2785 from Grzesie2k/fix/composite-expression-add

Fix `CompositeExpression#add()` optimization, which was leading to bbroken `CompositeExpression` instances
parents 118d7f9a 8eb2c1f1
......@@ -91,10 +91,16 @@ class CompositeExpression implements \Countable
*/
public function add($part)
{
if ( ! empty($part) || ($part instanceof self && $part->count() > 0)) {
$this->parts[] = $part;
if (empty($part)) {
return $this;
}
if ($part instanceof self && 0 === count($part)) {
return $this;
}
$this->parts[] = $part;
return $this;
}
......
......@@ -20,6 +20,29 @@ class CompositeExpressionTest extends \Doctrine\Tests\DbalTestCase
$this->assertEquals(2, count($expr));
}
public function testAdd()
{
$expr = new CompositeExpression(CompositeExpression::TYPE_OR, array('u.group_id = 1'));
$this->assertCount(1, $expr);
$expr->add(new CompositeExpression(CompositeExpression::TYPE_AND, array()));
$this->assertCount(1, $expr);
$expr->add(new CompositeExpression(CompositeExpression::TYPE_OR, array('u.user_id = 1')));
$this->assertCount(2, $expr);
$expr->add(null);
$this->assertCount(2, $expr);
$expr->add('u.user_id = 1');
$this->assertCount(3, $expr);
}
/**
* @dataProvider provideDataForConvertToString
*/
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment