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.
Completed
Pull Request — master (#154)
by joseph
30:29
created

EntityUpserterLargeTest::setUp()   A

Complexity

Conditions 2
Paths 2

Size

Total Lines 11
Code Lines 8

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 2
eloc 8
nc 2
nop 0
dl 0
loc 11
rs 10
c 0
b 0
f 0
1
<?php declare(strict_types=1);
2
3
namespace EdmondsCommerce\DoctrineStaticMeta\Tests\Large\D\Entity\Savers;
4
5
use EdmondsCommerce\DoctrineStaticMeta\CodeGeneration\NamespaceHelper;
6
use EdmondsCommerce\DoctrineStaticMeta\Entity\Fields\Interfaces\String\EmailAddressFieldInterface;
7
use EdmondsCommerce\DoctrineStaticMeta\Entity\Interfaces\DataTransferObjectInterface;
8
use EdmondsCommerce\DoctrineStaticMeta\Tests\Assets\AbstractLargeTest;
9
use EdmondsCommerce\DoctrineStaticMeta\Tests\Assets\AbstractTest;
10
use EdmondsCommerce\DoctrineStaticMeta\Tests\Assets\GetGeneratedCodeContainerTrait;
11
use EdmondsCommerce\DoctrineStaticMeta\Tests\Assets\TestCodeGenerator;
12
13
/**
14
 * @large
15
 */
16
class EntityUpserterLargeTest extends AbstractLargeTest
17
{
18
    use GetGeneratedCodeContainerTrait;
19
20
    public const WORK_DIR = AbstractTest::VAR_PATH . '/' . self::TEST_TYPE_LARGE . '/EntityUpserterLargeTest';
21
22
    private const TEST_ENTITY_FQN = self::TEST_ENTITIES_ROOT_NAMESPACE . TestCodeGenerator::TEST_ENTITY_EMAIL;
23
24
    protected static $buildOnce = true;
25
    /** @var string */
26
    private $entityFqn;
27
    /** @var NamespaceHelper */
28
    private $namespaceHelper;
29
30
    public function setUp()
31
    {
32
        parent::setUp();
33
        if (false === self::$built) {
34
            $this->getTestCodeGenerator()
35
                 ->copyTo(self::WORK_DIR);
36
            self::$built = true;
37
        }
38
        $this->setupCopiedWorkDirAndCreateDatabase();
39
        $this->entityFqn       = $this->getCopiedFqn(self::TEST_ENTITY_FQN);
40
        $this->namespaceHelper = self::$containerStaticRef->get(NamespaceHelper::class);
41
    }
42
43
    /**
44
     * @test
45
     */
46
    public function itCanCreateADtoForAnEntityThatDoesNotExist(): void
47
    {
48
        $upserter     = $this->getUpserter();
49
        $className    = $this->namespaceHelper->getEntityUpserterFqnFromEntityFqn($this->entityFqn);
50
        $unknownEmail = '[email protected]';
51
        $this->assertInstanceOf($className, $upserter);
52
        $dto = $upserter->getUpsertDtoByProperty(EmailAddressFieldInterface::PROP_EMAIL_ADDRESS, $unknownEmail);
53
        self::assertInstanceOf(DataTransferObjectInterface::class, $dto);
54
        self::assertNull($dto->getJson());
55
        self::assertSame($unknownEmail, $dto->getEmailAddress());
56
    }
57
58
    /**
59
     * @test
60
     */
61
    public function itCanCreateADtoForAnExistingEntity(): void
62
    {
63
        $expectedEmail = '[email protected]';
64
        $expectedId    = $this->createAndSaveEntity($expectedEmail);
65
        $upserter      = $this->getUpserter();
66
        $dto           = $upserter->getUpsertDtoByProperty(
67
            EmailAddressFieldInterface::PROP_EMAIL_ADDRESS,
68
            $expectedEmail
69
        );
70
        self::assertSame($expectedEmail, $dto->getEmailAddress());
71
        self::assertSame($expectedId, $dto->getId()->toString());
72
    }
73
74
    /**
75
     * @test
76
     */
77
    public function itCanCreateADtoForAnExistingEntityUsingMultipleProperties(): void
78
    {
79
        $expectedEmail  = '[email protected]';
80
        $expectedString = 'This is a test string value';
81
        $expectedId     = $this->createAndSaveEntity($expectedEmail, $expectedString);
82
        $upserter       = $this->getUpserter();
83
        $dto            = $upserter->getUpsertDtoByProperties(
84
            [
85
                EmailAddressFieldInterface::PROP_EMAIL_ADDRESS => $expectedEmail,
86
                'string' => $expectedString
87
            ]
88
        );
89
        self::assertSame($expectedEmail, $dto->getEmailAddress());
90
        self::assertSame($expectedString, $dto->getString());
91
        self::assertSame($expectedId, $dto->getId()->toString());
92
    }
93
94
    /**
95
     * @test
96
     */
97
    public function itCanPersistADtoForANewEntity(): void
98
    {
99
        $expectedEmail = '[email protected]';
100
        $upserter      = $this->getUpserter();
101
        $dto           = $upserter->getUpsertDtoByProperty(
102
            EmailAddressFieldInterface::PROP_EMAIL_ADDRESS,
103
            $expectedEmail
104
        );
105
        $dto->setEmailAddress($expectedEmail);
106
        $upserter->persistUpsertDto($dto);
107
        $repository    = $this->getRepository();
108
        $updatedEntity = $repository->getOneBy([EmailAddressFieldInterface::PROP_EMAIL_ADDRESS => $expectedEmail]);
109
        self::assertSame($expectedEmail, $updatedEntity->getEmailAddress());
110
    }
111
112
    /**
113
     * @test
114
     */
115
    public function itCanPersistADtoForAnExistingDto(): void
116
    {
117
        $oldEmailAddress = '[email protected]';
118
        $expectedId      = $this->createAndSaveEntity($oldEmailAddress);
119
        $upserter        = $this->getUpserter();
120
        $dto             = $upserter->getUpsertDtoByProperty(
121
            EmailAddressFieldInterface::PROP_EMAIL_ADDRESS,
122
            $oldEmailAddress
123
        );
124
        $newEmailAddress = '[email protected]';
125
        $dto->setEmailAddress($newEmailAddress);
126
        $upserter->persistUpsertDto($dto);
127
        $repository    = $this->getRepository();
128
        $updatedEntity = $repository->getOneBy([EmailAddressFieldInterface::PROP_EMAIL_ADDRESS => $newEmailAddress]);
129
        self::assertSame($newEmailAddress, $updatedEntity->getEmailAddress());
130
        self::assertSame($expectedId, $updatedEntity->getId()->toString());
131
    }
132
133
    private function createAndSaveEntity(string $emailAddress, ?string $stringValue = null): string
134
    {
135
        $entity     = $this->createEntity($this->entityFqn);
136
        $dtoFactory = $this->getDtoFactory();
137
        $updateDto  = $dtoFactory->createDtoFromEmail($entity)->setEmailAddress($emailAddress);
138
        if ($stringValue !== null) {
139
            $updateDto->setString($stringValue);
140
        }
141
        $entity->update($updateDto);
142
        $saver = $this->getEntitySaver();
143
        $saver->save($entity);
144
145
        return $entity->getId()->toString();
146
    }
147
148
    private function getDtoFactory()
149
    {
150
        $dtoFactory = $this->namespaceHelper->getDtoFactoryFqnFromEntityFqn($this->entityFqn);
151
152
        return $this->getGeneratedClass($dtoFactory);
153
    }
154
155
    private function getRepository()
156
    {
157
        $repository = $this->namespaceHelper->getRepositoryqnFromEntityFqn($this->entityFqn);
158
159
        return $this->getGeneratedClass($repository);
160
    }
161
162
    private function getUpserter()
163
    {
164
        $class = $this->namespaceHelper->getEntityUpserterFqnFromEntityFqn($this->entityFqn);
165
166
        return $this->getGeneratedClass($class);
167
    }
168
}
169