<< Retour à l’index

Validation de norme en ligne de commande

  1. Validation de norme en ligne de commande
    1. Prérequis
    2. Commande d'invocation de la validation
    3. Codes d'erreur possibles
    4. Configuration java
    5. Encoding sous windows
    6. La paramétrisation de la validation

Prérequis

Pour pouvoir utiliser l’application en mode ligne de commande, il faut :

La machine sur laquelle est exécutée la validation en mode ligne de commande n’a pas besoin de serveur graphique.

Commande d’invocation de la validation

Le plugin «fr.cnav.autocontrole.headless» permet de valider un message DSN en mode ligne de commande. Ce plugin est intégré à l’exécutable DSN-Val. Pour exécuter la validation, il faut se mettre dans le répertoire d’installation de l’exécutable DSN-Val (ce répertoire doit contenir entre autre le fichier Autocontrol-Validateur.exe et les répertoires plugins et features) et ensuite lancer la commande suivante :

Pour Windows :

Autocontrol-ValidateurModeBatchWin32.cmd [{--help|-h}]
Autocontrol-ValidateurModeBatchWin32.cmd 
		[{--output|-o} cheminDuRepertoireCible] [--grouping|-g] [{--limit|-l} nbreAnomalieLimite]  
		[{--noCheckUpdate|-nc} {--inputFileTypeXML|-xml}]cheminDuMessageDsn.dns
Autocontrol-ValidateurModeBatchWin32.cmd [{--doUpdate|-du}]

Pour linux :

./Autocontrol-ValidateurModeBatchLinux32.sh [{--help|-h}]
./Autocontrol-ValidateurModeBatchLinux32.sh 
		[{--output|-o} cheminDuRepertoireCible] [{--grouping|-g}]  [{--limit|-l} nbreAnomalieLimite]  
		[{--noCheckUpdate|-nc} {--inputFileTypeXML|-xml}]cheminDuMessageDsn.dns
./Autocontrol-ValidateurModeBatchLinux32.sh [{--doUpdate|-du}]

Pour windows avec architecture 64 bits :

Pour linux avec architecture 64 bits :

Voici la description des paramètres de lancement :

Voici une copie d'écran de l’utilisation sur une machine linux sans utilisation du paramètre output :

Voici une copie d'écran de l’utilisation sur une machine linux avec utilisation du paramètre output :

Codes d’erreur possibles

Nom Message Code
EC_NO_ERROR No error 0
EC_NO_INPUT_FILE Vous devez fournir un message en paramètre. 1
EC_INPUT_FILE_NOT_EXIST Le fichier ‹%s› n’existe pas. 2
EC_INVALID_OUTPUT_TYPE Le format d'écriture ‹%s› du rapport n’est pas supporté." 3
EC_INVALID_LIMIT_ANOMALIE La limite du nombre d’anomalies passée en paramètre ‹%s› n’est pas valide (doit être un entier). 4
EC_INVALID_OPTION Option invalide. 5
EC_INVALID_FACTORIZATION_THRESHOLD Le seuil de factorisation des anomales ‹%s› n’est pas valide (doit être un entier). 6
EC_OUTPUT_DIR_PARMETER_NOT_EXIST Le répertoire ‹%s› passé en paramètre doit exister. 7
EC_OUTPUT_PARMETER_IS_NOT_DIR La ressource ‹%s› passée en paramètre doit être un répertoire. 8
EC_MUST_UPDATE_PRODUCT Le produit doit être mis à jour pour réaliser une validation conforme à la version actuelle de la norme. La validation peut être réalisée sans faire la mise à jour en utilisant l’option –nc pour -noCheckUpdate. Vous pouvez faire la mise à jour en ligne de commande en utilisant l’option -du ou --doUpdate 9
EC_UPDATESITE_NOT_AVAILABLE L’update site ‹%s› est inaccessible ou n’est pas un updatesite valide. La vérification du besoin de mise à jour du produit ne peut pas être faite. La validation peut être réalisée malgré ceci en utilisant l’option –nc ou --noCheckUpdate. 10
EC_EMPTY_UPDATESITE L’update site n’est pas configuré, il peut être indiqué dans le fichier de configuration Autocontrol-Validateur.ini. La vérification du besoin de mise à jour du produit ne peut pas être faite. La validation peut être réalisée malgré ceci en utilisant l’option –nc ou --noCheckUpdate. 11
EC_NEED_HELP Vous avez besoin d’aide. 12
EC_INCORRECT_URI_UPDATESITE L’update site ‹%s› indiqué dans le fichier de configuration Autocontrol-Validateur.ini n’est pas valide. Ce paramètre doit avoir une forme d’url (http://monUpdateSite.fr, https://monUpdateSite.fr, file://monUpdateSitePath) 13
EC_TECHNICAL_ERROR Une erreur technique inconnue s’est produite lors de la validation. 14
EC_UPDATE_PRODUCT_DONE Le produit est mise à jour. 15
EC_UPDATE_PRODUCT_FAILED La mise à jour du produit a échouée avec l’erreur %s 16
EC_PRODUCT_ALREADY_UP_TO_DATE Le produit est déjà à jour. 17
EC_MSG_INTEGRITY_TEST_FAILED Le fichier à valider (%s) ne semble pas correspondre au type de fichier attendu par la norme %s. La validation est donc interrompue. 18
CANNOT_CREATE_PRJ La création du projet %s a échoué (%s). 21
CANNOT_PERPARE_PRJ La préparation du projet %s à échoué (%s). 22
CANNOT_REFRESH_FOLDER Le rafraîchissement des répertoires de validation a échoué. 23
CANNOT_PROCESS_SYNTACTIC_VALIDATION La validation syntaxique a échoué. 24
CANNOT_PROCESS_SEMAMTIC_VALIDATION La validation sémantique a échoué. 25
CANNOT_LOAD_FILE Le chargement du fichier ‹%s› a échoué. 26
CANNOT_CLOSE_FILE La fermeture du fichier ‹%s› a échoué. 27
CANNOT_CREATE_NORME_DESCRIPTOR La création du norme descripteur a échouée : %s 28
CANNOT_EXPORT_XML L’export XML a échoué. 30
CANNOT_EXPORT_CURRENT_REPORT L’exportation du rapport du message courant dans le rapport ‹%s› dans le répertoire conteneur %s a échoué. Vérifier la validité du répertoire. 31
ERROR_UNSUPPORTED_EXPORT L’exportation ‹%s› n’est pas supportée. 32
ERROR_PATH_NOT_FILE Le chemin ‹%s› ne correspond pas à un fichier 33
ERROR_REPORT_CREATION La création du rapport de %s a échoué ( %s ). 34
ERROR_PROCESS_CONVERTION La conversion a échoué. 35
ERROR_PROCESS_CONVERTION_FORMAT_NORME La validation a été interrompue. Le fichier d’entrée ‹%s› n’est pas un message de la norme. 36
ERROR_VALIDATE_SEMANTIC La validation sémantique a échoué (%s). 37
ERROR_MERGE_REPORTS La fusion des rapports a échoué (%s). 38
ERROR_FORMATER_INI_CANNOT_ADD_VALUE L’ajout de la valeur %s est impossible. Le nombre de valeur ne doit pas être plus grand que le nombre de titre %d. 39
ERROR_FORMATER_INI_NOT_EQUAL_LIST_SIZE L’initialisation de formateur n’est pas correcte. Le nombre de %s %d et de %s %d est diffrent 40
ERROR_FORMATER_INI_NOT_PREPARE_METHOD_EXECUTED L’initialisation du formateur n’est pas correcte. La méthode prepareValueLineSeparator n’a pas été invoquée 41
ERROR_ZIP_FILE_ACCESS L’accès au fichier zip ‹%s› a échoué (%s). 42
CANNOT_CLOSE_ZIP_FILE La fermeture du fichier Zip précédent ‹%s› a échoué. (%s). 43
ERROR_EXTRACT_SALARIE_MSG_LIST L’extraction des salariés du message a échoué (%s). 44
ERROR_EXPORT_IMPORT_TEMPLATE Le template n’a pas pu être importé, le projet (%s) est introuvable. 45
ERROR_PROCESS_ALL_IN_ONE Le processus de conversion-validation a échoué (%s). 47
ERROR_SERIALISATION_REPORT_HEADLESS Le fichier de destination ‹%s› n’a pu être sérialisé à partir du fichier temporaire ‹%s› qui a été généré par la validation 49
ERROR_TECHNIC_VALIDATION Une erreur technique s’est produite lors de la validation. Veuillez regarder la vue erreur log pour plus de détails 50
ERROR_TECHNIC_EXPORT Une erreur technique s’est produite lors de l’export. Veuillez regarder la vue erreur log pour plus de détails. 51
ERROR_OPENING_ERROR_LOG Une erreur technique s’est produite lors de l’ouverture de la vue error log. 52
ERROR_INDIVIDUAL_VIEW_INITIALIZATION Une erreur technique s’est produite lors de l’ouverture de la vue salarié. 53
ERROR_INDIVIDUAL_VIEW_REFRESH Une erreur technique s’est produite lors du rafraîchissement de la vue salarié 54
ERROR_NORME_VIEW_REFRESH Une erreur technique s’est produite lors du rafraîchissement de la vue norme. 55
ERROR_NORME_VIEW_INITIALIZATION Une erreur technique s’est produite lors de l’ouverture de la vue norme. 56
ERROR_PRINCIPAL_VIEW_REFRESH Une erreur technique s’est produite lors du rafraîchissement de la vue principale. 57
ERROR_PRINCIPALVIEW_INITIALIZATION Une erreur technique s’est produite lors de l’ouverture de la vue principale. 58
ERROR_NO_VALUE_FOR_INDIVIDUAL_FIELD Impossible de trouver de rubrique correspondante à celle fournie (%s) dans le message, pour l’affichage du champ individu %s 59
ERROR_CANNOT_RETRIEVE_BUNDLE Le bundle de la norme ‹%s› n’a pu être r\u00E9cup\u00E9rer 60
CANNOT_SELECT_GIVEN_NORM La norme dont l’identifiant est ‹%s› ne correspond à aucune norme installée. La liste des normes installées est la suivante 61
ERROR_NO_NORMS_REGISTERED Il n’y a aucune norme installée dans le produit. 62
ERROR_INTEGRITY_CHECKING Une erreur s’est produite lors de la tentative de détermination de la validité du fichier fournit pour la validation. 63
ERROR_CANNOT_INSTANCIATE_DESCRIPTOR La création du norme descripteur de la norme ‹%s› a échouée. 70
ERROR_CLASS_INSTANCIATED_IS_NOT_DESCRIPTOR Le type fourni par la norme %s qui permet de créer un descripteur de norme ne correspond pas à un type attendu. 71
ERROR_CANNOT_INSTANCIATE_SERIALIZER La création du sérialiseur de la norme ‹%s› a échoué 72
ERROR_CLASS_INSTANCIATED_IS_NOT_SERIALIZER Le type fourni par la norme %s qui permet de créer un sérialiseur ne correspond pas à un type attendu. 74
EC_JAVA_VERSION La version de java utilise (‹%s›) n’est pas bonne. Vous devez utiliser une version 1.6 – 32 bits (configurer la variable DSNVAL_JAVA). 99
EC_JAVA_ARCHI La version de java est une version 64 bits. Vous devez utiliser une version 1.6 – 32 bits (configurez la variable DSNVAL_JAVA). 98
EC_JAVA_ARCHI_64 La version de java est une version 32 bits. Vous devez utiliser une version 64 bits (configurez la variable DSNVAL_JAVA). 97

Le code retour de la commande peut être récupérer dans la variable ? ( echo $? ) dans un shell bash sous linux et la variable errorlevel sous windows ( echo %errorlevel% ).

Configuration java

Par défaut, les scripts de lancement prennent l’exécutable java qui est défini dans le path du système. Si ce java n’est pas compatible avec le produit (Java 1.6 en version 32 ou 64-Bit) un message nous indiquera que la version utilisée n’est pas valide.

Nous pouvons configurer la version utilisé en valorisant la variable DSNVAL_JAVA avec le chemin de l’exécutable java voulu. Voici les commandes de configuration :

Pour Windows :

set DSNVAL_JAVA="c:\path\to\java.exe"

Pour Linux :

export DSNVAL_JAVA=/path/to/java

Encoding sous windows

Pour que les accents soient correctement restitués sous windows, deux actions doivent être réalisées :

La paramétrisation de la validation

Le comportement de la validation avec la validation headless d’autocontrole peut être paramétrée via le fichier «Autocontrol-Validateur.ini». Pour chaque paramètre que l’on veut spécifier, il faut ajouter sa ligne à la fin du fichier «ini». La liste des paramètres est la suivante :

Nom du paramètre Valeur par défaut Valeurs autorisées Description
-Dfr.cnav.norme.report.mutualisation.threshold Pas de mutualisation entier n > 0 Propriété permettant de fixer le seuil à partir duquel les anomalies sont factorisées par le validateur. Si la définition de la propriété est absente la factorisation est inactive. Si la définition de la propriété est présente et contient un entier positif n alors les anomalies identiques ne seront présentes qu’au nombre de n dans chaque déclaration.
-Dmaximal.number.errors Illimité entier n > 0 Propriété fournissant le nombre d’anomalies au-delà duquel les anomalies sont factorisées en une seule anomalie. Une valeur de 0, une valeur négative ou l’absence de la propriété correspondent à l’absence de limite.
-DconvertedFiles.root.path none String chemin vers la racine du répertoire où sont produits les fichiers xml après conversion
-Dfr.cnav.norme.val.originalValue datenum «date», "datenum" Propriété indiquant si on doit utiliser l’attribut XML originalValue sur les rubriques générées lors de la conversion.
-Dstop.on.syntactic.error false «true», "false" Si la propriété est renseignée à la valeur « true » alors la validation est interrompue après la validation syntaxique en cas d’anomalies syntaxiques.
-Dstop.on.conversion.error false «true», "false" Si la propriété est renseignée à la valeur « true » alors la validation est interrompue après la conversion en cas d’anomalies lors de la conversion.
-Dfr.cnav.norme.val.anomaliesInhibiting true «true», "false" Lorsque cette propriété est à « true », les anomalies sémantiques secondaires générées à cause d’une autre anomalie primaire sont filtrées du rapport de validation