Custom project roles inherit from project members

This commit is contained in:
Frederic Guillot
2016-09-08 20:44:03 -04:00
parent dded773749
commit fedf4ea2de
4 changed files with 86 additions and 0 deletions

View File

@@ -0,0 +1,37 @@
<?php
use Kanboard\Core\Security\Role;
require_once __DIR__.'/../../Base.php';
class RoleTest extends Base
{
public function testIsCustomRole()
{
$role = new Role();
$this->assertFalse($role->isCustomProjectRole(Role::PROJECT_MANAGER));
$this->assertFalse($role->isCustomProjectRole(Role::PROJECT_MEMBER));
$this->assertFalse($role->isCustomProjectRole(Role::PROJECT_VIEWER));
$this->assertFalse($role->isCustomProjectRole(''));
$this->assertTrue($role->isCustomProjectRole('Custom Role'));
}
public function testGetRoleName()
{
$role = new Role();
$this->assertEquals('Project Manager', $role->getRoleName(Role::PROJECT_MANAGER));
$this->assertEquals('Project Member', $role->getRoleName(Role::PROJECT_MEMBER));
$this->assertEquals('Project Viewer', $role->getRoleName(Role::PROJECT_VIEWER));
$this->assertEquals('Administrator', $role->getRoleName(Role::APP_ADMIN));
$this->assertEquals('Manager', $role->getRoleName(Role::APP_MANAGER));
$this->assertEquals('User', $role->getRoleName(Role::APP_USER));
$this->assertEquals('Unknown', $role->getRoleName('Foobar'));
}
public function testGetters()
{
$role = new Role();
$this->assertCount(3, $role->getApplicationRoles());
$this->assertCount(3, $role->getProjectRoles());
}
}

View File

@@ -5,6 +5,7 @@ require_once __DIR__.'/../Base.php';
use Kanboard\Core\User\UserSession;
use Kanboard\Helper\UserHelper;
use Kanboard\Model\ProjectModel;
use Kanboard\Model\ProjectRoleModel;
use Kanboard\Model\ProjectUserRoleModel;
use Kanboard\Model\TaskCreationModel;
use Kanboard\Model\TaskFinderModel;
@@ -263,6 +264,37 @@ class UserHelperTest extends Base
$this->assertFalse($helper->hasProjectAccess('TaskCreationController', 'save', 2));
}
public function testHasProjectAccessForCustomProjectRole()
{
$helper = new UserHelper($this->container);
$user = new UserModel($this->container);
$project = new ProjectModel($this->container);
$projectUserRole = new ProjectUserRoleModel($this->container);
$projectRole = new ProjectRoleModel($this->container);
$this->container['sessionStorage']->user = array(
'id' => 2,
'role' => Role::APP_USER,
);
$this->assertEquals(1, $project->create(array('name' => 'My project')));
$this->assertEquals(2, $project->create(array('name' => 'My project')));
$this->assertEquals(2, $user->create(array('username' => 'user')));
$this->assertEquals(1, $projectRole->create(1, 'Custom Role'));
$this->assertTrue($projectUserRole->addUser(1, 2, 'Custom Role'));
$this->assertFalse($helper->hasProjectAccess('ProjectEditController', 'edit', 1));
$this->assertTrue($helper->hasProjectAccess('BoardViewController', 'show', 1));
$this->assertTrue($helper->hasProjectAccess('TaskViewController', 'show', 1));
$this->assertTrue($helper->hasProjectAccess('TaskCreationController', 'save', 1));
$this->assertFalse($helper->hasProjectAccess('ProjectEditController', 'edit', 2));
$this->assertFalse($helper->hasProjectAccess('BoardViewController', 'show', 2));
$this->assertFalse($helper->hasProjectAccess('TaskViewController', 'show', 2));
$this->assertFalse($helper->hasProjectAccess('TaskCreationController', 'save', 2));
}
public function testCanRemoveTask()
{
$taskCreationModel = new TaskCreationModel($this->container);