ebs/tests/Functional/Controller/Admin/ServiceRequestCrudControllerTest.php
Loïc Vernet 32d91e49a0
Symfony 6.4 update (#590)
* symfony 6.3: removed sensio/framework-extra-bundle

* symfony 6.3: update

* Symfony 6.3.1 update

* chore: composer up

* symfony 6.4 update

* cs: php-code-fixer update

* fix composer.lock

* add php-http required dependencies

* Fix Stan and CS

---------

Co-authored-by: Jérôme Tanghe <jerome.tanghe@les-tilleuls.coop>
2024-10-08 09:50:06 +02:00

58 lines
2.2 KiB
PHP

<?php
declare(strict_types=1);
namespace App\Tests\Functional\Controller\Admin;
use App\Controller\Admin\ServiceRequestCrudController;
use App\Test\ContainerRepositoryTrait;
use App\Test\KernelTrait;
use App\Tests\TestReference;
use Hautelook\AliceBundle\PhpUnit\ReloadDatabaseTrait;
use Symfony\Bundle\FrameworkBundle\Test\WebTestCase;
use Symfony\Component\HttpFoundation\Response;
final class ServiceRequestCrudControllerTest extends WebTestCase
{
use KernelTrait;
use ReloadDatabaseTrait;
use ContainerRepositoryTrait;
/**
* @see ServiceRequestCrudController
*/
public function testController(): void
{
$client = self::createClient();
$this->loginAsAdmin($client);
// list + filter
$filters = 'filters[status]=new';
$client->request('GET', \sprintf(TestReference::ADMIN_URL, 'index', ServiceRequestCrudController::class.'&'.$filters));
self::assertResponseIsSuccessful();
// detail
$client->request('GET', \sprintf(TestReference::ADMIN_URL.'&entityId=%s', 'detail', ServiceRequestCrudController::class, TestReference::SERVICE_REQUEST_1));
self::assertResponseIsSuccessful();
// conversation
$client->request('GET', \sprintf(TestReference::ADMIN_URL.'&entityId=%s', 'conversation', ServiceRequestCrudController::class, TestReference::SERVICE_REQUEST_1));
self::assertResponseIsSuccessful();
}
public function testConversationPageWithAccessDenied(): void
{
$client = self::createClient();
$this->loginAsAdmin($client);
$configurationRepo = $this->getConfigurationRepository();
$config = $configurationRepo->getInstanceConfiguration()?->getConfiguration();
$config['confidentiality']['confidentialityConversationAdminAccess'] = false;
$configurationRepo->getInstanceConfiguration()?->setConfiguration($config);
// conversation page not allowed if confidentiality conversation admin access is set to false
$client->request('GET', \sprintf(TestReference::ADMIN_URL.'&entityId=%s', 'conversation', ServiceRequestCrudController::class, TestReference::SERVICE_REQUEST_1));
self::assertResponseStatusCodeSame(Response::HTTP_FORBIDDEN);
}
}