mirror of
https://gitlab.com/Chill-Projet/chill-bundles.git
synced 2025-06-07 18:44:08 +00:00
commit 977863c2dd56d5c835f2a710cad7f7d3ba42da68 Merge: 5c37b419d 3eb7ffed1 Author: Julien Fastré <julien.fastre@champs-libres.coop> Date: Sun Dec 12 14:45:21 2021 +0100 Merge remote-tracking branch 'origin/master' into docgen/improve-normalizer commit 5c37b419ddf0b32b9950c33042396bba1860da84 Author: Julien Fastré <julien.fastre@champs-libres.coop> Date: Sun Dec 12 14:37:05 2021 +0100 fix normalization for user and type in null value commit 4469d46cdb19051fedec86bbb84e2351e6fcb72e Author: Julien Fastré <julien.fastre@champs-libres.coop> Date: Sun Dec 12 13:24:23 2021 +0100 add civility to person commit 6cf92fbbde8f4d9f2f4763ec4ee88216257040f7 Author: Julien Fastré <julien.fastre@champs-libres.coop> Date: Sun Dec 12 13:19:36 2021 +0100 fix person normalization: add a isNull on not null person commit ed6087ff8fd47b80ea5e9526756fe5d032d478e3 Author: Julien Fastré <julien.fastre@champs-libres.coop> Date: Sun Dec 12 13:08:46 2021 +0100 fix stan and cs issues commit 8429c334c33b3545835cbde034fccaa529c134a7 Author: Julien Fastré <julien.fastre@champs-libres.coop> Date: Sun Dec 12 13:08:36 2021 +0100 fix id type commit 39ae00d172a9f29320a97abb8518b2ea48d89d9b Author: Julien Fastré <julien.fastre@champs-libres.coop> Date: Sun Dec 12 12:52:41 2021 +0100 fix test and fix null or not-null value have same keys commit 312fcc44c07affa7aa60f6c5fce58f9d1c564cc3 Author: Julien Fastré <julien.fastre@champs-libres.coop> Date: Sat Dec 11 03:27:30 2021 +0100 improve normalization wip commit f91a29635827005fc58617dc1c9d210091372be5 Author: Julien Fastré <julien.fastre@champs-libres.coop> Date: Sat Dec 11 01:15:32 2021 +0100 improve normalization commit 56060e5e6a2191ef441039fdc91a01fb4653a553 Author: Julien Fastré <julien.fastre@champs-libres.coop> Date: Sat Dec 11 00:41:09 2021 +0100 handle changelog with translatable string commit 9004686a13f816309806cb1231bccd3159a652df Author: Julien Fastré <julien.fastre@champs-libres.coop> Date: Fri Dec 10 01:10:55 2021 +0100 improve docgen wip commit e266fa0e5dc8c0da446851e5f79f2dc7dab00f70 Author: Julien Fastré <julien.fastre@champs-libres.coop> Date: Thu Dec 9 21:50:56 2021 +0100 show errors from relatorio driver commit 75ba56fa096917da3b284e3d5a3bb8fe490df2a3 Author: Julien Fastré <julien.fastre@champs-libres.coop> Date: Thu Dec 9 21:14:12 2021 +0100 add verification tool for admin commit 12d6829b98d73eab232b345f2a611d58ae95874b Author: Julien Fastré <julien.fastre@champs-libres.coop> Date: Thu Dec 9 14:17:42 2021 +0100 fix type with phonenumber helper commit 7b5e96771f4ca76fc131b9f2f6b5cac70996bec9 Merge: 8a9024de1 8a4748dc2 Author: Julien Fastré <julien.fastre@champs-libres.coop> Date: Thu Dec 9 14:11:14 2021 +0100 Merge remote-tracking branch 'origin/master' into docgen/improve-normalizer commit 8a9024de13ed702373fffd19c15ca638eb398520 Author: Julien Fastré <julien.fastre@champs-libres.coop> Date: Thu Dec 9 13:51:36 2021 +0100 add docgen:normalization for relation commit 24a404964b75d1a31108c6b90d82b1592305dccb Author: Julien Fastré <julien.fastre@champs-libres.coop> Date: Thu Dec 9 12:44:41 2021 +0100 docgen normalization for relation commit 5d24bd4d11db1627527497a8b83dd2bd59726fee Merge: 70ab23214 455b225f4 Author: Julien Fastré <julien.fastre@champs-libres.coop> Date: Wed Dec 8 21:08:30 2021 +0100 Merge branch 'master' into docgen/improve-normalizer commit 70ab23214906088b9287061ca3d721ba3ea624f3 Author: Julien Fastré <julien.fastre@champs-libres.coop> Date: Wed Dec 8 13:58:49 2021 +0100 improve docgen, trnslations, admin commit 027c01fc58d679cfcc2e71ca16825a38533bdf79 Author: Julien Fastré <julien.fastre@champs-libres.coop> Date: Wed Dec 8 12:23:24 2021 +0100 fix css block commit fdc5127c74ff0be3828c4bb0fc989010d28eca6f Author: Julien Fastré <julien.fastre@champs-libres.coop> Date: Wed Dec 8 11:57:16 2021 +0100 fix some error in test (wip) commit b8d48f04ae2e2c5dfec6a876c2a7d5733f8b8a58 Author: Julien Fastré <julien.fastre@champs-libres.coop> Date: Wed Dec 8 11:47:50 2021 +0100 fix tests (wip) commit f1b1771d6baf8e585e01859b138f3ad5ad6f8c7a Author: Julien Fastré <julien.fastre@champs-libres.coop> Date: Wed Dec 8 11:35:00 2021 +0100 fix tests (wip) commit 62dabbe1e76dfead6b5ec94b354f8b4e1b9a7476 Author: Julien Fastré <julien.fastre@champs-libres.coop> Date: Wed Dec 8 11:14:46 2021 +0100 fix code style commit 4101392190f3e0a3772553235a44268d8144c2e8 Author: Julien Fastré <julien.fastre@champs-libres.coop> Date: Wed Dec 8 11:13:49 2021 +0100 fix tests and type hinting commit 3f1bed0b1cc4a4248f7041f81e633fedb762f5c9 Author: Julien Fastré <julien.fastre@champs-libres.coop> Date: Wed Dec 8 11:05:41 2021 +0100 fix tests (wip) commit 79fbdcdee4a1b9e63cf5ab7d33d61b75e638837e Author: Julien Fastré <julien.fastre@champs-libres.coop> Date: Wed Dec 8 11:05:29 2021 +0100 type hint User class commit 3d8d79323e47c9dd27361a212dbf73f58600ed9a Author: Julien Fastré <julien.fastre@champs-libres.coop> Date: Wed Dec 8 10:56:30 2021 +0100 remove error messages commit 32178e22feced2256ae58a3c63d4d7d863c555e6 Author: Julien Fastré <julien.fastre@champs-libres.coop> Date: Wed Dec 8 10:51:30 2021 +0100 fix tests (wip) commit 60a8c20896908d7e434871527910c83eefb8d849 Author: Julien Fastré <julien.fastre@champs-libres.coop> Date: Wed Dec 8 10:29:54 2021 +0100 update app commit 9d8011da617c83a96451b33b0a0b43054a1f0c7c Author: Julien Fastré <julien.fastre@champs-libres.coop> Date: Wed Dec 8 10:06:35 2021 +0100 fix loading origin commit 789eeadb404c1950f4b33d201bd78bda915664df Author: Julien Fastré <julien.fastre@champs-libres.coop> Date: Wed Dec 8 09:52:51 2021 +0100 fix loading fixtures for doc generator template commit f206fdb08ccd85d7d2a460e51578b1acc6dc153c Author: Julien Fastré <julien.fastre@champs-libres.coop> Date: Wed Dec 8 09:52:35 2021 +0100 fix code style commit 9d5409d8d9e0df8c5f0e53e758dde60817732b9b Author: Julien Fastré <julien.fastre@champs-libres.coop> Date: Wed Dec 8 09:52:06 2021 +0100 fix casting commit e297d8253344a13f297793e7102ed1f51ff28235 Author: Julien Fastré <julien.fastre@champs-libres.coop> Date: Wed Dec 8 09:26:13 2021 +0100 fixes on tests [WIP]
239 lines
8.8 KiB
PHP
239 lines
8.8 KiB
PHP
<?php
|
|
|
|
/**
|
|
* Chill is a software for social workers
|
|
*
|
|
* For the full copyright and license information, please view
|
|
* the LICENSE file that was distributed with this source code.
|
|
*/
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace Serializer\Normalizer;
|
|
|
|
use Chill\MainBundle\Templating\TranslatableStringHelper;
|
|
use Chill\MainBundle\Templating\TranslatableStringHelperInterface;
|
|
use Chill\PersonBundle\Entity\Household\Household;
|
|
use Chill\PersonBundle\Entity\Household\HouseholdMember;
|
|
use Chill\PersonBundle\Entity\Household\Position;
|
|
use Chill\PersonBundle\Entity\Person;
|
|
use Chill\PersonBundle\Entity\Relationships\Relation;
|
|
use Chill\PersonBundle\Entity\Relationships\Relationship;
|
|
use Chill\PersonBundle\Repository\Relationships\RelationshipRepository;
|
|
use Chill\PersonBundle\Serializer\Normalizer\PersonDocGenNormalizer;
|
|
use Chill\PersonBundle\Templating\Entity\PersonRender;
|
|
use Prophecy\Argument;
|
|
use Symfony\Bundle\FrameworkBundle\Test\KernelTestCase;
|
|
use Symfony\Component\Serializer\Normalizer\NormalizerInterface;
|
|
use Symfony\Contracts\Translation\TranslatorInterface;
|
|
use function array_merge;
|
|
|
|
/**
|
|
* @internal
|
|
* @coversNothing
|
|
*/
|
|
final class PersonDocGenNormalizerTest extends KernelTestCase
|
|
{
|
|
private const BLANK = [
|
|
'firstname' => '',
|
|
'lastname' => '',
|
|
'altNames' => '',
|
|
'text' => '',
|
|
'isNull' => true,
|
|
'type' => 'person',
|
|
'birthdate' => ['short' => '', 'long' => ''],
|
|
'deathdate' => ['short' => '', 'long' => ''],
|
|
'gender' => '',
|
|
'civility' => '@ignored',
|
|
'address' => '@ignored',
|
|
'maritalStatus' => '',
|
|
'maritalStatusDate' => ['short' => '', 'long' => ''],
|
|
'email' => '',
|
|
'firstPhoneNumber' => '',
|
|
'fixPhoneNumber' => '',
|
|
'mobilePhoneNumber' => '',
|
|
'nationality' => '',
|
|
'placeOfBirth' => '',
|
|
'memo' => '',
|
|
'numberOfChildren' => '',
|
|
];
|
|
|
|
private NormalizerInterface $normalizer;
|
|
|
|
protected function setUp()
|
|
{
|
|
self::bootKernel();
|
|
|
|
$this->normalizer = self::$container->get(NormalizerInterface::class);
|
|
}
|
|
|
|
public function generateData()
|
|
{
|
|
$person = new Person();
|
|
$person
|
|
->setFirstName('Renaud')
|
|
->setLastName('Mégane');
|
|
|
|
$expected = array_merge(
|
|
self::BLANK,
|
|
['firstname' => 'Renaud', 'lastname' => 'Mégane',
|
|
'text' => 'Renaud Mégane', ]
|
|
);
|
|
|
|
yield [$person, $expected, 'partial normalization for a person'];
|
|
|
|
yield [null, self::BLANK, 'normalization for a null person'];
|
|
}
|
|
|
|
public function testNormalizationNullOrNotNullHaveSameKeys()
|
|
{
|
|
$period = new Person();
|
|
$notNullData = $this->buildPersonNormalizer()->normalize($period, 'docgen', ['docgen:expects' => Person::class]);
|
|
$nullData = $this->buildPersonNormalizer()->normalize(null, 'docgen', ['docgen:expects' => Person::class]);
|
|
|
|
$this->assertEqualsCanonicalizing(
|
|
array_keys($notNullData),
|
|
array_keys($nullData),
|
|
'test that the data returned by null value and a Person have the same keys'
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @dataProvider generateData
|
|
*
|
|
* @param mixed $expected
|
|
* @param mixed $msg
|
|
*/
|
|
public function testNormalize(?Person $person, $expected, $msg)
|
|
{
|
|
$normalized = $this->normalizer->normalize($person, 'docgen', [
|
|
'docgen:expects' => Person::class,
|
|
'groups' => 'docgen:read',
|
|
]);
|
|
|
|
$this->assertIsArray($normalized);
|
|
|
|
foreach ($normalized as $key => $value) {
|
|
if ('@ignored' === $value) {
|
|
continue;
|
|
}
|
|
|
|
$this->assertEquals($value, $normalized[$key]);
|
|
}
|
|
$this->assertEqualsCanonicalizing(array_keys($expected), array_keys($normalized), $msg);
|
|
}
|
|
|
|
public function testNormalizePersonWithHousehold()
|
|
{
|
|
$household = new Household();
|
|
$person = new Person();
|
|
$person
|
|
->setFirstName('Renaud')
|
|
->setLastName('Mégane');
|
|
$householdMember = new HouseholdMember();
|
|
$householdMember
|
|
->setPosition((new Position())->setAllowHolder(true)->setLabel(['fr' => 'position'])
|
|
->setShareHousehold(true))
|
|
->setHolder(true);
|
|
$person->addHouseholdParticipation($householdMember);
|
|
$household->addMember($householdMember);
|
|
|
|
$person = new Person();
|
|
$person
|
|
->setFirstName('Citroen')
|
|
->setLastName('Xsara');
|
|
$householdMember = new HouseholdMember();
|
|
$householdMember
|
|
->setPosition((new Position())->setAllowHolder(true)->setLabel(['fr' => 'position2'])
|
|
->setShareHousehold(true))
|
|
->setHolder(false);
|
|
$person->addHouseholdParticipation($householdMember);
|
|
$household->addMember($householdMember);
|
|
|
|
$actual = $this->normalizer->normalize($person, 'docgen', [
|
|
'groups' => 'docgen:read',
|
|
'docgen:expects' => Person::class,
|
|
'docgen:person:with-household' => true,
|
|
]);
|
|
|
|
$this->assertCount(2, $household->getMembers());
|
|
$this->assertIsArray($actual);
|
|
$this->assertArrayHasKey('household', $actual);
|
|
$this->assertCount(2, $actual['household']['currentMembers']);
|
|
$this->assertCount(2, $actual['household']['members']);
|
|
}
|
|
|
|
public function testNormalizePersonWithRelationships()
|
|
{
|
|
$person = (new Person())->setFirstName('Renaud')->setLastName('megane');
|
|
$father = (new Person())->setFirstName('Clément')->setLastName('megane');
|
|
$mother = (new Person())->setFirstName('Mireille')->setLastName('Mathieu');
|
|
$sister = (new Person())->setFirstName('Callie')->setLastName('megane');
|
|
|
|
$relations = [
|
|
(new Relationship())->setFromPerson($person)->setToPerson($father)
|
|
->setReverse(false)->setRelation((new Relation())->setTitle(['fr' => 'Père'])
|
|
->setReverseTitle(['fr' => 'Fils'])),
|
|
(new Relationship())->setFromPerson($person)->setToPerson($mother)
|
|
->setReverse(false)->setRelation((new Relation())->setTitle(['fr' => 'Mère'])
|
|
->setReverseTitle(['fr' => 'Fils'])),
|
|
(new Relationship())->setFromPerson($person)->setToPerson($sister)
|
|
->setReverse(true)->setRelation((new Relation())->setTitle(['fr' => 'Frère'])
|
|
->setReverseTitle(['fr' => 'Soeur'])),
|
|
];
|
|
|
|
$repository = $this->prophesize(RelationshipRepository::class);
|
|
$repository->findByPerson($person)->willReturn($relations);
|
|
|
|
$normalizer = $this->buildPersonNormalizer(null, $repository->reveal(), null, null);
|
|
|
|
$actual = $normalizer->normalize($person, 'docgen', [
|
|
'groups' => 'docgen:read',
|
|
'docgen:expects' => Person::class,
|
|
'docgen:person:with-relations' => true,
|
|
]);
|
|
|
|
$this->assertIsArray($actual);
|
|
$this->assertArrayHasKey('relations', $actual);
|
|
$this->assertCount(3, $actual['relations']);
|
|
}
|
|
|
|
private function buildPersonNormalizer(
|
|
?PersonRender $personRender = null,
|
|
?RelationshipRepository $relationshipRepository = null,
|
|
?TranslatorInterface $translator = null,
|
|
?TranslatableStringHelper $translatableStringHelper = null
|
|
): PersonDocGenNormalizer {
|
|
$normalizer = new PersonDocGenNormalizer(
|
|
$personRender ?? self::$container->get(PersonRender::class),
|
|
$relationshipRepository ?? self::$container->get(RelationshipRepository::class),
|
|
$translator ?? self::$container->get(TranslatorInterface::class),
|
|
$translatableStringHelper ?? self::$container->get(TranslatableStringHelperInterface::class)
|
|
);
|
|
$normalizerManager = $this->prophesize(NormalizerInterface::class);
|
|
$normalizerManager->supportsNormalization(Argument::any(), 'docgen', Argument::any())->willReturn(true);
|
|
$normalizerManager->normalize(Argument::type(Person::class), 'docgen', Argument::any())
|
|
->will(static function ($args) use ($normalizer) {
|
|
return $normalizer->normalize($args[0], $args[1], $args[2]);
|
|
});
|
|
$normalizerManager->normalize(Argument::any(), 'docgen', Argument::any())->will(
|
|
static function ($args) {
|
|
if (is_iterable($args[0])) {
|
|
$r = [];
|
|
|
|
foreach ($args[0] as $i) {
|
|
$r[] = ['fake' => true, 'hash' => spl_object_hash($i)];
|
|
}
|
|
|
|
return $r;
|
|
}
|
|
|
|
return ['fake' => true, 'hash' => null !== $args[0] ? spl_object_hash($args[0]) : null];
|
|
}
|
|
);
|
|
$normalizer->setNormalizer($normalizerManager->reveal());
|
|
|
|
return $normalizer;
|
|
}
|
|
}
|