Ce sprint n°13 a été consacré à la consolidation de l’outil ezVIS.
Nous avons principalement modifié la documentation et corrigé des bugs.
Tâches
- 20 tâches prévues
- 18 tâches effectuées (dont 15 avaient été prévues)
- 24 tâches au total
- plus de 24 points de complexité prévus
- 37,5 points de complexité effectués
Le nombre de points de complexité prévus était très peu précis, car nous avions plusieurs bugs.
Les bugs sont par définition difficile à estimer.
N’ont pas été comptabilisés ici les travaux de déclaration des bugs par les documentalistes/utilisateurs.
Production
Basculements des URL publics
Les URL publics des rapports du service Appui au Pilotage de l’Inist pointent maintenant sur la machine de production dont la mise au point a été finalisée (via puppet).
Au passage, les instances ont été copiées de la machine d’intégration vers la machine de production (et vérifiées par les gestionnaires de ces instances).
Augmentation de l’espace disque
À cause de la manière dont ezVIS gère le cache des requêtes qu’il utilise, la place utilisée par une de ses instances dans la base de données augmente à mesure que ses utilisateurs en font des usages variés.
C’est pourquoi nous avons fait augmenter par le service Ingénierie de Production l’espace disque disponible sur la machine de production (c’était 10 Go au total sur la machine d’intégration, c’est 200 Go sur la machine de production).
Bugs
Déclaration des bugs par les gestionnaires
Ce sprint ayant été dédié à la consolidation d’ezVIS, nous avons demandé aux gestionnaires des instances déjà existantes de faire une déclaration formelle des bugs qu’ils ont rencontré.
De plus, ils ont dû faire en faire qu’on puisse reproduire ces bugs.
Nous avons donc utilisé l’application ezREF présente sur la machine d’intégration, et fait utiliser l’interface de dépôt de fichiers sur ce serveur pour y mettre:
- la description du dysfonctionnement (dans un fichier
*README.txt
) - la configuration de l’instance (dans un fichier
*.json
) - le(s) corpus dans un ou plusieurs fichier(s) dont préfixe était commun à tous les fichiers concernant ce bug.
Tout le monde a parfaitement joué le jeu et nous avons obtenu la description de 5 bugs:
1 | (-rw-rw-r--) 3.6M Bibliotep_XML_14_08_corpus_final_NCT.xml |
Correction du chargement incomplet
Dans plusieurs des bugs déclarés, lors du chargement des données au premier lancement, ezVIS ne rendait pas la main: la déclaration Files and Database are synchronised.
n’arrivait pas (même quand tous les documents avaient été chargés), et donc encore moins le calcul des corpusFields
(les métriques sur le corpus).
Souvent d’ailleurs, on pouvait contourner ce problème en relançant simplement l’instance (ezVIS détectait alors que le(s) fichier(s) n’avaient pas changés, et passait directement à l’étape suivante: le calcul des métriques).
Il s’est avéré que ce cas arrivait quand une erreur survenait lors du chargement (soit un problème de parsing du fichier, soit un problème JBJ lors du calcul des documentFields
).
L’analyse a révélé que lors du chargement, les erreurs étaient complètement ignorées, et qu’ezVIS essayait quand même de traiter les données, sans même afficher l’erreur.
Dorénavant, l’erreur est affichée, accompagnée du nom du fichier et du numéro du document, dans ce fichier, pour lequel l’erreur s’est produite.
Exemple:
1 | $ ezvis bibliotep_entier_pertes |
Cette correction a modifier le comportement d’ezVIS sur plusieurs des bugs déclarés, révélant alors que c’était plutôt les fichiers d’origine qui ne respectaient pas le format demandé (CVS et l’échappement des guillemets, par exemple).
Voir sur GitHub: #46.
Correction: mettre à jour l’instance quand la configuration est modifiée
Un comportement pratique d’ezVIS a cessé de fonctionner il y a déjà quelques sprints: quand on modifie la configuration d’une instance et qu’on la relance sans modifier les données, les documents ne prennent pas en compte les modifications de la configuration.
En particulier, quand un gestionnaire modifie les documentFields
, ces nouveaux champs ne sont calculés que pour les nouveaux documents (ou pour aucun). C’est très handicapant quand on met au point une configuration car on est alors contraint, quand on passe par ezMaster, de supprimer l’instance et de la recréer (ce qui implique de recharger les données).
Ce comportement a été rétabli: quand on modifie une configuration, si les documents sont plus anciens que le fichier de configuration, ezVIS les mets à jour en prenant en compte la nouvelle configuration.
Voir sur GitHub: #49.
Correction: mettre à jour l’instance quand les fichiers sont modifiés
Quand un fichier déjà chargé dans l’instance est remplacé par un fichier du même nom mais contenant des lignes en moins, les lignes ne disparaissaient pas.
Après une enquête approfondie (merci à Yannick pour son aide), nous avons trouvé et corrigé le bug.
Voir sur GitHub: #50.
ATTENTION : il est possible que des métriques faisant un comptage des documents ne soient pas mises à jour immédiatement. Dans ce cas, il est nécessaire de redémarrer l’instance (ou de la mettre en pause de la relancer, via ezMaster) pour bénéficier d’un calcul à jour.
Nouvelle documentation
Il commençait à être difficile de s’y retrouver dans l’ancienne documentation d’ezVIS, qui tenait sur une page, mais était dépourvue de table des matières (et souvent faisait référence à la documentation d’autres projets).
Il a donc été décidé d’utiliser un système dédié à la documentation de projets informatiques, qui se base sur le même format que l’ancienne documentation (Markdown): ReadTheDocs.
La nouvelle documentation, divisée en pages plus courtes, et agrémentée d’illustrations, est donc disponible sur http://ezvis.readthedocs.org/ ou http://ezvis.rtfd.org/.
Elle est mise à jour à chaque mise à jour du dépôt GitHub, et responsive (lisible sur un téléphone mobile).
Au besoin, on pourrait même en garder des versions différentes (une pour la version 6.*, et une pour la version suivante, par exemple).
Voir sur GitHub: #51.
Meilleurs messages d’erreur
oubli de lancer MongoDB
Quand on a oublié MongoDB avant de lancer ezVIS, il y a maintenant un message d’erreur:
1 | failed to connect to [localhost:27017] |
Il est certes sibyllin, mais il est difficile de faire mieux (principalement en raison du fait qu’ezVIS n’établit la connexion à MongoDB que lorsqu’il en a besoin).
oubli du paramètre
ezVIS a un paramètre obligatoire: le chemin du répertoire où se trouvent les fichiers contenant les données.
Auparavant, le message était très technique, et même les programmeurs avaient besoin de toute leur expérience pour le comprendre.
Maintenant c’est celui ci:
1 | $ ezvis |
Voir sur GitHub: #52.
Erreurs JBJ
Afin de pouvoir afficher les erreurs JBJ (dues à la configuration des documentFields
, corpusFields
et flyingFields
), nous avons mené une opération d’homogénéisation du traitement des erreurs dans JBJ.
Il sont maintenant traités comme n’importe quelle erreur dans ezVIS (en particulier lors du chargement des données).
Voir sur GitHub: #56.
Camemberts: position des légendes lorsque des labels sont précisés
Dans un pie
, quand on déclare des labels
, la position de la légende n’était pas prise en compte (voir image ci-dessous).
Ex:
1 | { |
C’est maintenant fonctionnel.
Voir sur GitHub: #55.
JBJ
Nouveaux alias: getIndex
& getIndexVar
Quand getProperty
et getPropertyVar
sont appliqués à un tableau, il est plus naturel d’utiliser getIndex
et getIndexVar
(cliquez sur les liens pour voir des exemples dans la documentation de JBJ version ReadTheDocs).
Voir sur GitHub: #60.
JBJ Playground
Voir sur GitHub: #61.
Recherche dans les exemples
Nous avions déjà une recherche dans les actions, mais pas dans les exemples.
C’est fait.
Voir sur GitHub: f8cde74.
Agrandissement des éditeurs
La taille des INPUT
, STYLESHEET
et RESULT
était fixe. Elle est maintenant dépendante de la largeur de la fenêtre du navigateur.
Voir sur GitHub: PR 12.
Supprimer les préfixes des exemples (Basic: find
)
Les exemples étaient initialement classés par sujet, et partageaient leur input
.
Nous avons supprimé le premier niveau (sujet).
Nous en avons aussi profité pour supprimer un effet de bord gênant: quand une feuille de style modifiait l’input
, elle le modifiait aussi pour les autres exemples du même sujet. Chaque exemple est maintenant indépendant.
Voir sur GitHub: e3915c3.
Ajouter un champ URL
Nous avons ajouté un champ URL
sous l’input
pour pouvoir remplir cet éditeur avec la réponse d’une requête renvoyant du JSON.
Voir sur GitHub: 8174aae.
ezVIS: ajouter des boutons vers le JBJ Playground
Quand on ajoute dans la configuration d’ezVIS une propriété addlinkstojbj
à true
, on ajoute un lien vers le JBJ Playground :
- dans la page d’affichage d’une notice (
/display/
) 7f51427 - dans la liste des documents (
/documents.html
) 25f64c3 - dans les graphiques (
/chart.html
) c0dad22
Voir dans la documentation, l’annexe sur JBJ.
Voir sur GitHub: #62.
castor-clean
: message explicite
Auparavant, castor-clean
était une commande muette: qu’elle ait accompli sa mission ou non, l’utilisateur n’en savait rien.
Maintenant, quand tout s’est bien passé, elle écrit OK
.
Sinon, le message est:
1 | Warning: no collections dropped. Either you mistyped the name, or it was already cleaned up. |
Voir sur GitHub: 8229754.
Pour en profiter: npm install -g castor-clean
. (version 1.2.0).
ezref
: usage
Comme pour ezVIS, quand on oublie le paramètre obligatoire d’ezref
, on a maintenant un message indiquant l’usage normal de la commande:
1 | $ ezref |
ezvis
: mise à jour de dépendances
Il existe un site qui recense la fraîcheur des dépendences de projets Node, et qui signale des trous de sécurité potentiels.
J’ai donc procédé à quelques mises à jour (marked
, sha1
, et qs
).
Sans doute à surveiller de près.
Comme d’habitude, pour profiter des ajouts de ce sprint dans ezVIS :
1 | $ npm install --production -g ezvis |
À ce jour, c’est la version 6.8.0.