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

OneToOneInverseSideLoadAfterDqlQueryTest   A

Complexity

Total Complexity 3

Size/Duplication

Total Lines 59
Duplicated Lines 22.03 %

Coupling/Cohesion

Components 1
Dependencies 8

Importance

Changes 0
Metric Value
wmc 3
lcom 1
cbo 8
dl 13
loc 59
c 0
b 0
f 0
rs 10

2 Methods

Rating   Name   Duplication   Size   Complexity  
A setUp() 13 13 2
B testInverseSideOneToOneLoadedAfterDqlQuery() 0 39 1

How to fix   Duplicated Code   

Duplicated Code

Duplicate code is one of the most pungent code smells. A rule that is often used is to re-structure code once it is duplicated in three or more places.

Common duplication problems, and corresponding solutions are:

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