Chamilo is a learning management system focused on ease of use and accessibility
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
chamilo-lms/tests/main/permissions/permissions_functions.inc.t...

235 lines
7.7 KiB

<?php
require_once api_get_path(SYS_CODE_PATH).'permissions/permissions_functions.inc.php';
//require_once dirname(__FILE__).'/../main/permissions/permissions_functions.inc.php';
class TestPermissions extends UnitTestCase {
public function __construct() {
$this->UnitTestCase('Permissions library - main/permissions/permissions_functions.inc.test.php');
}
/**
* This function is called when we assign a role to a user or a group
* @param string
* @param string
* @param int
* @param int
* @return string
*/
function testAssignRole(){
$content='';
$action='';
$id=1;
$role_id=1;
$scope='course';
$res = assign_role($content, $action, $id, $role_id, $scope);
$this->assertTrue(is_string($res));
//var_dump($res);
}
/**
This function displays a checked or unchecked checkbox. The checkbox will be checked if the
* user, group or role has the permission for the given tool, unchecked if the user, group or role
* does not have the right
* @param array
* @param string
* @param string
* @param array
* @return null
*/
function testDisplayCheckboxMatrix(){
ob_start();
$permission_array=array();
$tool='';
$permission=1;
$inherited_permissions=array();
$res = display_checkbox_matrix($permission_array, $tool, $permission, $inherited_permissions);
$this->assertTrue(is_null($res));
ob_end_clean();
//var_dump($res);
}
/**
* This function displays a checked or unchecked image. The image will be checked if the
* user, group or role has the permission for the given tool, unchecked if the user, group or role
* does not have the right
* @param $permission_array the array that contains all the permissions of the user, group, role
* @param $tool the tool we want to check a permission for
* @param $permission the permission we want to check for
*/
function testDisplayImageMatrix(){
//ob_start();
$permission_array=array();
$tool=1;
$permission=1;
$inherited_permissions=array($tool => array());
$course_admin=false;
$editable=true;
$res = display_image_matrix($permission_array, $tool, $permission,$inherited_permissions, $course_admin, $editable);
$this->assertTrue(is_null($res));
//ob_end_clean();
//var_dump($res);
}
/**
* Slightly modified: Toon Keppens
* This function displays a checked or unchecked image. The image will be checked if the
* user, group or role has the permission for the given tool, unchecked if the user, group or role
* does not have the right
* @param int
* @param string
* @param string
* @param array
* @param bool
*/
function testDisplayImageMatrixForBlogs(){
$permission_array=array();
$user_id=1;
$tool=1;
$permission=1;
$inherited_permissions=array();
$course_admin=false;
$editable=true;
$res = display_image_matrix_for_blogs($permission_array, $user_id, $tool, $permission,$inherited_permissions, $course_admin, $editable);
$this->assertTrue(is_null($res));
//var_dump($res);
}
/**
* This function displays a list off all the roles of the course (and those defined by the platform admin)
* @param
* @param
*/
function testDisplayRoleList(){
$current_course_roles='';
$current_platform_roles='';
$res = display_role_list($current_course_roles, $current_platform_roles);
$this->assertTrue(is_null($res));
//var_dump($res);
}
/**
* This function gets all the current roles of the user or group
* @param string
* @return array that contains the name of the roles the user has
*/
function testGetAllRoles(){
$content='course';
$res = get_all_roles($content);
if (!is_null($res)){
$this->assertTrue(is_array($res));
}
//var_dump($res);
}
/**
* This function retrieves the existing permissions of a user, group or role.
* @param $content are we retrieving the rights of a user, a group or a role (the database depends on it)
* @param $id the id of the user, group or role
*/
function testGetPermissions(){
$content='user';
$id=1;
$res = get_permissions($content, $id);
$this->assertTrue(is_array($res));
//var_dump($res);
}
/**
* This function gets all the current roles of the user or group
* @param $content are we finding the roles for a user or a group (the database depends on it)
* @param $id the id of the user or group
* @return array that contains the name of the roles the user has
*/
function testGetRoles(){
$content='user';
$id=1;
$scope='course';
$res = get_roles($content, $id, $scope);
$this->assertTrue(is_array($res));
//var_dump($res);
}
/**
* This function gets all the roles that are defined
* @param $content are we finding the roles for a user or a group (the database depends on it)
* @param $id the id of the user or group
* @param string Deprecated parameter allowing use of 'platform' scope - the corresponding tables don't exist anymore so the scope is always set to 'course'
* @return array that contains the name of the roles the user has
*/
function testGetRolesPermissions(){
$content='user';
$id=1;
$scope='course';
$res = get_roles_permissions($content, $id, $scope);
if (!is_null($res)){
$this->assertTrue(is_array($res));
}
//var_dump($res);
}
/**
* the array that contains the current permission a user, group or role has will now be changed depending on
* the Dokeos Config Setting for the permissions (limited [add, edit, delete] or full [view, add, edit, delete, move, visibility]
* @param $content are we retrieving the rights of a user, a group or a role (the database depends on it)
* @param $id the id of the user, group or role
* @author Patrick Cool <patrick.cool@ugent.be>, Ghent University
* @version 1.0
* @todo currently there is a setting user_permissions and group_permissions. We should merge this in one config setting.
*/
function testLimitedOrFull(){
$current_permissions=array();
$res = limited_or_full($current_permissions);
if (!is_null($res)){
$this->assertTrue(is_array($res));
}
//var_dump($res);
}
function testMyPrintR(){
ob_start();
$array='';
$res = my_print_r($array);
$this->assertTrue(is_null($res));
ob_end_clean();
//var_dump($res);
}
/**
* This function merges permission arrays. Each permission array has the following structure
* a permission array has a tool contanst as a key and an array as a value. This value array consists of all the permissions that are granted in that tool.
*/
function testPermissionArrayMerge(){
$array1=array();
$array2=array();
$res = permission_array_merge($array1, $array2);
$this->assertTrue(is_array($res));
//var_dump($res);
}
/**
* This function stores one permission in the correct table.
* @param $content are we storing rights for a user, a group or a role (the database depends on it)
* @param $action are we granting or revoking a permission?
* @param $id the id of the user, group or role
* @param $tool the tool
* @param $permission the permission the user, group or role has been granted or revoked
*/
function testStoreOnePermission(){
$res = store_one_permission('user', 'grant', 2, 'link','');
if(!$res === NULL){
$this->assertTrue(is_string($res));
} else {
$this->assertNull($res);
}
//var_dump($res);
}
/**
* This function stores the permissions in the correct table.
* Since Checkboxes are used we do not know which ones are unchecked.
* That's why we first delete them all (for the given user/group/role
* and afterwards we store the checked ones only.
* @param $content are we storing rights for a user, a group or a role (the database depends on it)
* @param $id the id of the user, group or role
* @author Patrick Cool <patrick.cool@ugent.be>, Ghent University
* @version 1.0
*/
function testStorePermissions(){
$content='user';
$id=1;
$res = store_permissions($content, $id);
$this->assertTrue(is_string($res));
//var_dump($res);
}
}
?>