| | <?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)); |
| | } |
| | } |
| |
|