mirror of
https://gitlab.com/Chill-Projet/chill-bundles.git
synced 2025-06-07 18:44:08 +00:00
202 lines
6.0 KiB
PHP
202 lines
6.0 KiB
PHP
<?php
|
|
|
|
|
|
declare(strict_types=1);
|
|
|
|
/*
|
|
* 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.
|
|
*/
|
|
|
|
namespace Chill\PersonBundle\Tests\Controller;
|
|
|
|
use Chill\MainBundle\Entity\Address;
|
|
use Chill\MainBundle\Entity\AddressReference;
|
|
use Chill\MainBundle\Entity\Center;
|
|
use Chill\MainBundle\Test\PrepareClientTrait;
|
|
use Chill\PersonBundle\Entity\AccompanyingPeriod;
|
|
use Chill\PersonBundle\Entity\Household\Household;
|
|
use Chill\PersonBundle\Entity\Household\HouseholdMember;
|
|
use Chill\PersonBundle\Entity\Person;
|
|
use DateTime;
|
|
use Doctrine\ORM\EntityManagerInterface;
|
|
use RuntimeException;
|
|
use Symfony\Bundle\FrameworkBundle\Test\WebTestCase;
|
|
use Symfony\Component\HttpFoundation\Request;
|
|
use function array_map;
|
|
use function array_pop;
|
|
use function random_int;
|
|
use function shuffle;
|
|
|
|
/**
|
|
* @internal
|
|
* @coversNothing
|
|
*/
|
|
final class HouseholdApiControllerTest extends WebTestCase
|
|
{
|
|
use PrepareClientTrait;
|
|
|
|
private array $toDelete = [];
|
|
|
|
protected function tearDown(): void
|
|
{
|
|
self::bootKernel();
|
|
$em = self::$container->get(EntityManagerInterface::class);
|
|
|
|
foreach ($this->toDelete as [$class, $id]) {
|
|
$obj = $em->getRepository($class)->find($id);
|
|
$em->remove($obj);
|
|
}
|
|
|
|
$em->flush();
|
|
}
|
|
|
|
public function generateHouseholdAssociatedWithAddressReference()
|
|
{
|
|
self::bootKernel();
|
|
$em = self::$container->get(EntityManagerInterface::class);
|
|
$centerA = $em->getRepository(Center::class)->findOneBy(['name' => 'Center A']);
|
|
$nbReference = $em->createQueryBuilder()->select('count(ar)')->from(AddressReference::class, 'ar')
|
|
->getQuery()->getSingleScalarResult();
|
|
|
|
if (0 === $nbReference) {
|
|
throw new RuntimeException('any reference found. Add a reference in database to perform this test');
|
|
}
|
|
|
|
$reference = $em->createQueryBuilder()->select('ar')->from(AddressReference::class, 'ar')
|
|
->setFirstResult(random_int(0, $nbReference - 1))
|
|
->setMaxResults(1)
|
|
->getQuery()->getSingleResult();
|
|
|
|
$p = new Person();
|
|
$p->setFirstname('test')->setLastName('test lastname')
|
|
->setGender(Person::BOTH_GENDER)
|
|
->setCenter($centerA);
|
|
$em->persist($p);
|
|
$h = new Household();
|
|
$h->addMember($m = (new HouseholdMember())->setPerson($p));
|
|
$h->addAddress(Address::createFromAddressReference($reference)->setValidFrom(new DateTime('today')));
|
|
$em->persist($m);
|
|
$em->persist($h);
|
|
|
|
$em->flush();
|
|
|
|
$this->toDelete = $this->toDelete + [
|
|
[HouseholdMember::class, $m->getId()],
|
|
[User::class, $p->getId()],
|
|
[Household::class, $h->getId()],
|
|
[Person::class, $p->getId()],
|
|
];
|
|
|
|
yield [$reference->getId(), $h->getId()];
|
|
}
|
|
|
|
public function generateHouseholdId()
|
|
{
|
|
self::bootKernel();
|
|
|
|
$qb = self::$container->get(EntityManagerInterface::class)
|
|
->createQueryBuilder();
|
|
|
|
$householdIds = $qb
|
|
->select('DISTINCT household.id')
|
|
->from(Household::class, 'household')
|
|
->join('household.members', 'members')
|
|
->join('members.person', 'person')
|
|
->join('person.center', 'center')
|
|
->where($qb->expr()->eq('center.name', ':center_name'))
|
|
->andWhere($qb->expr()->gt('SIZE(person.accompanyingPeriodParticipations)', 0))
|
|
->setParameter('center_name', 'Center A')
|
|
->setMaxResults(100)
|
|
->getQuery()
|
|
->getResult();
|
|
|
|
shuffle($householdIds);
|
|
|
|
yield [array_pop($householdIds)['id']];
|
|
|
|
yield [array_pop($householdIds)['id']];
|
|
|
|
yield [array_pop($householdIds)['id']];
|
|
}
|
|
|
|
public function generatePersonId()
|
|
{
|
|
self::bootKernel();
|
|
|
|
$qb = self::$container->get(EntityManagerInterface::class)
|
|
->createQueryBuilder();
|
|
|
|
$period = $qb
|
|
->select('ap')
|
|
->from(AccompanyingPeriod::class, 'ap')
|
|
->where(
|
|
$qb->expr()->gte('SIZE(ap.participations)', 2)
|
|
)
|
|
->getQuery()
|
|
->setMaxResults(1)
|
|
->getSingleResult();
|
|
|
|
$person = $period->getParticipations()
|
|
->first()->getPerson();
|
|
|
|
yield [$person->getId()];
|
|
}
|
|
|
|
/**
|
|
* @dataProvider generateHouseholdAssociatedWithAddressReference
|
|
*/
|
|
public function testFindHouseholdByAddressReference(int $addressReferenceId, int $expectedHouseholdId)
|
|
{
|
|
$client = $this->getClientAuthenticated();
|
|
|
|
$client->request(
|
|
Request::METHOD_GET,
|
|
"/api/1.0/person/household/by-address-reference/{$addressReferenceId}.json"
|
|
);
|
|
|
|
$this->assertResponseIsSuccessful();
|
|
$data = json_decode($client->getResponse()->getContent(), true);
|
|
$this->assertArrayHasKey('count', $data);
|
|
$this->assertArrayHasKey('results', $data);
|
|
|
|
$householdIds = array_map(static function ($r) {
|
|
return $r['id'];
|
|
}, $data['results']);
|
|
|
|
$this->assertContains($expectedHouseholdId, $householdIds);
|
|
}
|
|
|
|
/**
|
|
* @dataProvider generateHouseholdId
|
|
*/
|
|
public function testSuggestAddressByHousehold(int $householdId)
|
|
{
|
|
$client = $this->getClientAuthenticated();
|
|
|
|
$client->request(
|
|
Request::METHOD_GET,
|
|
"/api/1.0/person/address/suggest/by-household/{$householdId}.json"
|
|
);
|
|
|
|
$this->assertResponseIsSuccessful();
|
|
}
|
|
|
|
/**
|
|
* @dataProvider generatePersonId
|
|
*/
|
|
public function testSuggestByAccompanyingPeriodParticipation(int $personId)
|
|
{
|
|
$client = $this->getClientAuthenticated();
|
|
|
|
$client->request(
|
|
Request::METHOD_GET,
|
|
"/api/1.0/person/household/suggest/by-person/{$personId}/through-accompanying-period-participation.json"
|
|
);
|
|
|
|
$this->assertResponseIsSuccessful();
|
|
}
|
|
}
|