Failed Conditions
Pull Request — master (#6392)
by Alessandro
21:55 queued 10:50
created

setUp()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 11
Code Lines 7

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
c 0
b 0
f 0
dl 0
loc 11
rs 9.4285
cc 1
eloc 7
nc 1
nop 0
1
<?php
2
3
namespace Doctrine\Tests\ORM\Functional\Ticket;
4
5
use Doctrine\Tests\OrmFunctionalTestCase;
6
7
class Ticket4646MultipleInstanceOfWithMultipleParametersTest extends OrmFunctionalTestCase
8
{
9
    protected function setUp(): void
10
    {
11
        parent::setUp();
12
13
        $this->_schemaTool->createSchema([
14
            $this->_em->getClassMetadata(PersonTicket4646Multiple::class),
15
            $this->_em->getClassMetadata(EmployeeTicket4646Multiple::class),
16
            $this->_em->getClassMetadata(ManagerTicket4646Multiple::class),
17
            $this->_em->getClassMetadata(InternTicket4646Multiple::class),
18
        ]);
19
    }
20
21
    public function testInstanceOf(): void
22
    {
23
        $this->_em->persist(new PersonTicket4646Multiple());
24
        $this->_em->persist(new EmployeeTicket4646Multiple());
25
        $this->_em->persist(new ManagerTicket4646Multiple());
26
        $this->_em->persist(new InternTicket4646Multiple());
27
        $this->_em->flush();
28
29
        $dql = 'SELECT p FROM Doctrine\Tests\ORM\Functional\Ticket\PersonTicket4646Multiple p
30
                WHERE p INSTANCE OF (Doctrine\Tests\ORM\Functional\Ticket\EmployeeTicket4646Multiple, Doctrine\Tests\ORM\Functional\Ticket\InternTicket4646Multiple)';
31
        $query = $this->_em->createQuery($dql);
32
        $result = $query->getResult();
33
34
        self::assertCount(2, $result);
35
        self::assertContainsOnlyInstancesOf(PersonTicket4646Multiple::class, $result);
36
    }
37
}
38
39
/**
40
 * @Entity()
41
 * @Table(name="instance_of_test_multiple_person")
42
 * @InheritanceType(value="JOINED")
43
 * @DiscriminatorColumn(name="kind", type="string")
44
 * @DiscriminatorMap(value={
45
 *     "person": "Doctrine\Tests\ORM\Functional\Ticket\PersonTicket4646Multiple",
46
 *     "employee": "Doctrine\Tests\ORM\Functional\Ticket\EmployeeTicket4646Multiple",
47
 *     "manager": "Doctrine\Tests\ORM\Functional\Ticket\ManagerTicket4646Multiple",
48
 *     "intern": "Doctrine\Tests\ORM\Functional\Ticket\InternTicket4646Multiple"
49
 * })
50
 */
51
class PersonTicket4646Multiple
52
{
53
    /**
54
     * @Id()
55
     * @GeneratedValue()
56
     * @Column(type="integer")
57
     */
58
    private $id;
59
60
    public function getId()
61
    {
62
        return $this->id;
63
    }
64
}
65
66
/**
67
 * @Entity()
68
 * @Table(name="instance_of_test_multiple_employee")
69
 */
70
class EmployeeTicket4646Multiple extends PersonTicket4646Multiple
71
{
72
}
73
74
/**
75
 * @Entity()
76
 * @Table(name="instance_of_test_multiple_manager")
77
 */
78
class ManagerTicket4646Multiple extends PersonTicket4646Multiple
79
{
80
}
81
82
/**
83
 * @Entity()
84
 * @Table(name="instance_of_test_multiple_intern")
85
 */
86
class InternTicket4646Multiple extends PersonTicket4646Multiple
87
{
88
}
89