mirror of
https://github.com/kevinpapst/kimai2.git
synced 2024-12-22 12:18:29 +00:00
242 lines
9.2 KiB
PHP
242 lines
9.2 KiB
PHP
<?php
|
|
|
|
/*
|
|
* This file is part of the Kimai time-tracking app.
|
|
*
|
|
* For the full copyright and license information, please view the LICENSE
|
|
* file that was distributed with this source code.
|
|
*/
|
|
|
|
namespace App\Tests\Controller;
|
|
|
|
use App\DataFixtures\UserFixtures;
|
|
use App\Entity\Role;
|
|
use App\Entity\RolePermission;
|
|
use App\Entity\User;
|
|
|
|
/**
|
|
* @group integration
|
|
*/
|
|
class PermissionControllerTest extends AbstractControllerBaseTestCase
|
|
{
|
|
public function testIsSecure(): void
|
|
{
|
|
$this->assertUrlIsSecured('/admin/permissions');
|
|
}
|
|
|
|
public function testIsSecureForRole(): void
|
|
{
|
|
$this->assertUrlIsSecuredForRole(User::ROLE_ADMIN, '/admin/permissions');
|
|
}
|
|
|
|
public function testPermissions(): void
|
|
{
|
|
$client = $this->getClientForAuthenticatedUser(User::ROLE_SUPER_ADMIN);
|
|
$this->assertAccessIsGranted($client, '/admin/permissions');
|
|
$this->assertHasDataTable($client);
|
|
$this->assertDataTableRowCount($client, 'datatable_user_admin_permissions', 135);
|
|
$this->assertPageActions($client, [
|
|
'create modal-ajax-form' => $this->createUrl('/admin/permissions/roles/create'),
|
|
]);
|
|
|
|
$content = $client->getResponse()->getContent();
|
|
$this->assertTableHeader($content);
|
|
}
|
|
|
|
private function assertTableHeader(string $content): void
|
|
{
|
|
// the english translation instead of the real system user role names
|
|
self::assertStringContainsString('<th data-field="ROLE_USER" class="alwaysVisible text-center bg-green-lt col_ROLE_USER">', $content);
|
|
self::assertStringContainsString('<th data-field="ROLE_TEAMLEAD" class="alwaysVisible text-center col_ROLE_TEAMLEAD">', $content);
|
|
self::assertStringContainsString('<th data-field="ROLE_ADMIN" class="alwaysVisible text-center col_ROLE_ADMIN">', $content);
|
|
self::assertStringContainsString('<th data-field="ROLE_SUPER_ADMIN" class="alwaysVisible text-center bg-orange-lt col_ROLE_SUPER_ADMIN">', $content);
|
|
}
|
|
|
|
public function testCreateRoleIsSecured(): void
|
|
{
|
|
$this->assertUrlIsSecured('/admin/permissions/roles/create');
|
|
}
|
|
|
|
public function testCreateRoleIsSecuredForRole(): void
|
|
{
|
|
$this->assertUrlIsSecuredForRole(User::ROLE_ADMIN, '/admin/permissions');
|
|
}
|
|
|
|
public function testCreateRole(): void
|
|
{
|
|
$client = $this->getClientForAuthenticatedUser(User::ROLE_SUPER_ADMIN);
|
|
$this->assertAccessIsGranted($client, '/admin/permissions/roles/create');
|
|
$form = $client->getCrawler()->filter('form[name=role]')->form();
|
|
$client->submit($form, [
|
|
'role' => [
|
|
'name' => 'TEST_ROLE',
|
|
]
|
|
]);
|
|
$this->assertIsRedirect($client, $this->createUrl('/admin/permissions'));
|
|
$client->followRedirect();
|
|
|
|
$content = $client->getResponse()->getContent();
|
|
$this->assertTableHeader($content);
|
|
}
|
|
|
|
public function testDeleteRoleIsSecured(): void
|
|
{
|
|
$client = self::createClient();
|
|
|
|
$role = new Role();
|
|
$role->setName('TEST_ROLE');
|
|
|
|
$em = $this->getEntityManager();
|
|
$em->persist($role);
|
|
$em->flush();
|
|
|
|
$this->assertRequestIsSecured($client, '/admin/permissions/roles/' . $role->getId() . '/delete/sdfsdfsdfsd');
|
|
}
|
|
|
|
public function testDeleteRoleIsSecuredForRole(): void
|
|
{
|
|
$this->assertUrlIsSecuredForRole(User::ROLE_ADMIN, '/admin/permissions');
|
|
}
|
|
|
|
public function testDeleteRole(): void
|
|
{
|
|
$client = $this->getClientForAuthenticatedUser(User::ROLE_SUPER_ADMIN);
|
|
$this->assertAccessIsGranted($client, '/admin/permissions/roles/create');
|
|
$form = $client->getCrawler()->filter('form[name=role]')->form();
|
|
$client->submit($form, [
|
|
'role' => [
|
|
'name' => 'TEST_ROLE',
|
|
]
|
|
]);
|
|
$this->assertIsRedirect($client, $this->createUrl('/admin/permissions'));
|
|
$client->followRedirect();
|
|
|
|
$roles = $this->getEntityManager()->getRepository(Role::class)->findAll();
|
|
$id = null;
|
|
foreach ($roles as $role) {
|
|
if ($role->getName() === 'TEST_ROLE') {
|
|
$id = $role->getId();
|
|
break;
|
|
}
|
|
}
|
|
|
|
$content = $client->getResponse()->getContent();
|
|
self::assertStringContainsString('<th data-field="TEST_ROLE" class="alwaysVisible text-center col_TEST_ROLE">', $content);
|
|
|
|
// add user to role
|
|
$this->request($client, '/profile/' . UserFixtures::USERNAME_USER . '/roles');
|
|
$form = $client->getCrawler()->filter('form[name=user_roles]')->form();
|
|
$client->submit($form, [
|
|
'user_roles[roles]' => [
|
|
0 => 'ROLE_TEAMLEAD',
|
|
2 => 'ROLE_SUPER_ADMIN',
|
|
3 => 'TEST_ROLE'
|
|
]
|
|
]);
|
|
$this->assertIsRedirect($client, $this->createUrl('/profile/' . urlencode(UserFixtures::USERNAME_USER) . '/roles'));
|
|
$client->followRedirect();
|
|
self::assertTrue($client->getResponse()->isSuccessful());
|
|
|
|
$user = $this->getUserByName(UserFixtures::USERNAME_USER);
|
|
self::assertEquals(['ROLE_TEAMLEAD', 'ROLE_SUPER_ADMIN', 'TEST_ROLE', 'ROLE_USER'], $user->getRoles());
|
|
|
|
$this->request($client, '/admin/permissions');
|
|
$node = $client->getCrawler()->filter('div.card .card-title a.confirmation-link');
|
|
self::assertEquals(1, $node->count());
|
|
|
|
$this->request($client, $node->attr('href'));
|
|
$this->assertIsRedirect($client, $this->createUrl('/admin/permissions'));
|
|
$client->followRedirect();
|
|
|
|
self::assertHasFlashDeleteSuccess($client);
|
|
$content = $client->getResponse()->getContent();
|
|
self::assertStringNotContainsString('<th data-field="TEST_ROLE" class="alwaysVisible text-center">', $content);
|
|
|
|
// verify that role was removed from user
|
|
$user = $this->getUserByName(UserFixtures::USERNAME_USER);
|
|
self::assertEquals(['ROLE_TEAMLEAD', 'ROLE_SUPER_ADMIN', 'ROLE_USER'], $user->getRoles());
|
|
}
|
|
|
|
public function testSavePermissionIsSecured(): void
|
|
{
|
|
$client = self::createClient();
|
|
|
|
$role = new Role();
|
|
$role->setName('TEST_ROLE');
|
|
|
|
$em = $this->getEntityManager();
|
|
$em->persist($role);
|
|
$em->flush();
|
|
|
|
$this->assertRequestIsSecured($client, '/admin/permissions/roles/' . $role->getId() . '/view_user/1/asdfasdf', 'POST');
|
|
}
|
|
|
|
public function testSavePermissionIsSecuredForRole(): void
|
|
{
|
|
$this->assertUrlIsSecuredForRole(User::ROLE_ADMIN, '/admin/permissions');
|
|
}
|
|
|
|
public function testSavePermission(): void
|
|
{
|
|
$client = $this->getClientForAuthenticatedUser(User::ROLE_SUPER_ADMIN);
|
|
$this->assertAccessIsGranted($client, '/admin/permissions/roles/create');
|
|
$form = $client->getCrawler()->filter('form[name=role]')->form();
|
|
$client->submit($form, [
|
|
'role' => [
|
|
'name' => 'TEST_ROLE',
|
|
]
|
|
]);
|
|
$this->assertIsRedirect($client, $this->createUrl('/admin/permissions'));
|
|
$client->followRedirect();
|
|
|
|
$em = $this->getEntityManager();
|
|
$rolePermissions = $em->getRepository(RolePermission::class)->findAll();
|
|
self::assertEquals(0, \count($rolePermissions));
|
|
|
|
$roles = $em->getRepository(Role::class)->findAll();
|
|
$id = null;
|
|
foreach ($roles as $role) {
|
|
if ($role->getName() === 'TEST_ROLE') {
|
|
$id = $role->getId();
|
|
break;
|
|
}
|
|
}
|
|
|
|
$token = $client->getCrawler()->filter('div#permission-token')->attr('data-value');
|
|
|
|
// create the permission
|
|
$this->request($client, '/admin/permissions/roles/' . $id . '/view_user/1/' . $token, 'POST');
|
|
self::assertTrue($client->getResponse()->isSuccessful());
|
|
$result = json_decode($client->getResponse()->getContent(), true);
|
|
self::assertIsArray($result);
|
|
self::assertArrayHasKey('token', $result);
|
|
|
|
$rolePermissions = $em->getRepository(RolePermission::class)->findAll();
|
|
self::assertCount(1, $rolePermissions);
|
|
$permission = $rolePermissions[0];
|
|
self::assertInstanceOf(RolePermission::class, $permission);
|
|
self::assertEquals('view_user', $permission->getPermission());
|
|
self::assertTrue($permission->isAllowed());
|
|
self::assertEquals('TEST_ROLE', $permission->getRole()->getName());
|
|
self::assertEquals($id, $permission->getRole()->getId());
|
|
|
|
// flush the cache to prevent wrong results
|
|
$em->clear();
|
|
|
|
// update the permission
|
|
$this->request($client, '/admin/permissions/roles/' . $id . '/view_user/0/' . $result['token'], 'POST');
|
|
|
|
self::assertTrue($client->getResponse()->isSuccessful());
|
|
$result = json_decode($client->getResponse()->getContent(), true);
|
|
self::assertIsArray($result);
|
|
self::assertArrayHasKey('token', $result);
|
|
|
|
$rolePermissions = $em->getRepository(RolePermission::class)->findAll();
|
|
self::assertEquals(1, \count($rolePermissions));
|
|
$permission = $rolePermissions[0];
|
|
self::assertInstanceOf(RolePermission::class, $permission);
|
|
self::assertEquals('view_user', $permission->getPermission());
|
|
self::assertFalse($permission->isAllowed());
|
|
}
|
|
}
|