Merge branch 'fix-tests/rdv-2' into 'features/rdv'

Fix tests/rdv 2

See merge request Chill-Projet/chill-bundles!147
This commit is contained in:
Julien Fastré 2021-09-24 08:33:42 +00:00
commit a9ce72034b
4 changed files with 40 additions and 29 deletions

View File

@ -95,6 +95,7 @@
} }
}, },
"config": { "config": {
"bin-dir": "bin" "bin-dir": "bin",
"vendor-dir": "tests/app/vendor"
} }
} }

View File

@ -10,7 +10,7 @@
<php> <php>
<ini name="error_reporting" value="-1" /> <ini name="error_reporting" value="-1" />
<server name="APP_ENV" value="test" force="true" /> <server name="APP_ENV" value="test" force="true" />
<env name="SYMFONY_DEPRECATIONS_HELPER" value="weak" /> <env name="SYMFONY_DEPRECATIONS_HELPER" value="weak" />
<server name="SHELL_VERBOSITY" value="-1" /> <server name="SHELL_VERBOSITY" value="-1" />
</php> </php>
@ -31,6 +31,9 @@
<!-- temporarily removed, the time to find a fix --> <!-- temporarily removed, the time to find a fix -->
<exclude>src/Bundle/ChillPersonBundle/Tests/Controller/PersonDuplicateControllerViewTest.php</exclude> <exclude>src/Bundle/ChillPersonBundle/Tests/Controller/PersonDuplicateControllerViewTest.php</exclude>
</testsuite> </testsuite>
<testsuite name="CalendarBundle">
<directory suffix="Test.php">src/Bundle/ChillCalendarBundle/Tests/</directory>
</testsuite>
</testsuites> </testsuites>
<listeners> <listeners>

View File

@ -2,65 +2,72 @@
namespace Chill\CalendarBundle\Tests\Controller; namespace Chill\CalendarBundle\Tests\Controller;
use Chill\PersonBundle\Repository\AccompanyingPeriodRepository;
use Doctrine\ORM\EntityManagerInterface;
use Symfony\Bundle\FrameworkBundle\Test\WebTestCase; use Symfony\Bundle\FrameworkBundle\Test\WebTestCase;
use Symfony\Component\HttpFoundation\Request; use Symfony\Component\HttpFoundation\Request;
use Chill\PersonBundle\Entity\AccompanyingPeriod; use Chill\PersonBundle\Entity\AccompanyingPeriod;
class CalendarControllerTest extends WebTestCase class CalendarControllerTest extends WebTestCase
{ {
/**
* Setup before the first test of this class (see phpunit doc)
*/
public static function setUpBeforeClass()
{
static::bootKernel();
}
/** /**
* Setup before each test method (see phpunit doc) * Setup before each test method (see phpunit doc)
*/ */
public function setUp() public function setUp()
{ {
static::bootKernel();
$this->client = static::createClient(array(), array( $this->client = static::createClient(array(), array(
'PHP_AUTH_USER' => 'center a_social', 'PHP_AUTH_USER' => 'center a_social',
'PHP_AUTH_PW' => 'password', 'PHP_AUTH_PW' => 'password',
)); ));
} }
private function getAccompanyingPeriodFromFixtures(): AccompanyingPeriod public function provideAccompanyingPeriod(): iterable
{ {
$em = static::$kernel->getContainer() static::bootKernel();
->get('doctrine.orm.entity_manager'); $em= static::$container->get(EntityManagerInterface::class);
$accompanying_period = $em->getRepository('ChillPersonBundle:AccompanyingPeriod')->find(1); $nb = $em->createQueryBuilder()
->from(AccompanyingPeriod::class, 'ac')
->select('COUNT(ac) AS nb')
->getQuery()
->getSingleScalarResult()
;
if ($accompanying_period === NULL) { yield [ $em->createQueryBuilder()
throw new \RuntimeException("We need an accompanying course with id = 1. Did you add fixtures ?"); ->from(AccompanyingPeriod::class, 'ac')
} ->select('ac.id')
->setFirstResult(\random_int(0, $nb))
return $accompanying_period; ->setMaxResults(1)
->getQuery()
->getSingleScalarResult()
];
} }
public function testList() /**
* @dataProvider provideAccompanyingPeriod
*/
public function testList(int $accompanyingPeriodId)
{ {
$this->client->request( $this->client->request(
Request::METHOD_GET, Request::METHOD_GET,
sprintf('/fr/calendar/?accompanying_period_id=%d', $this->getAccompanyingPeriodFromFixtures()->getId()) sprintf('/fr/calendar/calendar/?accompanying_period_id=%d', $accompanyingPeriodId)
); );
$this->assertEquals(200, $this->client->getResponse()->getStatusCode()); $this->assertEquals(200, $this->client->getResponse()->getStatusCode());
} }
/**
public function testNew() * @dataProvider provideAccompanyingPeriod
*/
public function testNew(int $accompanyingPeriodId)
{ {
$this->client->request( $this->client->request(
Request::METHOD_GET, Request::METHOD_GET,
sprintf('/fr/calendar/new?accompanying_period_id=%d', $this->getAccompanyingPeriodFromFixtures()->getId()) sprintf('/fr/calendar/calendar/new?accompanying_period_id=%d', $accompanyingPeriodId)
); );
$this->assertEquals(200, $this->client->getResponse()->getStatusCode()); $this->assertEquals(200, $this->client->getResponse()->getStatusCode());
} }
} }

@ -1 +1 @@
Subproject commit 8839b431f296733b792c788f2ef58e5ecd6419d3 Subproject commit bd95d3c96a437757b7e8f35cdfd30da9aeac1a01