Passed
Pull Request — master (#6760)
by Marco
11:57
created

testInverseSideOneToOneLoadedAfterDqlQuery()   B

Complexity

Conditions 1
Paths 1

Size

Total Lines 39
Code Lines 28

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
dl 0
loc 39
c 0
b 0
f 0
rs 8.8571
cc 1
eloc 28
nc 1
nop 0
1
<?php
2
3
declare(strict_types=1);
4
5
namespace Doctrine\Tests\ORM\Functional;
6
7
use Doctrine\ORM\Tools\ToolsException;
8
use Doctrine\Tests\Models\OneToOneInverseSideLoad\InverseSide;
9
use Doctrine\Tests\Models\OneToOneInverseSideLoad\OwningSide;
10
use Doctrine\Tests\OrmFunctionalTestCase;
11
12
class OneToOneInverseSideLoadAfterDqlQueryTest extends OrmFunctionalTestCase
13
{
14 View Code Duplication
    protected function setUp()
15
    {
16
        parent::setUp();
17
18
        try {
19
            $this->_schemaTool->createSchema([
20
                $this->_em->getClassMetadata(OwningSide::class),
21
                $this->_em->getClassMetadata(InverseSide::class),
22
            ]);
23
        } catch(ToolsException $e) {
24
            // ignored
25
        }
26
    }
27
28
    /**
29
     * @group #6759
30
     */
31
    public function testInverseSideOneToOneLoadedAfterDqlQuery(): void
32
    {
33
        $owner   = new OwningSide();
34
        $inverse = new InverseSide();
35
36
        $owner->id       = 'owner';
37
        $inverse->id     = 'inverse';
38
        $owner->inverse  = $inverse;
39
        $inverse->owning = $owner;
40
41
        $this->_em->persist($owner);
42
        $this->_em->persist($inverse);
43
        $this->_em->flush();
44
        $this->_em->clear();
45
46
        /* @var $fetchedInverse InverseSide */
47
        $fetchedInverse = $this
48
            ->_em
49
            ->createQueryBuilder()
50
            ->select('inverse')
51
            ->from(InverseSide::class, 'inverse')
52
            ->andWhere('inverse.id = :id')
53
            ->setParameter('id', 'inverse')
54
            ->getQuery()
55
            ->getSingleResult();
56
57
        self::assertInstanceOf(InverseSide::class, $fetchedInverse);
58
        self::assertInstanceOf(OwningSide::class, $fetchedInverse->owning);
59
60
        $this->assertSQLEquals(
61
            'select o0_.id as id_0 from one_to_one_inverse_side_load_inverse o0_ where o0_.id = ?',
62
            $this->_sqlLoggerStack->queries[$this->_sqlLoggerStack->currentQuery - 1]['sql']
63
        );
64
65
        $this->assertSQLEquals(
66
            'select t0.id as id_1, t0.inverse as inverse_2 from one_to_one_inverse_side_load_owning t0 WHERE t0.inverse = ?',
67
            $this->_sqlLoggerStack->queries[$this->_sqlLoggerStack->currentQuery]['sql']
68
        );
69
    }
70
}
71