Subversion Repositories eFlore/Projets.eflore-projets

Rev

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

Rev Author Line No. Line
96 jpm 1
<?php
2
// declare(encoding='UTF-8');
3
/**
4
 * Classe contenant des méthodes :
5
 *  - d'intialisation des tests,
6
 *  - refactorisant le code des tests,
7
 *  - facilitant les tests.
8
 *
9
 * @category	php 5.3
10
 * @package		Tests/Services
11
 * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
12
 * @copyright	Copyright (c) 2011, Tela Botanica (accueil@tela-botanica.org)
13
 * @license		http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
14
 * @license		http://www.gnu.org/licenses/gpl.html Licence GNU-GPL
15
 * @version		$Id$
16
 */
17
abstract class ServiceEflorePhpUnit extends PHPUnit_Framework_TestCase {
18
 
19
	/** Définir la valeur de cet attribut dans le constructeur de la classe de test.*/
20
	protected $projet = '';
21
	/** Définir la valeur de cet attribut dans le constructeur de la classe de test.*/
22
	protected $service = '';
23
 
24
	//+------------------------------------------------------------------------------------------------------+
25
	// Intialisation
26
 
27
	public static function setUpBeforeClass() {
28
		error_reporting(E_ALL);
29
 
30
		self::chargerFramework();
31
 
32
		// Enregistrement en première position des autoload de la méthode gérant les classes des services
33
		spl_autoload_register(array(get_class(), 'chargerClasseAuto'));
34
	}
35
 
36
	public static function chargerClasseAuto($classe) {
37
		if (class_exists($classe)) {
38
			return null;
39
		}
195 jpm 40
		$cheminBase = realpath(__DIR__.'/../../modules/0.1').'/';
96 jpm 41
		$cheminsTests = __DIR__.'/';
42
		$chemins = array($cheminBase, $cheminsTests);
43
		foreach ($chemins as $chemin) {
44
			$chemin = $chemin.$classe.'.php';
45
			if (file_exists($chemin)) {
46
				require_once $chemin;
47
			}
48
		}
49
	}
50
 
51
	private static function chargerFramework() {
195 jpm 52
		$cheminRacine = realpath(dirname(__FILE__).'/../..').'/';
96 jpm 53
		$framework =  $cheminRacine.'framework.php';
54
		if (!file_exists($framework)) {
55
			$e = "Veuillez paramétrer l'emplacement et la version du Framework dans le fichier $framework";
56
			trigger_error($e, E_USER_ERROR);
57
		} else {
58
			// Inclusion du Framework
59
			require_once $framework;
60
 
61
			// Ajout d'information concernant cette application
62
			Framework::setCheminAppli($cheminRacine);// Obligatoire
63
		}
64
	}
65
 
66
	//+------------------------------------------------------------------------------------------------------+
67
	// Refactorisation
833 raphael 68
	public function consulterJson($service, $projet, $ressources, $parametres = NULL) {
790 raphael 69
		$retourJson = self::consulterBrut($service, $projet, $ressources, $parametres);
96 jpm 70
		$retour = json_decode($retourJson, true);
790 raphael 71
		$url = self::creerUrl($service, $ressources, $parametres);
137 jpm 72
		$this->assertEquals(JSON_ERROR_NONE, json_last_error(), "Le json contient des erreurs qui bloquent le décodage. Voir : $url\n".print_r($retourJson, true));
96 jpm 73
		return $retour;
74
	}
75
 
833 raphael 76
	static function consulterBrut($service, $projet, $ressources, $parametres = NULL) {
855 raphael 77
		if(is_null($ressources)) $ressources = array();
833 raphael 78
		array_unshift($ressources, $projet, $service);
96 jpm 79
		$projets = new Projets();
80
		$retourJson = $projets->consulter($ressources, $parametres);
81
		return $retourJson;
82
	}
83
 
833 raphael 84
	static function creerUrl($service, $ressources, $parametres = NULL) {
790 raphael 85
		// TODO ? $version
96 jpm 86
		$ressourcesUrl = array();
87
		foreach ($ressources as $ressource) {
88
			$ressourcesUrl[] = $ressource;
89
		}
90
		$ressourcesUrl = count($ressourcesUrl) > 0 ? '/'.implode('/', $ressourcesUrl) : '';
91
 
92
		$parametresUrl = '';
833 raphael 93
		if ($parametres) {
96 jpm 94
			foreach ($parametres as $cle => $valeur) {
95
				$parametresUrl[] = $cle.'='.rawurlencode($valeur);
96
			}
97
			$parametresUrl = '?'.implode('&', $parametresUrl);
98
		}
97 jpm 99
 
790 raphael 100
		return Config::get('url_service') . '/' . $service . $ressourcesUrl . $parametresUrl;
96 jpm 101
	}
102
 
103
	//+------------------------------------------------------------------------------------------------------+
104
	// Méthodes facilitant les tests
105
 
106
	/**
107
	* Récupère un bouchon de classe abstraite.
108
	* Comment l'utiliser :
109
	* 	$classeAstraite = $this->getClasseAbstraite('MaClasse', array('param1', 'param2'));
110
	*   $foo = $classeAstraite->methodeConcretePublique();
111
	*
112
	* @param String $classeNom Le nom de la classe
113
	* @param Array $parametres Les paramètres à passer au constructeur.
114
	* @return Object Le bouchon de la classe abstraite
115
	*/
116
	public function getClasseAbstraite($classeNom, Array $parametres) {
117
		$efloreScript = $this->getMockForAbstractClass($classeNom, $parametres);
118
		return $efloreScript;
119
	}
120
 
121
	/**
122
	 * Récupère une méthode privée d'une classe pour tester/documenter.
123
	 * Comment l'utiliser :
124
	 * 	MyClass->foo():
125
	 *   $cls = new MyClass();
126
	 *   $foo = self::getPrivateMethode($cls, 'foo');
127
	 *   $foo->invoke($cls, $...);
128
	 *
129
	 * @param object $objet Une instance de votre classe
130
	 * @param string $methode Le nom de la méthode private
131
	 * @return ReflectionMethod La méthode demandée
132
	 */
133
	public static function getMethodePrivee($objet, $nomMethode) {
134
		$classe = new ReflectionClass($objet);
135
		$methode = $classe->getMethod($nomMethode);
136
		$methode->setAccessible(true);
137
		return $methode;
138
	}
139
 
140
	/**
141
	* Récupère une méthode protégée d'une classe pour tester/documenter.
142
	* Comment l'utiliser :
143
	* 	MyClass->foo():
144
	*   $cls = new MyClass();
145
	*   $foo = self::getProtectedMethode($cls, 'foo');
146
	*   $foo->invoke($cls, $...);
147
	* @param object $objet Une instance de votre classe
148
	* @param string $methode Le nom de la méthode protected
149
	* @return ReflectionMethod La méthode demandée
150
	*/
151
	public static function getMethodeProtegee($objet, $nomMethode) {
152
		return self::getMethodePrivee($objet, $nomMethode);
153
	}
154
}
790 raphael 155
 
156
/*
157
sed -i 's/$this->consulterBrut(/ServiceEflorePhpUnit::consulterBrut($this->service, $this->projet, /' $(grep -rl consulterBrut)
158
sed -i 's/$this->consulterJson(/$this->consulterJson($this->service, $this->projet, /' $(grep -rl consulterJson)
159
sed -i 's/$this->creerUrl(/ServiceEflorePhpUnit::creerUrl($this->service, /' $(grep -rl creerUrl)
160
*/
161
?>