Passed
Push — main ( f4e8a4...c84275 )
by Gabriel
02:34
created

AccessorsTraitTest::test_compileMutators()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 4
Code Lines 2

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 1
eloc 2
c 1
b 0
f 0
nc 1
nop 0
dl 0
loc 4
rs 10
1
<?php
2
3
namespace ByTIC\DataObjects\Tests\Behaviors\Accessors;
4
5
use ByTIC\DataObjects\Tests\AbstractTest;
6
use ByTIC\DataObjects\Tests\Fixtures\Dto\ObjectWithGetSet;
7
use ByTIC\DataObjects\Tests\Fixtures\Models\Books\Book;
8
use ByTIC\DataObjects\Utility\Constants;
9
10
/**
11
 * Class AccessorsTraitTest
12
 * @package ByTIC\DataObjects\Tests\Behaviors\ArrayAccess
13
 */
14
class AccessorsTraitTest extends AbstractTest
15
{
16
    public function test_compileMutators_only_once()
17
    {
18
        $book1 = new Book();
19
        $book1->name = 'Test';
0 ignored issues
show
Bug Best Practice introduced by
The property $name is declared protected in ByTIC\DataObjects\Tests\Fixtures\Models\Books\Book. Since you implement __set, consider adding a @property or @property-write.
Loading history...
20
21
        self::assertSame('Test', $book1->name);
22
        self::assertSame('Test', $book1->get('name'));
23
        self::assertSame(1, $book1::$compiled);
24
    }
25
26
    public function test_getter_internal_property()
27
    {
28
        $book1 = new Book(['name' => 'test']);
29
30
        self::assertSame('Test', $book1->name);
0 ignored issues
show
Bug Best Practice introduced by
The property $name is declared protected in ByTIC\DataObjects\Tests\Fixtures\Models\Books\Book. Since you implement __get, consider adding a @property or @property-read.
Loading history...
31
        self::assertSame('Test', $book1->getName());
32
        self::assertSame('Test', $book1->getAttribute('name'));
33
    }
34
35
    public function test_getter_magic_property()
36
    {
37
        $object = new ObjectWithGetSet(['name' => 'test']);
38
39
        self::assertSame('test', $object->name);
40
        self::assertSame('test', $object->getName());
41
        self::assertSame('test', $object->get('name'));
42
    }
43
44
    public function test_callAccessors_setter()
45
    {
46
        $book1 = new Book();
47
        $book1->name = 'test';
0 ignored issues
show
Bug Best Practice introduced by
The property $name is declared protected in ByTIC\DataObjects\Tests\Fixtures\Models\Books\Book. Since you implement __set, consider adding a @property or @property-write.
Loading history...
48
49
        self::assertSame('Test', $book1->name);
50
    }
51
52
    public function test_compileMutators()
53
    {
54
        $book1 = new Book();
55
        self::assertSame(Constants::NO_ACCESSORS_FOUND, $book1->getMutated('attribute'));
56
    }
57
58
    public function test_setter_magic_property()
59
    {
60
        $object = new ObjectWithGetSet();
61
        self::assertSame(null, $object->name);
62
63
        $object = new ObjectWithGetSet(['name' => 'test']);
64
65
        self::assertSame('test', $object->name);
66
67
        $object->name = 'test1';
68
        self::assertSame('test1', $object->name);
69
        self::assertSame('test1', $object->getName());
70
        self::assertSame('test1', $object->get('name'));
71
    }
72
}
73