<?php
require_once(api_get_path(SYS_CODE_PATH).'work/work.lib.php');
require_once(api_get_path(LIBRARY_PATH).'course.lib.php');


class TestWork extends UnitTestCase {


	/**
	 * @param	string	Base work dir (.../work)
	 * @param 	string $desiredDirName complete path of the desired name
 	 * @return 	string actual directory name if it succeeds, boolean false
 	 * otherwise
 	 */

	function testcreate_unexisting_work_directory() {
		$path_name = api_get_path(SYS_COURSE_PATH);
		$base_work_dir=$path_name.'testing/';
		$desired_dir_name= $path_name.'testing';
		$res=create_unexisting_work_directory($base_work_dir,$desired_dir_name);
		$this->assertTrue(is_bool($res));
	}


	 /**
	 * Builds the form thats enables the user to
	 * select a directory to browse/upload in
	 * This function has been copied from the document/document.inc.php library
	 *
	 * @param array $folders
	 * @param string $curdirpath
	 * @param string $group_dir
	 * @return string html form
	 */

	function testbuild_work_directory_selector() {
		$folders=array();
		$curdirpath='';
		$group_dir='';
		$res=build_work_directory_selector($folders,$curdirpath,$group_dir='');
		$this->assertTrue(is_string($res));
		//var_dump($res);
	}

	 /**
	 * Builds the form thats enables the user to
	 * move a document from one directory to another
	 * This function has been copied from the document/document.inc.php library
	 *
	 * @param array $folders
	 * @param string $curdirpath
	 * @param string $move_file
	 * @return string html form
	 */

	function testbuild_work_move_to_selector() {
		$folders=array();
		$curdirpath='';
		$move_file='';
		$group_dir='';
		$res=build_work_move_to_selector($folders,$curdirpath,$move_file,$group_dir='');
		$this->assertTrue(is_string($res));
		//var_dump($res);
	}

	function testconvert_date_to_array() {
		$date=date('d/m/Y',time());
		$group=array();
		$res=convert_date_to_array($date,$group);
		$this->assertTrue(is_array($res));
		//var_dump($res);
	}

	/**
	* This function displays the number of files contained in a directory
	* @param	string the path of the directory complete e.g. /var/www/dokeos
	* @param	boolean true if we want the total quantity of files include in others child directorys , false only  files in the directory
	* @return	array the first element is an integer with the number of files in the folder, the second element is the number of directories
	*/

	function testcount_dir() {
		$path_name = api_get_path(SYS_COURSE_PATH);
		$path_dir=$path_name;
		$recurse=0;
		ob_start();
		$res=count_dir($path_dir, $recurse);
		$this->assertTrue(is_array($res));
		ob_end_clean();
		//var_dump($res);
	}

	/**
	* create a group of select from a date
	* @return array list
	*/

	function testcreate_group_date_select() {
		$res=create_group_date_select($prefix='');
		$this->assertTrue(is_array($res));
		//var_dump($res);
	}


	/**
	 * Transform an all directory structure (only directories) in an array
	 * @param	string path of the directory
	 * @return	array the directory structure into an array
	 */

	function testdirectory_to_array() {
		$path_name = api_get_path(SYS_PATH);
		$directory= $path_name;
		$res=directory_to_array($directory);
		$this->assertTrue(is_array($res));
		//var_dump($res);
	}

	/**
	 * Displays action links (for admins, authorized groups members and authorized students)
	 * @param	string	Current dir
	 * @param	integer	Whether to show tool options
	 * @param	integer	Whether to show upload form option
	 * @return	void
	 */

	function testdisplay_action_links() {
		$cur_dir_path='';
		$always_show_tool_options=1;
		$always_show_upload_form=1;
		ob_start();
		$res=display_action_links($cur_dir_path, $always_show_tool_options, $always_show_upload_form);
		$this->assertTrue(is_null($res));
		ob_end_clean();
		//var_dump($res);
	}

	/**
	* Displays the form where course admins can specify wether uploaded documents
	* are visible or invisible by default.
	*
	* @param $uploadvisibledisabled
	* @return html with two list radio button
	*/

	function testdisplay_default_visibility_form() {
		$uploadvisibledisabled='';
		ob_start();
		$res=display_default_visibility_form($uploadvisibledisabled);
		$this->assertTrue(is_null($res));
		ob_end_clean();
		//var_dump($res);
	}

	/**
	* Displays all options for this tool.
	* These are
	* - make all files visible / invisible
	* - set the default visibility of uploaded files
	*
	* @param $uploadvisibledisabled
	* @param $origin
	* @param $base_work_dir Base working directory (up to '/work')
	* @param $cur_dir_path	Current subdirectory of 'work/'
	* @param $cur_dir_path_url Current subdirectory of 'work/', url-encoded
	*/

	function testdisplay_tool_options() {
		global $charset, $group_properties,$gradebook,$base_work_dir;
		$uploadvisibledisabled='';
		$origin='';
		$cur_dir_path='';
		$cur_dir_path_url='';
		ob_start();
		$res=display_tool_options($uploadvisibledisabled, $origin,$base_work_dir,$cur_dir_path,$cur_dir_path_url);
		$this->assertTrue(is_null($res));
		ob_end_clean();
		//var_dump($res);
	}

	/**
	* create a group of select from a date
	*/

	function testget_date_from_group() {
		$group='';
		$res=get_date_from_group($group);
		$this->assertTrue(is_string($res));
		//var_dump($res);
	}

	/**
	 * @param	string Path of the directory
	 * @return	array The list of ids of all the directories in the path
	 */

	function testget_parent_directories() {
		$my_cur_dir_path='';
		$res=get_parent_directories($my_cur_dir_path);
		$this->assertTrue(is_array($res));
		//var_dump($res);
	}

	/**
	 * Gets the id of a student publication with a given path
	 * @param string $path
	 * @return true if is found / false if not found
	 */

	function testget_work_id() {
		global $cidReq;
		$path_name = api_get_path(SYS_PATH);
		$path=$path_name.$cidReq;
		$res=get_work_id($path);
		$this->assertTrue(is_bool($res));
		//var_dump($res);
	}

	/**
	 * Get the path of a document in the student_publication table (path relative to the course directory)
	 * @param	integer	Element ID
	 * @return	string	Path (or -1 on error)
	 */

	function testget_work_path() {
		$id=1;
		$res=get_work_path($id);
		$this->assertTrue(is_numeric($res));
		//var_dump($res);
	}

	/**
	 * Insert into the DB of the course all the directories
	 * @param	string path of the /work directory of the course
	 * @return	-1 on error, sql query result on success
	 * @version April 2008
	 */

	function testinsert_all_directory_in_course_table() {
		$path_name = api_get_path(SYS_COURSE_PATH);
		$base_work_dir=$path_name.'work/testing';
		$dir_to_array =directory_to_array($base_work_dir,true);
		$res=insert_all_directory_in_course_table($base_work_dir);
		$this->assertTrue(is_null($res));
		//var_dump($res);
	}


	/**
	* returns all the javascript that is required for easily
	* validation when you create a work
	* this goes into the $htmlHeadXtra[] array
	*/

	function testto_javascript_work() {
		$res=to_javascript_work();
		$this->assertTrue(is_string($res));
		//var_dump($res);
	}

	/**
	* converts 1-9 to 01-09
	*/

	function testtwo_digits() {
		$number=1;
		$res=two_digits($number);
		$this->assertTrue(is_numeric($res));
		//var_dump($res);
	}

	/**
	 * Update the url of a dir in the student_publication table
	 * @param	string old path
	 * @param	string new path
	 */
	function testupdate_dir_name() {
		global $base_work_dir;
		$path='';
		$new_name='';
		$res=update_dir_name($path,$new_name);
		$this->assertTrue(is_null($res));
		//var_dump($res);
	}

	/**
	 * Update the url of a work in the student_publication table
	 * @param	integer	ID of the work to update
	 * @param	string	Destination directory where the work has been moved (must end with a '/')
	 * @return	-1 on error, sql query result on success
	 */

	function testupdate_work_url() {
		$id=1;
		$path_name = api_get_path(SYS_COURSE_PATH);
		$new_path=$path_name.'work/testing';
		$res=update_work_url($id,$new_path);
		$this->assertTrue(is_numeric($res));
		//var_dump($res);
	}

		/**
	 * Delete a work-tool directory
	 * @param	string	Base "work" directory for this course as /var/www/dokeos/courses/ABCD/work/
	 * @param	string	The directory name as the bit after "work/", without trailing slash
	 * @return	integer	-1 on error
	 */


	function testdel_dir() {
		global $cidReq;
		$path_name = api_get_path(SYS_PATH);
		$base_work_dir=$path_name.$cidReq.'work/testing';
		$dir= $path_name.'testing/';
		$id=-1;
		$res=del_dir($base_work_dir,$dir,$id);
		$this->assertTrue(is_numeric($res));
		//var_dump($res);
	}
}
?>