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/inc/lib/database.lib.test.php

311 lines
8.4 KiB

<?php
require_once(api_get_path(LIBRARY_PATH).'database.lib.php');
require_once(api_get_path(LIBRARY_PATH).'add_course.lib.inc.php');
require_once(api_get_path(LIBRARY_PATH).'course.lib.php');
class TestDatabase extends UnitTestCase {
public $dbase;
public function TestDatabase() {
$this->UnitTestCase('Database library - main/inc/lib/database.lib.test.php');
}
public function setUp() {
global $_configuration;
$this->dbase = new Database();
}
public function tearDown() {
$this->dbase = null;
}
public function testAffectedRows() {
$res=$this->dbase->affected_rows();
$this->assertTrue(is_numeric($res));
}
public function testCountRows() {
$table='class';
$res=$this->dbase->count_rows($table);
if(!is_string($res)){
$this->assertTrue(is_numeric($res));
}
}
public function testError() {
$res=$this->dbase->error();
$this->assertTrue(is_string($res));
}
public function testEscapeString() {
$string='Lore"May';
$res=$this->dbase->escape_string($string);
$this->assertTrue(is_string($res));
}
public function testFetchArray() {
$sql = 'select 1';
$res=Database::query($sql);
$resu=$this->dbase->fetch_array($res);
$this->assertTrue(is_array($resu));
$this->assertFalse(is_null($resu));
}
public function testFetchArrayError() {
$sql = 'SELECT 1';
$res=Database::query($sql);
$resu=$this->dbase->fetch_array($res);
$this->assertTrue(is_array($resu));
}
function testFetchObject() {
$sql = 'SELECT 1';
$res=Database::query($sql);
$resu=$this->dbase->fetch_object($res);
$this->assertTrue(is_object($resu));
}
function testFetchRow() {
$sql = 'SELECT 1';
$res=Database::query($sql);
$resu=$this->dbase->fetch_row($res);
$this->assertTrue(is_array($resu));
}
/* // Contains a private unaccessible method, Database::fix_database_parameter().
function testFixDatabaseParameterEmpty() {
$course_info = api_get_course_info();
$database_name= $course_info[""];
$res=$this->dbase->fix_database_parameter($database_name);
if(!is_null($res)) :
$this->assertTrue(is_string($res));
endif;
//var_dump($res);
}
*/
/* // Contains a private unaccessible method, Database::fix_database_parameter().
function testFixDatabaseParameterReturnString() {
$course_info = api_get_course_info();
$database_name= $course_info["dbName"];
$res=$this->dbase->fix_database_parameter($course_info);
$this->assertTrue(is_string($res));
}
*/
/* // Contains a private unaccessible method, Database::format_glued_course_table_name().
function testFormatGluedCourseTableName() {
$database_name_with_glue='';
$table='';
$res=$this->dbase->format_glued_course_table_name($database_name_with_glue, $table);
$this->assertTrue(is_string($res));
}
*/
/* // Contains a private unaccessible method, Database::format_table_name().
function testFormatTableName() {
$database='';
$table='';
$res=$this->dbase->format_table_name($database, $table);
$this->assertTrue(is_string($res));
}
*/
function testGenerateAbstractCourseFieldNames() {
$result_array='';
$res=$this->dbase->generate_abstract_course_field_names($result_array);
$this->assertTrue(is_array($res));
}
function testGenerateAbstractUserFieldNames() {
$result_array='';
$res=$this->dbase->generate_abstract_user_field_names($result_array);
$this->assertTrue(is_array($res));
}
function get_course_by_category() {
$category_id='1';
$res=$this->dbase->get_course_by_category($category_id);
$this->assertTrue(is_string($res));
}
function testGetCourseChatConnectedTable() {
$database_name='dokeosla';
$res=$this->dbase->get_course_chat_connected_table($database_name);
$this->assertTrue(is_string($res));
}
function testGetCourseInfo() {
$course_code='AYDD';
$res=$this->dbase->get_course_info($course_code);
$this->assertTrue(is_array($res));
}
function testGetCourseList() {
$sql_query = "SELECT * FROM $table";
$res=$this->dbase->get_course_list($sql_query);
$this->assertTrue(is_array($res));
}
function testGetCourseTable() {
$short_table_name='';
$database_name='';
$res=$this->dbase->get_course_table($short_table_name,$database_name);
$this->assertTrue(is_string($res));
}
function testGetCourseTableFromCode() {
$course_code='AYDD';
$table='course';
$ret = NULL;
$res=$this->dbase->get_course_table_from_code($course_code, $table);
$this->assertTrue(is_string($res));
}
function testGetCourseTablePrefix() {
global $_configuration;
$res=$this->dbase->get_course_table_prefix($_configuration);
$this->assertTrue(is_string($res));
}
function testGetCurrentCourseDatabase() {
$res=$this->dbase->get_current_course_database();
if (empty($GLOBALS['_course']['dbName'])) {
$this->assertFalse($res);
} else {
$this->assertTrue(is_string($res));
}
$res=$this->dbase->get_current_course_database('___');
$this->assertFalse($res);
}
function testGetCurrentCourseGluedDatabase() {
$res=$this->dbase->get_current_course_glued_database();
if (empty($GLOBALS['_course']['dbName'])) {
$this->assertFalse($res);
} else {
$this->assertTrue(is_string($res));
}
$res=$this->dbase->get_current_course_glued_database('___');
$this->assertFalse($res);
}
function testGetDatabaseGlue()
{
global $_configuration;
$res=$this->dbase->get_database_glue($_configuration);
$this->assertTrue(is_string($res));
}
function testGetDatabaseNamePrefix() {
global $_configuration;
$res=$this->dbase->get_database_name_prefix($_configuration);
$this->assertTrue(is_string($res));
}
function testGetMainDatabase() {
global $_configuration;
$res=$this->dbase->get_main_database();
$this->assertTrue(is_string($res));
}
function testGetMainTable() {
$short_table_name='';
$res=$this->dbase->get_main_table($short_table_name);
$this->assertTrue(is_string($res));
}
function testGetScormDatabase() {
global $_configuration;
$res=$this->dbase->get_scorm_database();
$this->assertTrue(is_string($res));
}
function testGetScorm_table() {
$short_table_name='';
$res=$this->dbase->get_scorm_table($short_table_name);
$this->assertTrue(is_string($res));
$this->assertTrue($res);
}
function testGetStatisticDatabase() {
global $_configuration;
$res=$this->dbase->get_statistic_database($_configuration);
$this->assertTrue(is_string($res));
$this->assertTrue($res);
}
function testGetStatisticTable() {
$short_table_name='';
$res=$this->dbase->get_statistic_table($short_table_name);
$this->assertTrue(is_string($res));
$this->assertTrue($res);
}
function testGetUserInfoFromId() {
$res=$this->dbase->get_user_info_from_id(1);
$this->assertTrue(is_array($res));
// should be returning GLOBALS[_user] (=null) if param is null (in testing context)
$res=$this->dbase->get_user_info_from_id(null);
$this->assertNull($res);
// should be returning array with empty values if user doesn't exist
$res=$this->dbase->get_user_info_from_id(5000000);
$this->assertTrue(is_array($res));
$this->assertNull($res['mail']);
}
function testGetUserPersonalDatabase() {
global $_configuration;
$res=$this->dbase->get_user_personal_database($_configuration);
$this->assertTrue(is_string($res));
$this->assertTrue($res);
}
function testGetUserPersonalTable(){
$short_table_name='';
$res=$this->dbase-> get_user_personal_table($short_table_name);
$this->assertTrue(is_string($res));
$this->assertTrue($res);
}
/* // Contains a private unaccessible method, Database::glue_course_database_name().
function testGlueCourseDatabaseName() {
$database_name='';
$res=$this->dbase->glue_course_database_name($database_name);
$this->assertTrue(is_string($res));
$this->assertTrue($res);
}
*/
function testInsertId() {
$res = $this->dbase->insert_id();
$this->assertTrue(is_numeric($res));
}
function testNumRows() {
$sql = 'SELECT * FROM user';
$res = Database::query($sql);
$resul=Database::num_rows($res);
$this->assertTrue(is_numeric($resul));
}
function testQuery() {
$sql = 'SELECT 1';
$res = Database::query($sql);
$this->assertTrue(is_resource($res));
}
function testResult() {
$sql = 'SELECT email FROM user';
$resource = Database::query($sql);
$res = Database::result($resource, 1);
$this->assertTrue(is_string($res));
}
function testStoreResult(){
$sql = 'SELECT 1';
$resource = $this->dbase->query($sql);
$res = $this->dbase->store_result($resource);
$this->assertTrue(is_array($res));
}
}
?>