Subversion Repositories eFlore/Projets.eflore-projets

Rev

Rev 947 | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

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