GitHub Access Token became invalid

It seems like the GitHub access token used for retrieving details about this repository from GitHub became invalid. This might prevent certain types of inspections from being run (in particular, everything related to pull requests).
Please ask an admin of your repository to re-new the access token on this website.
Passed
Pull Request — master (#54)
by joseph
17:02
created

EntitySaverFunctionalTest::getEntitySaver()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
dl 0
loc 3
rs 10
c 0
b 0
f 0
cc 1
eloc 1
nc 1
nop 0
1
<?php declare(strict_types=1);
2
3
namespace EdmondsCommerce\DoctrineStaticMeta\Entity\Savers;
4
5
use EdmondsCommerce\DoctrineStaticMeta\AbstractFunctionalTest;
6
use EdmondsCommerce\DoctrineStaticMeta\AbstractIntegrationTest;
7
use EdmondsCommerce\DoctrineStaticMeta\MappingHelper;
8
9
class EntitySaverFunctionalTest extends AbstractFunctionalTest
10
{
11
    public const WORK_DIR = AbstractIntegrationTest::VAR_PATH.'/'.self::TEST_TYPE.'/EntitySaverFunctionalTest';
12
13
    private const TEST_ENTITIES = [
14
        self::TEST_PROJECT_ROOT_NAMESPACE.'\\Entities\\TestEntityOne',
15
        self::TEST_PROJECT_ROOT_NAMESPACE.'\\Entities\\Deeply\\Nested\\TestEntityTwo',
16
    ];
17
18
    private const TEST_FIELDS = [
19
        self::TEST_PROJECT_ROOT_NAMESPACE.'\\Entity\\Fields\\Traits\\NameFieldTrait',
20
        self::TEST_PROJECT_ROOT_NAMESPACE.'\\Entity\\Fields\\Traits\\FooFieldTrait',
21
    ];
22
23
    public function setup()
24
    {
25
        parent::setup();
26
        $fieldGenerator = $this->getFieldGenerator();
27
        foreach (self::TEST_FIELDS as $fieldFqn) {
28
            $fieldGenerator->generateField($fieldFqn, MappingHelper::TYPE_STRING);
29
        }
30
        $entityGenerator = $this->getEntityGenerator();
31
        foreach (self::TEST_ENTITIES as $entityFqn) {
32
            $entityGenerator->generateEntity($entityFqn);
33
            foreach (self::TEST_FIELDS as $fieldFqn) {
34
                $fieldGenerator->setEntityHasField($entityFqn, $fieldFqn);
35
            }
36
        }
37
        $this->setupCopiedWorkDirAndCreateDatabase();
38
    }
39
40
41
42
    protected function findAllEntity(string $entityFqn)
43
    {
44
        $entityManager = $this->getEntityManager();
45
46
        return $entityManager->getRepository($entityFqn)->findAll();
47
    }
48
49
50
    public function testItCanSaveAndRemoveASingleEntity()
51
    {
52
        $entityFqn = $this->getCopiedFqn(current(self::TEST_ENTITIES));
53
        $entity    = new $entityFqn();
54
        $entity->setName('blah');
55
        $entity->setfoo('bar');
56
        $saver = $this->getEntitySaver();
57
        $saver->save($entity);
58
        $loaded = $this->findAllEntity($entityFqn)[0];
59
        $this->assertSame($entity->getName(), $loaded->getName());
60
        $this->assertSame($entity->getFoo(), $loaded->getFoo());
61
        $saver->remove($loaded);
62
        $this->assertSame([], $this->findAllEntity($entityFqn));
63
    }
64
65
    public function testItCanSaveAndRemoveMultipleEntities()
66
    {
67
        $entities = [];
68
        foreach (self::TEST_ENTITIES as $entityFqn) {
69
            $entityFqn = $this->getCopiedFqn($entityFqn);
70
            foreach (range(0, 9) as $num) {
71
                $entities[$entityFqn.$num] = new $entityFqn();
72
                $entities[$entityFqn.$num]->setName('blah');
73
                $entities[$entityFqn.$num]->setfoo('bar');
74
            }
75
        }
76
        $saver = $this->getEntitySaver();
77
        $saver->saveAll($entities);
78
        foreach (self::TEST_ENTITIES as $entityFqn) {
79
            $entityFqn = $this->getCopiedFqn($entityFqn);
80
            $loaded    = $this->findAllEntity($entityFqn);
81
            $this->assertCount(10, $loaded);
82
            foreach (range(0, 9) as $num) {
83
                $this->assertSame($entities[$entityFqn.$num]->getName(), $loaded[$num]->getName());
84
                $this->assertSame($entities[$entityFqn.$num]->getFoo(), $loaded[$num]->getFoo());
85
            }
86
        }
87
88
        $saver->removeAll($entities);
89
        foreach (self::TEST_ENTITIES as $entityFqn) {
90
            $entityFqn = $this->getCopiedFqn($entityFqn);
91
            $this->assertSame([], $this->findAllEntity($entityFqn));
92
        }
93
    }
94
}
95