| <?php |
|
|
| use Kanboard\Core\Security\Role; |
| use Kanboard\Core\User\UserSession; |
| use Kanboard\Helper\ProjectRoleHelper; |
| use Kanboard\Model\ColumnMoveRestrictionModel; |
| use Kanboard\Model\ColumnRestrictionModel; |
| use Kanboard\Model\ProjectModel; |
| use Kanboard\Model\ProjectRoleModel; |
| use Kanboard\Model\ProjectRoleRestrictionModel; |
| use Kanboard\Model\ProjectUserRoleModel; |
| use Kanboard\Model\TaskCreationModel; |
| use Kanboard\Model\TaskFinderModel; |
| use Kanboard\Model\TaskStatusModel; |
| use Kanboard\Model\UserModel; |
|
|
| require_once __DIR__.'/../Base.php'; |
|
|
| class ProjectRoleHelperTest extends Base |
| { |
| public function testCanCreateTaskInColumnWithProjectViewer() |
| { |
| $projectRoleHelper = new ProjectRoleHelper($this->container); |
| $projectModel = new ProjectModel($this->container); |
| $projectUserRole = new ProjectUserRoleModel($this->container); |
| $userModel = new UserModel($this->container); |
|
|
| $_SESSION['user'] = array( |
| 'id' => 2, |
| 'role' => Role::APP_USER, |
| ); |
|
|
| $this->assertEquals(2, $userModel->create(array('username' => 'user'))); |
| $this->assertEquals(1, $projectModel->create(array('name' => 'Test'))); |
| $this->assertTrue($projectUserRole->addUser(1, 2, Role::PROJECT_VIEWER)); |
|
|
| $this->assertFalse($projectRoleHelper->canCreateTaskInColumn(1, 1)); |
| } |
|
|
| public function testCanCreateTaskInColumnWithProjectMember() |
| { |
| $projectRoleHelper = new ProjectRoleHelper($this->container); |
| $projectModel = new ProjectModel($this->container); |
| $projectUserRole = new ProjectUserRoleModel($this->container); |
| $userModel = new UserModel($this->container); |
|
|
| $_SESSION['user'] = array( |
| 'id' => 2, |
| 'role' => Role::APP_USER, |
| ); |
|
|
| $this->assertEquals(2, $userModel->create(array('username' => 'user'))); |
| $this->assertEquals(1, $projectModel->create(array('name' => 'Test'))); |
| $this->assertTrue($projectUserRole->addUser(1, 2, Role::PROJECT_MEMBER)); |
|
|
| $this->assertTrue($projectRoleHelper->canCreateTaskInColumn(1, 1)); |
| } |
|
|
| public function testCanCreateTaskInColumnWithCustomProjectRole() |
| { |
| $projectRoleHelper = new ProjectRoleHelper($this->container); |
| $projectModel = new ProjectModel($this->container); |
| $projectUserRole = new ProjectUserRoleModel($this->container); |
| $userModel = new UserModel($this->container); |
| $projectRoleModel = new ProjectRoleModel($this->container); |
|
|
| $_SESSION['user'] = array( |
| 'id' => 2, |
| 'role' => Role::APP_USER, |
| ); |
|
|
| $this->assertEquals(2, $userModel->create(array('username' => 'user'))); |
| $this->assertEquals(1, $projectModel->create(array('name' => 'Test'))); |
|
|
| $this->assertEquals(1, $projectRoleModel->create(1, 'Custom Role')); |
| $this->assertTrue($projectUserRole->addUser(1, 2, 'Custom Role')); |
|
|
| $this->assertTrue($projectRoleHelper->canCreateTaskInColumn(1, 1)); |
| } |
|
|
| public function testCanCreateTaskInColumnWithCustomProjectRoleAndRestrictions() |
| { |
| $projectRoleHelper = new ProjectRoleHelper($this->container); |
| $projectModel = new ProjectModel($this->container); |
| $projectUserRole = new ProjectUserRoleModel($this->container); |
| $userModel = new UserModel($this->container); |
| $projectRoleModel = new ProjectRoleModel($this->container); |
| $projectRoleRestrictionModel = new ProjectRoleRestrictionModel($this->container); |
| $columnRestrictionModel = new ColumnRestrictionModel($this->container); |
|
|
| $_SESSION['user'] = array( |
| 'id' => 2, |
| 'role' => Role::APP_USER, |
| ); |
|
|
| $this->assertEquals(2, $userModel->create(array('username' => 'user'))); |
| $this->assertEquals(1, $projectModel->create(array('name' => 'Test'))); |
|
|
| $this->assertEquals(1, $projectRoleModel->create(1, 'Custom Role')); |
| $this->assertTrue($projectUserRole->addUser(1, 2, 'Custom Role')); |
|
|
| $this->assertEquals(1, $projectRoleRestrictionModel->create(1, 1, ProjectRoleRestrictionModel::RULE_TASK_CREATION)); |
| $this->assertEquals(1, $columnRestrictionModel->create(1, 1, 1, ColumnRestrictionModel::RULE_ALLOW_TASK_CREATION)); |
|
|
| $this->assertTrue($projectRoleHelper->canCreateTaskInColumn(1, 1)); |
| $this->assertFalse($projectRoleHelper->canCreateTaskInColumn(1, 2)); |
| } |
|
|
| public function testCanRemoveTaskWithCustomProjectRoleAndRestriction() |
| { |
| $projectRoleHelper = new ProjectRoleHelper($this->container); |
| $projectModel = new ProjectModel($this->container); |
| $projectUserRole = new ProjectUserRoleModel($this->container); |
| $userModel = new UserModel($this->container); |
| $projectRoleModel = new ProjectRoleModel($this->container); |
| $taskCreationModel = new TaskCreationModel($this->container); |
| $taskFinderModel = new TaskFinderModel($this->container); |
| $projectRoleRestrictionModel = new ProjectRoleRestrictionModel($this->container); |
|
|
| $_SESSION['user'] = array( |
| 'id' => 2, |
| 'role' => Role::APP_USER, |
| ); |
|
|
| $this->assertEquals(2, $userModel->create(array('username' => 'user'))); |
| $this->assertEquals(1, $projectModel->create(array('name' => 'Test'))); |
| $this->assertEquals(1, $taskCreationModel->create(array('project_id' => 1 , 'title' => 'test'))); |
|
|
| $this->assertEquals(1, $projectRoleModel->create(1, 'Custom Role')); |
| $this->assertTrue($projectUserRole->addUser(1, 2, 'Custom Role')); |
|
|
| $this->assertEquals(1, $projectRoleRestrictionModel->create(1, 1, ProjectRoleRestrictionModel::RULE_TASK_SUPPRESSION)); |
|
|
| $task = $taskFinderModel->getById(1); |
| $this->assertFalse($projectRoleHelper->canRemoveTask($task)); |
| } |
|
|
| public function testCanRemoveTaskWithCustomProjectRole() |
| { |
| $projectRoleHelper = new ProjectRoleHelper($this->container); |
| $projectModel = new ProjectModel($this->container); |
| $projectUserRole = new ProjectUserRoleModel($this->container); |
| $userModel = new UserModel($this->container); |
| $projectRoleModel = new ProjectRoleModel($this->container); |
| $taskCreationModel = new TaskCreationModel($this->container); |
| $taskFinderModel = new TaskFinderModel($this->container); |
|
|
| $_SESSION['user'] = array( |
| 'id' => 2, |
| 'role' => Role::APP_USER, |
| ); |
|
|
| $this->assertEquals(2, $userModel->create(array('username' => 'user'))); |
| $this->assertEquals(1, $projectModel->create(array('name' => 'Test'))); |
| $this->assertEquals(1, $taskCreationModel->create(array('project_id' => 1 , 'title' => 'test'))); |
|
|
| $this->assertEquals(1, $projectRoleModel->create(1, 'Custom Role')); |
| $this->assertTrue($projectUserRole->addUser(1, 2, 'Custom Role')); |
|
|
| $task = $taskFinderModel->getById(1); |
| $this->assertTrue($projectRoleHelper->canRemoveTask($task)); |
| } |
|
|
| public function testCanChangeAssigneeWithCustomProjectRoleAndRestriction() |
| { |
| $projectRoleHelper = new ProjectRoleHelper($this->container); |
| $projectModel = new ProjectModel($this->container); |
| $projectUserRole = new ProjectUserRoleModel($this->container); |
| $userModel = new UserModel($this->container); |
| $projectRoleModel = new ProjectRoleModel($this->container); |
| $taskCreationModel = new TaskCreationModel($this->container); |
| $taskFinderModel = new TaskFinderModel($this->container); |
| $projectRoleRestrictionModel = new ProjectRoleRestrictionModel($this->container); |
|
|
| $_SESSION['user'] = array( |
| 'id' => 2, |
| 'role' => Role::APP_USER, |
| ); |
|
|
| $this->assertEquals(2, $userModel->create(array('username' => 'user'))); |
| $this->assertEquals(1, $projectModel->create(array('name' => 'Test'))); |
| $this->assertEquals(1, $taskCreationModel->create(array('project_id' => 1 , 'title' => 'test'))); |
|
|
| $this->assertEquals(1, $projectRoleModel->create(1, 'Custom Role')); |
| $this->assertTrue($projectUserRole->addUser(1, 2, 'Custom Role')); |
|
|
| $this->assertEquals(1, $projectRoleRestrictionModel->create(1, 1, ProjectRoleRestrictionModel::RULE_TASK_CHANGE_ASSIGNEE)); |
|
|
| $task = $taskFinderModel->getById(1); |
| $this->assertFalse($projectRoleHelper->canChangeAssignee($task)); |
| } |
|
|
| public function testCanChangeAssigneeWithCustomProjectRole() |
| { |
| $projectRoleHelper = new ProjectRoleHelper($this->container); |
| $projectModel = new ProjectModel($this->container); |
| $projectUserRole = new ProjectUserRoleModel($this->container); |
| $userModel = new UserModel($this->container); |
| $projectRoleModel = new ProjectRoleModel($this->container); |
| $taskCreationModel = new TaskCreationModel($this->container); |
| $taskFinderModel = new TaskFinderModel($this->container); |
|
|
| $_SESSION['user'] = array( |
| 'id' => 2, |
| 'role' => Role::APP_USER, |
| ); |
|
|
| $this->assertEquals(2, $userModel->create(array('username' => 'user'))); |
| $this->assertEquals(1, $projectModel->create(array('name' => 'Test'))); |
| $this->assertEquals(1, $taskCreationModel->create(array('project_id' => 1 , 'title' => 'test'))); |
|
|
| $this->assertEquals(1, $projectRoleModel->create(1, 'Custom Role')); |
| $this->assertTrue($projectUserRole->addUser(1, 2, 'Custom Role')); |
|
|
| $task = $taskFinderModel->getById(1); |
| $this->assertTrue($projectRoleHelper->canChangeAssignee($task)); |
| } |
|
|
| public function testCanChangeTaskStatusInColumnWithProjectViewer() |
| { |
| $projectRoleHelper = new ProjectRoleHelper($this->container); |
| $projectModel = new ProjectModel($this->container); |
| $projectUserRole = new ProjectUserRoleModel($this->container); |
| $userModel = new UserModel($this->container); |
|
|
| $_SESSION['user'] = array( |
| 'id' => 2, |
| 'role' => Role::APP_USER, |
| ); |
|
|
| $this->assertEquals(2, $userModel->create(array('username' => 'user'))); |
| $this->assertEquals(1, $projectModel->create(array('name' => 'Test'))); |
| $this->assertTrue($projectUserRole->addUser(1, 2, Role::PROJECT_VIEWER)); |
|
|
| $this->assertFalse($projectRoleHelper->canChangeTaskStatusInColumn(1, 1)); |
| } |
|
|
| public function testCanChangeTaskStatusInColumnWithProjectMember() |
| { |
| $projectRoleHelper = new ProjectRoleHelper($this->container); |
| $projectModel = new ProjectModel($this->container); |
| $projectUserRole = new ProjectUserRoleModel($this->container); |
| $userModel = new UserModel($this->container); |
|
|
| $_SESSION['user'] = array( |
| 'id' => 2, |
| 'role' => Role::APP_USER, |
| ); |
|
|
| $this->assertEquals(2, $userModel->create(array('username' => 'user'))); |
| $this->assertEquals(1, $projectModel->create(array('name' => 'Test'))); |
| $this->assertTrue($projectUserRole->addUser(1, 2, Role::PROJECT_MEMBER)); |
|
|
| $this->assertTrue($projectRoleHelper->canChangeTaskStatusInColumn(1, 1)); |
| } |
|
|
| public function testCanChangeTaskStatusInColumnWithCustomProjectRole() |
| { |
| $projectRoleHelper = new ProjectRoleHelper($this->container); |
| $projectModel = new ProjectModel($this->container); |
| $projectUserRole = new ProjectUserRoleModel($this->container); |
| $userModel = new UserModel($this->container); |
| $projectRoleModel = new ProjectRoleModel($this->container); |
|
|
| $_SESSION['user'] = array( |
| 'id' => 2, |
| 'role' => Role::APP_USER, |
| ); |
|
|
| $this->assertEquals(2, $userModel->create(array('username' => 'user'))); |
| $this->assertEquals(1, $projectModel->create(array('name' => 'Test'))); |
|
|
| $this->assertEquals(1, $projectRoleModel->create(1, 'Custom Role')); |
| $this->assertTrue($projectUserRole->addUser(1, 2, 'Custom Role')); |
|
|
| $this->assertTrue($projectRoleHelper->canChangeTaskStatusInColumn(1, 1)); |
| } |
|
|
| public function testCanChangeTaskStatusInColumnWithCustomProjectRoleAndRestrictions() |
| { |
| $projectRoleHelper = new ProjectRoleHelper($this->container); |
| $projectModel = new ProjectModel($this->container); |
| $projectUserRole = new ProjectUserRoleModel($this->container); |
| $userModel = new UserModel($this->container); |
| $projectRoleModel = new ProjectRoleModel($this->container); |
| $projectRoleRestrictionModel = new ProjectRoleRestrictionModel($this->container); |
| $columnRestrictionModel = new ColumnRestrictionModel($this->container); |
|
|
| $_SESSION['user'] = array( |
| 'id' => 2, |
| 'role' => Role::APP_USER, |
| ); |
|
|
| $this->assertEquals(2, $userModel->create(array('username' => 'user'))); |
| $this->assertEquals(1, $projectModel->create(array('name' => 'Test'))); |
|
|
| $this->assertEquals(1, $projectRoleModel->create(1, 'Custom Role')); |
| $this->assertTrue($projectUserRole->addUser(1, 2, 'Custom Role')); |
|
|
| $this->assertEquals(1, $projectRoleRestrictionModel->create(1, 1, ProjectRoleRestrictionModel::RULE_TASK_OPEN_CLOSE)); |
| $this->assertEquals(1, $columnRestrictionModel->create(1, 1, 1, ColumnRestrictionModel::RULE_ALLOW_TASK_OPEN_CLOSE)); |
|
|
| $this->assertTrue($projectRoleHelper->canChangeTaskStatusInColumn(1, 1)); |
| $this->assertFalse($projectRoleHelper->canChangeTaskStatusInColumn(1, 2)); |
| } |
|
|
| public function testIsDraggableWithProjectMember() |
| { |
| $projectRoleHelper = new ProjectRoleHelper($this->container); |
| $projectModel = new ProjectModel($this->container); |
| $taskCreationModel = new TaskCreationModel($this->container); |
| $taskFinderModel = new TaskFinderModel($this->container); |
| $projectUserRole = new ProjectUserRoleModel($this->container); |
| $userModel = new UserModel($this->container); |
|
|
| $_SESSION['user'] = array( |
| 'id' => 2, |
| 'role' => Role::APP_USER, |
| ); |
|
|
| $this->assertEquals(2, $userModel->create(array('username' => 'user'))); |
| $this->assertEquals(1, $projectModel->create(array('name' => 'Test'))); |
| $this->assertTrue($projectUserRole->addUser(1, 2, Role::PROJECT_MEMBER)); |
| $this->assertEquals(1, $taskCreationModel->create(array('project_id' => 1, 'title' => 'test'))); |
|
|
| $task = $taskFinderModel->getById(1); |
| $this->assertTrue($projectRoleHelper->isDraggable($task)); |
| } |
|
|
| public function testIsDraggableWithClosedTask() |
| { |
| $projectRoleHelper = new ProjectRoleHelper($this->container); |
| $projectModel = new ProjectModel($this->container); |
| $taskCreationModel = new TaskCreationModel($this->container); |
| $taskFinderModel = new TaskFinderModel($this->container); |
| $taskStatusModel = new TaskStatusModel($this->container); |
| $projectUserRole = new ProjectUserRoleModel($this->container); |
| $userModel = new UserModel($this->container); |
|
|
| $_SESSION['user'] = array( |
| 'id' => 2, |
| 'role' => Role::APP_USER, |
| ); |
|
|
| $this->assertEquals(2, $userModel->create(array('username' => 'user'))); |
| $this->assertEquals(1, $projectModel->create(array('name' => 'Test'))); |
| $this->assertTrue($projectUserRole->addUser(1, 2, Role::PROJECT_MEMBER)); |
| $this->assertEquals(1, $taskCreationModel->create(array('project_id' => 1, 'title' => 'test'))); |
| $this->assertTrue($taskStatusModel->close(1)); |
|
|
| $task = $taskFinderModel->getById(1); |
| $this->assertFalse($projectRoleHelper->isDraggable($task)); |
| } |
|
|
| public function testIsDraggableWithColumnRestrictions() |
| { |
| $projectRoleHelper = new ProjectRoleHelper($this->container); |
| $projectModel = new ProjectModel($this->container); |
| $taskCreationModel = new TaskCreationModel($this->container); |
| $taskFinderModel = new TaskFinderModel($this->container); |
| $projectUserRole = new ProjectUserRoleModel($this->container); |
| $userModel = new UserModel($this->container); |
| $projectRoleModel = new ProjectRoleModel($this->container); |
| $columnMoveRestrictionModel = new ColumnMoveRestrictionModel($this->container); |
|
|
| $_SESSION['user'] = array( |
| 'id' => 2, |
| 'role' => Role::APP_USER, |
| ); |
|
|
| $this->assertEquals(2, $userModel->create(array('username' => 'user'))); |
| $this->assertEquals(1, $projectModel->create(array('name' => 'Test'))); |
|
|
| $this->assertEquals(1, $projectRoleModel->create(1, 'Custom Role')); |
| $this->assertEquals(1, $columnMoveRestrictionModel->create(1, 1, 2, 3)); |
|
|
| $this->assertTrue($projectUserRole->addUser(1, 2, 'Custom Role')); |
| $this->assertEquals(1, $taskCreationModel->create(array('project_id' => 1, 'title' => 'test', 'column_id' => 1))); |
| $this->assertEquals(2, $taskCreationModel->create(array('project_id' => 1, 'title' => 'test', 'column_id' => 2))); |
| $this->assertEquals(3, $taskCreationModel->create(array('project_id' => 1, 'title' => 'test', 'column_id' => 3))); |
| $this->assertEquals(4, $taskCreationModel->create(array('project_id' => 1, 'title' => 'test', 'column_id' => 4))); |
|
|
| $task = $taskFinderModel->getById(1); |
| $this->assertFalse($projectRoleHelper->isDraggable($task)); |
|
|
| $task = $taskFinderModel->getById(2); |
| $this->assertTrue($projectRoleHelper->isDraggable($task)); |
|
|
| $task = $taskFinderModel->getById(3); |
| $this->assertTrue($projectRoleHelper->isDraggable($task)); |
|
|
| $task = $taskFinderModel->getById(4); |
| $this->assertFalse($projectRoleHelper->isDraggable($task)); |
| } |
|
|
| public function testCanRemoveTask() |
| { |
| $taskCreationModel = new TaskCreationModel($this->container); |
| $taskFinderModel = new TaskFinderModel($this->container); |
| $projectRoleHelper = new ProjectRoleHelper($this->container); |
| $projectModel = new ProjectModel($this->container); |
| $userModel = new UserModel($this->container); |
| $userSessionModel = new UserSession($this->container); |
|
|
| $this->assertNotFalse($userModel->create(array('username' => 'toto', 'password' => '123456'))); |
| $this->assertNotFalse($userModel->create(array('username' => 'toto2', 'password' => '123456'))); |
| $this->assertEquals(1, $projectModel->create(array('name' => 'Project #1'))); |
| $this->assertEquals(1, $taskCreationModel->create(array('title' => 'TaskViewController #1', 'project_id' => 1, 'creator_id' => 1))); |
| $this->assertEquals(2, $taskCreationModel->create(array('title' => 'TaskViewController #2', 'project_id' => 1, 'creator_id' => 2))); |
| $this->assertEquals(3, $taskCreationModel->create(array('title' => 'TaskViewController #3', 'project_id' => 1, 'creator_id' => 3))); |
| $this->assertEquals(4, $taskCreationModel->create(array('title' => 'TaskViewController #4', 'project_id' => 1))); |
|
|
| |
| $user = $userModel->getById(1); |
| $this->assertNotEmpty($user); |
| $userSessionModel->initialize($user); |
|
|
| $task = $taskFinderModel->getById(1); |
| $this->assertNotEmpty($task); |
| $this->assertTrue($projectRoleHelper->canRemoveTask($task)); |
|
|
| |
| $user = $userModel->getById(2); |
| $this->assertNotEmpty($user); |
| $userSessionModel->initialize($user); |
|
|
| $task = $taskFinderModel->getById(1); |
| $this->assertNotEmpty($task); |
| $this->assertFalse($projectRoleHelper->canRemoveTask($task)); |
|
|
| |
| $user = $userModel->getById(1); |
| $this->assertNotEmpty($user); |
| $userSessionModel->initialize($user); |
|
|
| $task = $taskFinderModel->getById(2); |
| $this->assertNotEmpty($task); |
| $this->assertTrue($projectRoleHelper->canRemoveTask($task)); |
|
|
| |
| $user = $userModel->getById(2); |
| $this->assertNotEmpty($user); |
| $userSessionModel->initialize($user); |
|
|
| $task = $taskFinderModel->getById(2); |
| $this->assertNotEmpty($task); |
| $this->assertTrue($projectRoleHelper->canRemoveTask($task)); |
|
|
| |
| $user = $userModel->getById(1); |
| $this->assertNotEmpty($user); |
| $userSessionModel->initialize($user); |
|
|
| $task = $taskFinderModel->getById(3); |
| $this->assertNotEmpty($task); |
| $this->assertTrue($projectRoleHelper->canRemoveTask($task)); |
|
|
| |
| $user = $userModel->getById(2); |
| $this->assertNotEmpty($user); |
| $userSessionModel->initialize($user); |
|
|
| $task = $taskFinderModel->getById(3); |
| $this->assertNotEmpty($task); |
| $this->assertFalse($projectRoleHelper->canRemoveTask($task)); |
|
|
| |
| $user = $userModel->getById(1); |
| $this->assertNotEmpty($user); |
| $userSessionModel->initialize($user); |
|
|
| $task = $taskFinderModel->getById(4); |
| $this->assertNotEmpty($task); |
| $this->assertTrue($projectRoleHelper->canRemoveTask($task)); |
|
|
| |
| $user = $userModel->getById(2); |
| $this->assertNotEmpty($user); |
| $userSessionModel->initialize($user); |
|
|
| $task = $taskFinderModel->getById(4); |
| $this->assertNotEmpty($task); |
| $this->assertFalse($projectRoleHelper->canRemoveTask($task)); |
| } |
| } |
|
|