Le Produit : Validation en Ligne de Commande
Il existe deux manières de valider une DSN, via l'interface graphique et via une commande lancer depuis un terminal linux ou une invite de commande windows.
Prérequis
Revoir ici les prérequis portant sur la machine sur laquelle on exécute le DSNVAL. Cette machine 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 DSNVAL. Pour exécuter la validation, il faut se mettre dans le répertoire d’installation de l’exécutable DSNVAL (comme repère, ce répertoire doit contenir : configuration, plugins, features, ...) et ensuite lancer la commande suivante :
Pour Windows :
<Autocontrol-ValidateurModeBatchWin64.cmd [{--help|-h}]>
< Autocontrol-ValidateurModeBatchWin64.cmd \
[{--output|-o} cheminDuRepertoireCible] [--grouping|-g] [{--limit|-l}
nbreAnomalieLimite] \
[{--noCheckUpdate|-nc}] cheminDuMessageDsn.dns>
Pour Linux :
<./Autocontrol-ValidateurModeBatchLinux64.sh [{--help|-h}]>
< ./Autocontrol-ValidateurModeBatchLinux64.sh \
[{--output|-o} cheminDuRepertoireCible] [{--grouping|-g}] [{--limit|-l}
nbreAnomalieLimite] \
[{--noCheckUpdate|-nc}] cheminDuMessageDsn.dns>
Voici la description des paramètres de lancement :
{--help|-h} | Affiche l’aide de la commande (paramètre optionnel). |
---|---|
{--output|-o} | cheminDuRepertoireCible : Indique le chemin du répertoire cible (paramètre optionnel). Si le paramètre n’est pas indiqué, le répertoire sera celui contenant le fichier DSN à valider. |
{--grouping|-g} | Activation de la mutualisation des anomalies. |
{--limit|-l} | nbreAnomalieLimite : Limite du nombre d’anomalies que le validateur doit présenter (paramètre optionnel). Si le paramètre n’est pas indiqué, la validation se fait sans limite. |
{--noCheckUpdate|-nc} | Désactive la vérification de la version de l’outil (paramètre optionnel) . Si le paramètre n’est pas indiqué, la vérification est réalisée. Deux cas sont possibles : le produit est déjà à jour : La validation est effectuée. une mise à jour est disponible : la validation n’est pas réalisée et le message suivant est renvoyé : 'Le produit doit être mis à jour. Vous pouvez néanmoins réaliser la validation avec l'option --noCheckUpdate. |
Voici une copie d'écran de l’utilisation de DSNVAL en ligne de commande sur une machine Linux sans utilisation du paramètre output :

avec utilisation du paramètre output :

Encoding sous Windows
En ligne de commande, pour que les accents soient correctement restitués sous Windows, deux actions peuvent être réalisées :
- Lancer le changement d’encoding de la console en CP1252 grâce à la
commande :
chcp 1252
- Mettre la police de la console en police TrueType si ce n’est pas déjà
le cas. Par exemple, la police
Police Raster
n’est pas TrueType alors que la policeLucida Console
l’est.
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. |
-Dfr.cnav.norme.conversion.algorithm | algorithme 2014 | «2011», «2014» | Propriété permettant de sélectionner l’algorithme de conversion actif. |
-DconvertedFiles.root.path | none | String | chemin vers la racine du répertoire où sont produits les fichiers xml après conversion. |
-Dfr.cnav.norme.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. |
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éré dans la variable ?
( echo
$? )
dans un
shell bash sous Linux et la variable errorlevel
sous windows ( echo
%errorlevel%
).