Subversion Repositories eFlore/Projets.eflore-projets

Rev

Rev 64 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
60 jpm 1
<?php
94 jpm 2
abstract class ScriptEflorePhpUnit extends PHPUnit_Framework_TestCase {
60 jpm 3
 
4
	public static function setUpBeforeClass() {
5
		error_reporting(E_ALL);
94 jpm 6
 
7
		self::chargerFramework();
8
	}
9
 
10
	private static function chargerFramework() {
64 jpm 11
		$cheminRacine = realpath(dirname(__FILE__).'/../').'/';
60 jpm 12
		$framework =  $cheminRacine.'framework.php';
13
		if (!file_exists($framework)) {
14
			$e = "Veuillez paramétrer l'emplacement et la version du Framework dans le fichier $framework";
15
			trigger_error($e, E_USER_ERROR);
16
		} else {
17
			// Inclusion du Framework
18
			require_once $framework;
19
 
20
			// Ajout d'information concernant cette application
21
			Framework::setCheminAppli($cheminRacine);// Obligatoire
22
		}
23
	}
24
 
25
	//+------------------------------------------------------------------------------------------------------+
26
	// Méthodes facilitant les tests
27
 
28
	/**
29
	* Récupère un bouchon de classe abstraite.
30
	* Comment l'utiliser :
31
	* 	$classeAstraite = $this->getClasseAbstraite('MaClasse', array('param1', 'param2'));
32
	*   $foo = $classeAstraite->methodeConcretePublique();
33
	*
34
	* @param String $classeNom Le nom de la classe
35
	* @param Array $parametres Les paramètres à passer au constructeur.
36
	* @return Object Le bouchon de la classe abstraite
37
	*/
38
	public function getClasseAbstraite($classeNom, Array $parametres) {
39
		$efloreScript = $this->getMockForAbstractClass($classeNom, $parametres);
40
		return $efloreScript;
41
	}
42
 
43
	/**
44
	 * Récupère une méthode privée d'une classe pour tester/documenter.
45
	 * Comment l'utiliser :
46
	 * 	MyClass->foo():
47
	 *   $cls = new MyClass();
48
	 *   $foo = self::getPrivateMethode($cls, 'foo');
49
	 *   $foo->invoke($cls, $...);
50
	 *
51
	 * @param object $objet Une instance de votre classe
52
	 * @param string $methode Le nom de la méthode private
53
	 * @return ReflectionMethod La méthode demandée
54
	 */
55
	public static function getPrivateMethode($objet, $nomMethode) {
56
		$classe = new ReflectionClass($objet);
57
		$methode = $classe->getMethod($nomMethode);
58
		$methode->setAccessible(true);
59
		return $methode;
60
	}
61
 
62
	/**
63
	* Récupère une méthode protégée d'une classe pour tester/documenter.
64
	* Comment l'utiliser :
65
	* 	MyClass->foo():
66
	*   $cls = new MyClass();
67
	*   $foo = self::getProtectedMethode($cls, 'foo');
68
	*   $foo->invoke($cls, $...);
69
	* @param object $objet Une instance de votre classe
70
	* @param string $methode Le nom de la méthode protected
71
	* @return ReflectionMethod La méthode demandée
72
	*/
73
	public static function getProtectedMethode($objet, $nomMethode) {
74
		return self::getPrivateMethode($objet, $nomMethode);
75
	}
76
}
77
?>