110 lines
3.9 KiB
PHP
110 lines
3.9 KiB
PHP
<?php
|
|
|
|
namespace Doctrine\Tests\ORM\Functional\Ticket;
|
|
|
|
use Doctrine\Common\Collections\ArrayCollection;
|
|
use Doctrine\Tests\Models\CMS\CmsUser;
|
|
use Doctrine\Tests\Models\CMS\CmsGroup;
|
|
|
|
require_once __DIR__ . '/../../../TestInit.php';
|
|
|
|
class DDC809Test extends \Doctrine\Tests\OrmFunctionalTestCase
|
|
{
|
|
public function setUp()
|
|
{
|
|
parent::setUp();
|
|
$this->_schemaTool->createSchema(array(
|
|
$this->_em->getClassMetadata(__NAMESPACE__ . '\DDC809Variant'),
|
|
$this->_em->getClassMetadata(__NAMESPACE__ . '\DDC809SpecificationValue')
|
|
));
|
|
|
|
$conn = $this->_em->getConnection();
|
|
$conn->insert('specification_value_test', array('specification_value_id' => 94589));
|
|
$conn->insert('specification_value_test', array('specification_value_id' => 94593));
|
|
$conn->insert('specification_value_test', array('specification_value_id' => 94606));
|
|
$conn->insert('specification_value_test', array('specification_value_id' => 94607));
|
|
$conn->insert('specification_value_test', array('specification_value_id' => 94609));
|
|
$conn->insert('specification_value_test', array('specification_value_id' => 94711));
|
|
|
|
$conn->insert('variant_test', array('variant_id' => 545208));
|
|
$conn->insert('variant_test', array('variant_id' => 545209));
|
|
|
|
$conn->insert('var_spec_value_test', array('variant_id' => 545208, 'specification_value_id' => 94606));
|
|
$conn->insert('var_spec_value_test', array('variant_id' => 545208, 'specification_value_id' => 94607));
|
|
$conn->insert('var_spec_value_test', array('variant_id' => 545208, 'specification_value_id' => 94609));
|
|
$conn->insert('var_spec_value_test', array('variant_id' => 545208, 'specification_value_id' => 94711));
|
|
|
|
$conn->insert('var_spec_value_test', array('variant_id' => 545209, 'specification_value_id' => 94589));
|
|
$conn->insert('var_spec_value_test', array('variant_id' => 545209, 'specification_value_id' => 94593));
|
|
$conn->insert('var_spec_value_test', array('variant_id' => 545209, 'specification_value_id' => 94606));
|
|
$conn->insert('var_spec_value_test', array('variant_id' => 545209, 'specification_value_id' => 94607));
|
|
}
|
|
|
|
/**
|
|
* @group DDC-809
|
|
*/
|
|
public function testIssue()
|
|
{
|
|
$result = $this->_em->createQueryBuilder()
|
|
->select('Variant, SpecificationValue')
|
|
->from('Doctrine\Tests\ORM\Functional\Ticket\DDC809Variant', 'Variant')
|
|
->leftJoin('Variant.SpecificationValues', 'SpecificationValue')
|
|
->getQuery()
|
|
->getResult();
|
|
|
|
$this->assertEquals(4, count($result[0]->getSpecificationValues()), "Works in test-setup.");
|
|
$this->assertEquals(4, count($result[1]->getSpecificationValues()), "Only returns 2 in the case of the hydration bug.");
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @Table(name="variant_test")
|
|
* @Entity
|
|
*/
|
|
class DDC809Variant
|
|
{
|
|
/**
|
|
* @Column(name="variant_id", type="integer")
|
|
* @Id
|
|
*/
|
|
protected $variantId;
|
|
|
|
/**
|
|
* @ManyToMany(targetEntity="DDC809SpecificationValue", inversedBy="Variants")
|
|
* @JoinTable(name="var_spec_value_test",
|
|
* joinColumns={
|
|
* @JoinColumn(name="variant_id", referencedColumnName="variant_id")
|
|
* },
|
|
* inverseJoinColumns={
|
|
* @JoinColumn(name="specification_value_id", referencedColumnName="specification_value_id")
|
|
* }
|
|
* )
|
|
*/
|
|
protected $SpecificationValues;
|
|
|
|
public function getSpecificationValues()
|
|
{
|
|
return $this->SpecificationValues;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @Table(name="specification_value_test")
|
|
* @Entity
|
|
*/
|
|
class DDC809SpecificationValue
|
|
{
|
|
/**
|
|
* @Column(name="specification_value_id", type="integer")
|
|
* @Id
|
|
*/
|
|
protected $specificationValueId;
|
|
|
|
/**
|
|
* @var Variant
|
|
*
|
|
* @ManyToMany(targetEntity="DDC809Variant", mappedBy="SpecificationValues")
|
|
*/
|
|
protected $Variants;
|
|
}
|