Subversion Repositories eFlore/Applications.del

Rev

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

<?php
require_once __DIR__ . '/../ServiceDelPhpUnit.php';
error_reporting(E_ALL);

class ObservationsTest extends ServiceDelPhpUnit {
        //static function creerUrl($service, $ressources, $parametres = NULL) {
        
        public function testNonExistant() {
                $url = $this->creerUrl('observations');
                $i = new Observations();
                $retour = $this->consulterDirectJson($i->consulter([0], []),
                                                                                        $url);
                // doit retourner une 404
                $this->assertEmpty($retour, "Le json doit retourner un tableau vide. Voir : $url");
        }

        public function testExistant() {
                $url = $this->creerUrl('observations');
                $i = new Observations();
                $retour = $this->consulterDirectJson($i->consulter([1043942], []),
                                                                                        $url);

                $this->hasKeysAndNotEmpty($retour, ['auteur.id', 'auteur.nom', 'date_transmission', 'observateur', 'id_observation'], $url);
                $this->hasKeys($retour, ['auteur.nom'], $url);
                $this->assertArrayHasKey('auteur.id', $retour, "attribut auteur.id manquant. Voir : $url");
        }


        public function testExistantEtContenu() {
                $url = $this->creerUrl('observations');
                $i = new Observations();
                $retour = $this->consulterDirectJson($i->consulter([1043942], []),
                                                                                        $url);

                // from
                // "http://www.tela-botanica.org/eflore/del/services/0.1/observations/1048532
                $expected = json_decode(file_get_contents("obs-1048532-complete.data.json"), true);

                self::ignoreNullValuesAndSort($expected);
                self::ignoreNullValuesAndSort($retour);

                // echo implode(',', array_keys($retour['resultats'])) . "\n" . implode(',', array_keys($expected['resultats']));die;
                $this->clefsIdentiques($expected, $retour, $url);
                $this->assertEquals($expected['resultats'], $retour['resultats'], "Différences dans le tableau pour l'obs 1048532, $url");
        }

        public function testSansImage() {
                $url = $this->creerUrl('observations');
                $i = new Observations();
                $retour = $this->consulterDirectJson($i->consulter([14203], []),
                                                                                        $url);
                // doit retourner une 404
                $this->assertEmpty($retour, "Observation sans image devrait ne rien retourner. Voir : $url");
        }

        public function testRechercheNoObs() {
                $url = $this->creerUrl('observations');
                $i = new Observations();
                $retour = $this->consulterDirectJson($i->consulter([], ['masque.date'=>-1e11]), // 10^11 secondes avant 1970
                                                                                        $url);
                // doit retourner une 404
                $this->assertEquals(0, $retour['entete']['total'], "Incongruité sur ['entete'][0]. Voir : $url");
                $this->assertEmpty($retour['resultats'], "Absence d'observation devrait retourner un result-set vide. Voir : $url");
        }

        /* guidelines pour des tests pérennes:
         * - Utiliser ordre=asc pour prendre les enregistrement les plus anciens, moins susceptibles de changer
         * - Restreindre par date (évite les date_transmission = NULL, qui, après des GROUP BY affectent le result-set
         * - Utiliser moins de "$limite" résultats à cause de la sélection (arbitraire[GROUP-BY])) des obs ayant la même date */
        public function testMasque() {
                $url = $this->creerUrl('observations');
                $i = new Observations();
                $retour = $this->consulterDirectJson($i->consulter([], ['navigation.depart'=>0,'navigation.limite'=>12,'ordre'=>'asc','masque'=>'Grand','masque.date'=>2009]),
                                                                                        $url);
                // from
                // "http://www.tela-botanica.org/eflore/del/services/0.1/observations?navigation.depart=0&navigation.limite=12&masque=Grand&masque.date=2009&ordre=asc"
                $expected = json_decode(file_get_contents("masque=G-date=2009.data.json"), true);

                self::ignoreNullValuesAndSort($expected);
                self::ignoreNullValuesAndSort($retour);

                // echo implode(',', array_keys($retour['resultats'])) . "\n" . implode(',', array_keys($expected['resultats']));die;
                $this->clefsIdentiques($expected, $retour, $url);
                $this->assertEquals($expected['resultats'], $retour['resultats'], "Différences dans le tableau, $url");
        }

        public function testType() {
                @$url = $this->creerUrl('observations');
                $i = new Observations();
                $retour = $this->consulterDirectJson($i->consulter([], ['ordre'=>'asc','masque.type'=>'endiscussion']),
                                                                                        $url);
                if(Config::get('nb_commentaires_discussion') != 1) {
                        printf("can't do test: Config::get('nb_commentaires_discussion') == %d <> 1\n", Config::get('nb_commentaires_discussion'));
                        return;
                }

                // from
                // "http://www.tela-botanica.org/eflore/del/services/0.1/observations?masque.type=endiscussion&ordre=asc"
                $expected = json_decode(file_get_contents("masque.type=endiscussion.data.json"), true);

                self::ignoreNullValuesAndSort($expected);
                self::ignoreNullValuesAndSort($retour);

                // echo implode(',', array_keys($retour['resultats'])) . "\n" . implode(',', array_keys($expected['resultats']));die;
                $this->clefsIdentiques($expected, $retour, $url);
                $this->assertEquals($expected['resultats'], $retour['resultats'], "Différences dans le tableau, $url");
        }


        public function testMasqueEtType() {
                @$url = $this->creerUrl('observations');
                $i = new Observations();
                $retour = $this->consulterDirectJson($i->consulter([], ['navigation.depart'=>0,'navigation.limite'=>12,'ordre'=>'asc','masque'=>'G','masque.type'=>'endiscussion']),
                                                                                        $url);

                $expected = json_decode(file_get_contents("masque=G-masque.type=endiscussion.data.json"), true);

                self::ignoreNullValuesAndSort($expected);
                self::ignoreNullValuesAndSort($retour);

                // echo implode(',', array_keys($retour['resultats'])) . "\n" . implode(',', array_keys($expected['resultats']));die;
                $this->clefsIdentiques($expected, $retour, $url);
                $this->assertEquals($expected['resultats'], $retour['resultats'], "Différences dans le tableau, $url");
        }



        public function hasKeys($arr, $keys, $url) {
                foreach($keys as $k) {
                        $this->assertArrayHasKey($k, $arr, "attribut {$k} manquant. Voir : $url");
                }
        }

        public function hasKeysAndNotEmpty($arr, $keys, $url) {
                foreach($keys as $k) {
                        $this->assertArrayHasKey($k, $arr, "attribut {$k} manquant. Voir : $url");
                        $this->assertNotEmpty($arr[$k], "attribut {$k} vide. Voir : $url");
                }
        }

        static function ignoreNullValuesAndSort(&$arr) {
                $arr['resultats'] = array_map('array_filter', $arr['resultats']);
                ksort($arr['resultats']);
        }

        public function clefsIdentiques($e, $r, $url) {
                $e = array_map(function($a) { return intval(trim($a, '"')); }, array_keys($e['resultats']));
                sort($e, SORT_NUMERIC);
                $r = array_map(function($a) { return intval(trim($a, '"')); }, array_keys($r['resultats']));
                sort($r, SORT_NUMERIC);
                $this->assertEquals($e, $r, "Différences dans les clefs du tableau, $url");
        }

        // obs-1048891-masque.ns=Fleur+violette-masque.comune=Arette.data.json
        // test la présence des commentaires en général

        // obs-1047949-masque.ns=Echium+wildpretii+Pearson-masque.commune=Vilaflor.data.json
        // test la présence des commentaires parents: "1047949"[commentaires][7730][nb_commentaires] == 1 ?

        // obs-1043671-masque.ns=plante+rose-masque.departement=38451
        // idem
}