<?php require_once __DIR__.'/../Base.php'; use Kanboard\Model\ProjectPermissionModel; use Kanboard\Model\ProjectModel; use Kanboard\Model\UserModel; use Kanboard\Model\GroupModel; use Kanboard\Model\GroupMemberModel; use Kanboard\Model\ProjectGroupRoleModel; use Kanboard\Model\ProjectUserRoleModel; use Kanboard\Core\Security\Role; class ProjectPermissionModelTest extends Base { public function testFindByUsernames() { $userModel = new UserModel($this->container); $projectModel = new ProjectModel($this->container); $groupModel = new GroupModel($this->container); $groupMemberModel = new GroupMemberModel($this->container); $groupRoleModel = new ProjectGroupRoleModel($this->container); $userRoleModel = new ProjectUserRoleModel($this->container); $projectPermissionModel = new ProjectPermissionModel($this->container); $this->assertEquals(1, $projectModel->create(array('name' => 'Project 1'))); $this->assertEquals(2, $userModel->create(array('username' => 'user1'))); $this->assertEquals(3, $userModel->create(array('username' => 'user2', 'name' => 'User 2', 'email' => 'test@here', 'avatar_path' => 'test'))); $this->assertEquals(4, $userModel->create(array('username' => 'user3'))); $this->assertEquals(1, $groupModel->create('Group A')); $this->assertTrue($groupMemberModel->addUser(1, 2)); $this->assertTrue($groupRoleModel->addGroup(1, 1, Role::PROJECT_MEMBER)); $this->assertTrue($userRoleModel->addUser(1, 3, Role::PROJECT_MANAGER)); $expected = array( 'user1' => array( 'username' => 'user1', 'name' => null, 'email' => null, 'avatar_path' => null, 'id' => '2', ), 'user2' => array( 'username' => 'user2', 'name' => 'User 2', 'email' => 'test@here', 'avatar_path' => 'test', 'id' => '3', ) ); $this->assertEquals($expected, $projectPermissionModel->findUsernames(1, 'us')); $this->assertEmpty($projectPermissionModel->findUsernames(1, 'a')); $this->assertEmpty($projectPermissionModel->findUsernames(2, 'user')); } public function testGetQueryByRole() { $userModel = new UserModel($this->container); $projectModel = new ProjectModel($this->container); $userRoleModel = new ProjectUserRoleModel($this->container); $projectPermission = new ProjectPermissionModel($this->container); $this->assertEquals(1, $projectModel->create(array('name' => 'Project 1'))); $this->assertEquals(2, $projectModel->create(array('name' => 'Project 2'))); $this->assertEquals(3, $projectModel->create(array('name' => 'Project 3'))); $this->assertEquals(2, $userModel->create(array('username' => 'user 1'))); $this->assertEquals(3, $userModel->create(array('username' => 'user 2'))); $this->assertEquals(4, $userModel->create(array('username' => 'user 3'))); $this->assertEquals(5, $userModel->create(array('username' => 'user 4'))); $this->assertTrue($userRoleModel->addUser(1, 2, Role::PROJECT_MANAGER)); $this->assertTrue($userRoleModel->addUser(1, 3, Role::PROJECT_MANAGER)); $this->assertTrue($userRoleModel->addUser(1, 4, Role::PROJECT_MEMBER)); $this->assertTrue($userRoleModel->addUser(1, 5, Role::PROJECT_MEMBER)); $this->assertTrue($userRoleModel->addUser(2, 2, Role::PROJECT_MEMBER)); $this->assertTrue($userRoleModel->addUser(2, 3, Role::PROJECT_MEMBER)); $this->assertTrue($userRoleModel->addUser(2, 5, Role::PROJECT_MANAGER)); $this->assertTrue($userRoleModel->addUser(3, 4, Role::PROJECT_MANAGER)); $this->assertTrue($userRoleModel->addUser(3, 5, Role::PROJECT_VIEWER)); $this->assertEmpty($projectPermission->getQueryByRole(array(), Role::PROJECT_MANAGER)->findAll()); $users = $projectPermission->getQueryByRole(array(1, 2), Role::PROJECT_MANAGER)->findAll(); $this->assertCount(3, $users); $this->assertEquals('user 1', $users[0]['username']); $this->assertEquals('Project 1', $users[0]['project_name']); $this->assertEquals('user 2', $users[1]['username']); $this->assertEquals('Project 1', $users[1]['project_name']); $this->assertEquals('user 4', $users[2]['username']); $this->assertEquals('Project 2', $users[2]['project_name']); $users = $projectPermission->getQueryByRole(array(1), Role::PROJECT_MANAGER)->findAll(); $this->assertCount(2, $users); $this->assertEquals('user 1', $users[0]['username']); $this->assertEquals('Project 1', $users[0]['project_name']); $this->assertEquals('user 2', $users[1]['username']); $this->assertEquals('Project 1', $users[1]['project_name']); $users = $projectPermission->getQueryByRole(array(1, 2, 3), Role::PROJECT_MEMBER)->findAll(); $this->assertCount(4, $users); $this->assertEquals('user 3', $users[0]['username']); $this->assertEquals('Project 1', $users[0]['project_name']); $this->assertEquals('user 4', $users[1]['username']); $this->assertEquals('Project 1', $users[1]['project_name']); $this->assertEquals('user 1', $users[2]['username']); $this->assertEquals('Project 2', $users[2]['project_name']); $this->assertEquals('user 2', $users[3]['username']); $this->assertEquals('Project 2', $users[3]['project_name']); $users = $projectPermission->getQueryByRole(array(1, 2, 3), Role::PROJECT_VIEWER)->findAll(); $this->assertCount(1, $users); $this->assertEquals('user 4', $users[0]['username']); $this->assertEquals('Project 3', $users[0]['project_name']); } public function testEverybodyAllowed() { $projectModel = new ProjectModel($this->container); $projectPermission = new ProjectPermissionModel($this->container); $this->assertEquals(1, $projectModel->create(array('name' => 'Project 1'))); $this->assertEquals(2, $projectModel->create(array('name' => 'Project 2', 'is_everybody_allowed' => 1))); $this->assertFalse($projectPermission->isEverybodyAllowed(1)); $this->assertTrue($projectPermission->isEverybodyAllowed(2)); } public function testIsUserAllowed() { $userModel = new UserModel($this->container); $projectModel = new ProjectModel($this->container); $groupModel = new GroupModel($this->container); $groupRoleModel = new ProjectGroupRoleModel($this->container); $groupMemberModel = new GroupMemberModel($this->container); $userRoleModel = new ProjectUserRoleModel($this->container); $projectPermission = new ProjectPermissionModel($this->container); $this->assertEquals(2, $userModel->create(array('username' => 'user 1'))); $this->assertEquals(3, $userModel->create(array('username' => 'user 2'))); $this->assertEquals(4, $userModel->create(array('username' => 'user 3'))); $this->assertEquals(5, $userModel->create(array('username' => 'user 4'))); $this->assertEquals(1, $projectModel->create(array('name' => 'Project 1'))); $this->assertEquals(2, $projectModel->create(array('name' => 'Project 2'))); $this->assertEquals(1, $groupModel->create('Group A')); $this->assertTrue($groupMemberModel->addUser(1, 2)); $this->assertTrue($groupRoleModel->addGroup(1, 1, Role::PROJECT_VIEWER)); $this->assertTrue($userRoleModel->addUser(1, 3, Role::PROJECT_MEMBER)); $this->assertTrue($userRoleModel->addUser(1, 4, Role::PROJECT_MANAGER)); $this->assertTrue($projectPermission->isUserAllowed(1, 2)); $this->assertTrue($projectPermission->isUserAllowed(1, 3)); $this->assertTrue($projectPermission->isUserAllowed(1, 4)); $this->assertFalse($projectPermission->isUserAllowed(1, 5)); $this->assertFalse($projectPermission->isUserAllowed(2, 2)); $this->assertFalse($projectPermission->isUserAllowed(2, 3)); $this->assertFalse($projectPermission->isUserAllowed(2, 4)); $this->assertFalse($projectPermission->isUserAllowed(2, 5)); } public function testIsAssignable() { $userModel = new UserModel($this->container); $projectModel = new ProjectModel($this->container); $groupModel = new GroupModel($this->container); $groupRoleModel = new ProjectGroupRoleModel($this->container); $groupMemberModel = new GroupMemberModel($this->container); $userRoleModel = new ProjectUserRoleModel($this->container); $projectPermission = new ProjectPermissionModel($this->container); $this->assertEquals(2, $userModel->create(array('username' => 'user 1'))); $this->assertEquals(3, $userModel->create(array('username' => 'user 2'))); $this->assertEquals(4, $userModel->create(array('username' => 'user 3'))); $this->assertEquals(5, $userModel->create(array('username' => 'user 4'))); $this->assertEquals(1, $projectModel->create(array('name' => 'Project 1'))); $this->assertEquals(2, $projectModel->create(array('name' => 'Project 2'))); $this->assertEquals(1, $groupModel->create('Group A')); $this->assertTrue($groupMemberModel->addUser(1, 2)); $this->assertTrue($groupRoleModel->addGroup(1, 1, Role::PROJECT_VIEWER)); $this->assertTrue($userRoleModel->addUser(1, 3, Role::PROJECT_MEMBER)); $this->assertTrue($userRoleModel->addUser(1, 4, Role::PROJECT_MANAGER)); $this->assertFalse($projectPermission->isAssignable(1, 2)); $this->assertTrue($projectPermission->isAssignable(1, 3)); $this->assertTrue($projectPermission->isAssignable(1, 4)); $this->assertFalse($projectPermission->isAssignable(1, 5)); $this->assertFalse($projectPermission->isAssignable(2, 2)); $this->assertFalse($projectPermission->isAssignable(2, 3)); $this->assertFalse($projectPermission->isAssignable(2, 4)); $this->assertFalse($projectPermission->isAssignable(2, 5)); } public function testIsAssignableWhenUserIsDisabled() { $userModel = new UserModel($this->container); $projectModel = new ProjectModel($this->container); $userRoleModel = new ProjectUserRoleModel($this->container); $projectPermission = new ProjectPermissionModel($this->container); $this->assertEquals(2, $userModel->create(array('username' => 'user 1'))); $this->assertEquals(3, $userModel->create(array('username' => 'user 2', 'is_active' => 0))); $this->assertEquals(1, $projectModel->create(array('name' => 'Project 1'))); $this->assertTrue($userRoleModel->addUser(1, 2, Role::PROJECT_MEMBER)); $this->assertTrue($userRoleModel->addUser(1, 3, Role::PROJECT_MEMBER)); $this->assertTrue($projectPermission->isAssignable(1, 2)); $this->assertFalse($projectPermission->isAssignable(1, 3)); } public function testIsMember() { $userModel = new UserModel($this->container); $projectModel = new ProjectModel($this->container); $groupModel = new GroupModel($this->container); $groupRoleModel = new ProjectGroupRoleModel($this->container); $groupMemberModel = new GroupMemberModel($this->container); $userRoleModel = new ProjectUserRoleModel($this->container); $projectPermission = new ProjectPermissionModel($this->container); $this->assertEquals(2, $userModel->create(array('username' => 'user 1'))); $this->assertEquals(3, $userModel->create(array('username' => 'user 2'))); $this->assertEquals(4, $userModel->create(array('username' => 'user 3'))); $this->assertEquals(5, $userModel->create(array('username' => 'user 4'))); $this->assertEquals(1, $projectModel->create(array('name' => 'Project 1'))); $this->assertEquals(2, $projectModel->create(array('name' => 'Project 2'))); $this->assertEquals(1, $groupModel->create('Group A')); $this->assertTrue($groupMemberModel->addUser(1, 2)); $this->assertTrue($groupRoleModel->addGroup(1, 1, Role::PROJECT_VIEWER)); $this->assertTrue($userRoleModel->addUser(1, 3, Role::PROJECT_MEMBER)); $this->assertTrue($userRoleModel->addUser(1, 4, Role::PROJECT_MANAGER)); $this->assertTrue($projectPermission->isMember(1, 2)); $this->assertTrue($projectPermission->isMember(1, 3)); $this->assertTrue($projectPermission->isMember(1, 4)); $this->assertFalse($projectPermission->isMember(1, 5)); $this->assertFalse($projectPermission->isMember(2, 2)); $this->assertFalse($projectPermission->isMember(2, 3)); $this->assertFalse($projectPermission->isMember(2, 4)); $this->assertFalse($projectPermission->isMember(2, 5)); } public function testGetActiveProjectIds() { $userModel = new UserModel($this->container); $projectModel = new ProjectModel($this->container); $userRoleModel = new ProjectUserRoleModel($this->container); $projectPermission = new ProjectPermissionModel($this->container); $this->assertEquals(2, $userModel->create(array('username' => 'user 1'))); $this->assertEquals(3, $userModel->create(array('username' => 'user 2'))); $this->assertEquals(1, $projectModel->create(array('name' => 'Project 1'))); $this->assertEquals(2, $projectModel->create(array('name' => 'Project 2', 'is_active' => 0))); $this->assertTrue($userRoleModel->addUser(1, 2, Role::PROJECT_MEMBER)); $this->assertTrue($userRoleModel->addUser(2, 2, Role::PROJECT_VIEWER)); $this->assertTrue($userRoleModel->addUser(1, 3, Role::PROJECT_VIEWER)); $this->assertEmpty($projectPermission->getActiveProjectIds(1)); $this->assertEquals(array(1), $projectPermission->getActiveProjectIds(2)); $this->assertEquals(array(1), $projectPermission->getActiveProjectIds(3)); } public function testGetProjectIds() { $userModel = new UserModel($this->container); $projectModel = new ProjectModel($this->container); $userRoleModel = new ProjectUserRoleModel($this->container); $projectPermission = new ProjectPermissionModel($this->container); $this->assertEquals(2, $userModel->create(array('username' => 'user 1'))); $this->assertEquals(3, $userModel->create(array('username' => 'user 2'))); $this->assertEquals(1, $projectModel->create(array('name' => 'Project 1'))); $this->assertEquals(2, $projectModel->create(array('name' => 'Project 2', 'is_active' => 0))); $this->assertTrue($userRoleModel->addUser(1, 2, Role::PROJECT_MEMBER)); $this->assertTrue($userRoleModel->addUser(2, 2, Role::PROJECT_MEMBER)); $this->assertTrue($userRoleModel->addUser(1, 3, Role::PROJECT_MEMBER)); $this->assertTrue($userRoleModel->addUser(2, 3, Role::PROJECT_MEMBER)); $this->assertEmpty($projectPermission->getProjectIds(1)); $this->assertEquals(array(1, 2), $projectPermission->getProjectIds(2)); $this->assertEquals(array(1, 2), $projectPermission->getProjectIds(3)); } public function testDuplicate() { $userModel = new UserModel($this->container); $projectModel = new ProjectModel($this->container); $groupModel = new GroupModel($this->container); $groupMemberModel = new GroupMemberModel($this->container); $groupRoleModel = new ProjectGroupRoleModel($this->container); $userRoleModel = new ProjectUserRoleModel($this->container); $projectPermission = new ProjectPermissionModel($this->container); $this->assertEquals(1, $projectModel->create(array('name' => 'Project 1'))); $this->assertEquals(2, $projectModel->create(array('name' => 'Project 2'))); $this->assertEquals(2, $userModel->create(array('username' => 'user 1', 'name' => 'User #1'))); $this->assertEquals(3, $userModel->create(array('username' => 'user 2'))); $this->assertEquals(4, $userModel->create(array('username' => 'user 3'))); $this->assertEquals(5, $userModel->create(array('username' => 'user 4'))); $this->assertEquals(6, $userModel->create(array('username' => 'user 5', 'name' => 'User #5'))); $this->assertEquals(1, $groupModel->create('Group C')); $this->assertEquals(2, $groupModel->create('Group B')); $this->assertEquals(3, $groupModel->create('Group A')); $this->assertTrue($groupMemberModel->addUser(1, 4)); $this->assertTrue($groupMemberModel->addUser(2, 5)); $this->assertTrue($groupMemberModel->addUser(3, 3)); $this->assertTrue($groupMemberModel->addUser(3, 2)); $this->assertTrue($groupRoleModel->addGroup(1, 1, Role::PROJECT_VIEWER)); $this->assertTrue($groupRoleModel->addGroup(1, 3, Role::PROJECT_MANAGER)); $this->assertTrue($userRoleModel->addUser(1, 5, Role::PROJECT_MANAGER)); $this->assertTrue($userRoleModel->addUser(1, 6, Role::PROJECT_MEMBER)); $this->assertTrue($projectPermission->duplicate(1, 2)); $this->assertCount(2, $userRoleModel->getUsers(2)); $this->assertCount(3, $groupRoleModel->getUsers(2)); } }