New file |
0,0 → 1,134 |
<?php |
class BdtfxTaxonsTest extends PHPUnit_Framework_TestCase { |
|
public function testVersionPrecise() { |
$ressources = array('v1.01'); |
$parametres = array(); |
$url = $this->creerUrl($ressources, $parametres); |
$retour = $this->consulterJson($ressources, $parametres); |
|
$this->assertArrayHasKey('entete', $retour, "Le json ne contient pas d'attribut : entete. Voir : $url"); |
$this->assertArrayHasKey('resultat', $retour, "Le json ne contient pas d'attribut : resultat. Voir : $url"); |
} |
|
public function testNomsIdVersionMultiple() { |
$ressources = array('*', '182'); |
$parametres = array(); |
$url = $this->creerUrl($ressources, $parametres); |
|
$retour = $this->consulterJson($ressources, $parametres); |
$this->assertArrayHasKey('bdtfx_v1_01', $retour, "Le json ne contient pas d'attribut : bdtfx_v1_01.\nVoir : $url"); |
$this->assertArrayHasKey('bdtfx_v1_02', $retour, "Le json ne contient pas d'attribut : bdtfx_v1_02.\nVoir : $url"); |
$this->assertEquals('182', $retour['bdtfx_v1_01']['id'], "'bdtfx_v1_01' doit contenir un attribut 'id' avec la valeur '182'"); |
$this->assertEquals('182', $retour['bdtfx_v1_02']['id'], "'bdtfx_v1_02' doit contenir un attribut 'id' avec la valeur '182'"); |
} |
|
public function testNomsVersionMultiple() { |
$ressources = array('*'); |
$parametres = array(); |
$url = $this->creerUrl($ressources, $parametres); |
|
$retour = $this->consulterBrut($ressources, $parametres); |
|
$attendu = "L'affichage de plusieurs versions ne fonctionne que pour les ressources de type /ressources/#id"; |
$message = "L'url :\n'$url'\n doit retourner un résultat de la forme :\n $attendu"; |
$this->assertEquals($attendu, $retour, $message); |
} |
|
public function testVersionInexistante() { |
$ressources = array('v99.00'); |
$parametres = array(); |
$url = $this->creerUrl($ressources, $parametres); |
|
$retour = $this->consulterBrut($ressources, $parametres); |
|
$attendu = 'La requête SQL formée comporte une erreur!'; |
$message = "L'url :\n'$url'\n doit retourner un résultat de la forme :\n $attendu"; |
$this->assertEquals($attendu, $retour, $message); |
} |
|
public function testRechercheStricte() { |
$ressources = array('v1.01'); |
$parametres = array( |
'recherche' => 'stricte', |
'masque' => 'Acer'); |
$url = $this->creerUrl($ressources, $parametres); |
|
$retour = $this->consulterJson($ressources, $parametres); |
$this->assertArrayHasKey('entete', $retour, "Le json ne contient pas d'attribut : entete. Voir : $url"); |
$this->assertArrayHasKey('resultat', $retour, "Le json ne contient pas d'attribut : resultat. Voir : $url"); |
$this->assertEquals('1', $retour['entete']['total'], "L'attribut 'total' de l'entête devrait valoir 1. Voir : $url"); |
$this->assertEquals(1, count($retour['resultat']), "Le résultat devrait contenir une seule donnée. Voir : $url"); |
} |
|
public function testRechercheEtendue() { |
$url = Config::get('url_service').'/v1.01/taxons?recherche=etendue&masque=Acer'; |
|
$ressources = array('v1.01'); |
$parametres = array( |
'recherche' => 'etendue', |
'masque' => 'Acer'); |
|
$retour = $this->consulterJson($ressources, $parametres); |
$this->assertArrayHasKey('entete', $retour, "Le json ne contient pas d'attribut : entete. Voir : $url"); |
$this->assertArrayHasKey('resultat', $retour, "Le json ne contient pas d'attribut : resultat. Voir : $url"); |
$this->assertEquals('50', $retour['entete']['total'], "L'attribut total de l'entête devrait valoir 50. Voir : $url"); |
$this->assertEquals(50, count($retour['resultat']), "Le résultat devrait contenir 50 données. Voir : $url"); |
} |
|
public function testRechercheFloue() { |
$url = Config::get('url_service').'/v1.01/taxons?recherche=floue&masque=Acer'; |
|
$ressources = array('v1.01'); |
$parametres = array( |
'recherche' => 'floue', |
'masque' => 'Acer'); |
|
$retour = $this->consulterJson($ressources, $parametres); |
$this->assertArrayHasKey('entete', $retour, "Le json ne contient pas d'attribut : entete. Voir : $url"); |
$this->assertArrayHasKey('resultat', $retour, "Le json ne contient pas d'attribut : resultat. Voir : $url"); |
$this->assertEquals('4', $retour['entete']['total'], "L'attribut total de l'entête devrait valoir 4. Voir : $url"); |
$this->assertEquals(4, count($retour['resultat']), "Le résultat devrait contenir 4 données. Voir : $url"); |
} |
|
//+------------------------------------------------------------------------------------------------------+ |
// Refactorisation |
private function consulterJson($ressources, $parametres) { |
$retourJson = $this->consulterBrut($ressources, $parametres); |
$retour = json_decode($retourJson, true); |
$this->assertEquals(JSON_ERROR_NONE, json_last_error(), "Le json contient des erreurs qui bloquent le décodage. Voir : $url"); |
return $retour; |
} |
|
private function consulterBrut($ressources, $parametres) { |
array_unshift($ressources, 'taxons'); |
array_unshift($ressources, 'bdtfx'); |
$projets = new Projets(); |
$retourJson = $projets->consulter($ressources, $parametres); |
return $retourJson; |
} |
|
private function creerUrl($ressources, $parametres) { |
$version = ''; |
$ressourcesUrl = array(); |
foreach ($ressources as $ressource) { |
if (preg_match('/^(v[0-9]+\.[0-9]+|[*+])$/', $ressource)) { |
$version = $ressource.'/'; |
} else { |
$ressourcesUrl[] = $ressource; |
} |
} |
$ressourcesUrl = count($ressourcesUrl) > 0 ? '/'.implode('/', $ressourcesUrl) : ''; |
|
$parametresUrl = ''; |
if (count($parametres) > 0) { |
foreach ($parametres as $cle => $valeur) { |
$parametresUrl[] = $cle.'='.rawurlencode($valeur); |
} |
$parametresUrl = '?'.implode('&', $parametresUrl); |
} |
$url = Config::get('url_service').'/'.$version.'noms'.$ressourcesUrl.$parametresUrl; |
return $url; |
} |
} |
?> |