*** Settings *** Documentation Fonctions et méthodes de traitement *** Keywords *** Wait Until All JavaScript Finished [Tags] utils [Documentation] Vérifie 3 conditions qui sont censées indiquer ensemble ... que toutes les requètes réseau et traitements JavaScript sont finis. ... 1. Pas de requète XHR/Ajax en cours (partie réseau, pas callbacks) ... 2. Ressources de la page chargées (css, images) qui sinon n'est pas ... convert par les autres vérifications. ... 3. Message(event) queue vide. ... On vérifie que tous les évenements *déclenchés* sont finis: onClick, ... onChange, onLoad, etc et n'importe quel callback en attente. Pas ... ceux qui attendent un timer(setTimeout) ou le retour d'une XHR. ... Quand le timer/XHR finisent, là les callbacks sont mis dans la queue. ... https://developer.mozilla.org/en-US/docs/Web/JavaScript/EventLoop#Adding_messages ... Attention: ne prend pas en compte le cas d'un traitement déclenché par ... un setTimeout(). Si les 3 conditions passent à true avant que le timer ... soit fini, c'est perdu ! ... Dépends de jQuery pour 1. mais il doit y avoir moyen de faire sans. ${js}= catenate SEPARATOR=\n ... // 1. ... if($.active !== 0) return false; ... // ... // 2. ... if(document.readyState !== "complete") return false; ... // ... // 3. Pour ce faire, on ajoute un message dans la queue et on attend ... // qu'il soit traité. ... // Le flag est stocké sur window pour en faire une variable globale. ... setTimeout(function() { window.allEventsFinished = true }, 0); ... if(window.allEventsFinished !== true) return false; ... // ... // On met le flag à null pour que cela puisse servir plus d'une fois. ... // Ce qui est utile en cas d'alternance d'XHR et callbacks où on risque ... // d'avoir besoin que le check 2 et 3 bloquent alternativement. ... window.allEventsFinished = null; ... return true; // Tout devrait être terminé! Wait For Condition ${js} ${TIMEOUT} Isolation d'un contexte [Tags] utils [Arguments] ${values} [Documentation] Permet d'isoler un contexte avec la création : ... - d'une collectivité mono et de son param minimum (dep, com et insee) ... - d'une direction ... - d'une division ... - d'un utilisateur avec le profil "GUICHET UNIQUE" ... - d'un utilisateur avec le profil "INSTRUCTEUR" et de son instructeur ... - d'une affectation automatique de l'instructeur sur les PCI ... ### ... Liste des valeurs à passer dans le dictionnaire en argument : ... om_collectivite_libelle ... departement ... commune ... insee ... direction_code ... direction_libelle ... direction_chef ... division_code ... division_libelle ... division_chef ... guichet_om_utilisateur_nom ... guichet_om_utilisateur_email ... guichet_om_utilisateur_login ... guichet_om_utilisateur_pwd ... instr_om_utilisateur_nom ... instr_om_utilisateur_email ... instr_om_utilisateur_login ... instr_om_utilisateur_pwd Ajouter la collectivité depuis le menu ${values.om_collectivite_libelle} mono Ajouter le paramètre depuis le menu departement ${values.departement} ${values.om_collectivite_libelle} Ajouter le paramètre depuis le menu commune ${values.commune} ${values.om_collectivite_libelle} Ajouter le paramètre depuis le menu insee ${values.insee} ${values.om_collectivite_libelle} Ajouter la direction depuis le menu ${values.direction_code} ${values.direction_libelle} null ${values.direction_chef} null null ${values.om_collectivite_libelle} Ajouter la division depuis le menu ${values.division_code} ${values.division_libelle} null ${values.division_chef} null null ${values.direction_libelle} ${exist_gu} = Run Keyword And Return Status Dictionary Should Contain Key ${values} guichet_om_utilisateur_nom Run Keyword If ${exist_gu} == True Ajouter l'utilisateur depuis le menu ${values.guichet_om_utilisateur_nom} ${values.guichet_om_utilisateur_email} ${values.guichet_om_utilisateur_login} ${values.guichet_om_utilisateur_pwd} GUICHET UNIQUE ${values.om_collectivite_libelle} Ajouter l'utilisateur depuis le menu ${values.instr_om_utilisateur_nom} ${values.instr_om_utilisateur_email} ${values.instr_om_utilisateur_login} ${values.instr_om_utilisateur_pwd} INSTRUCTEUR ${values.om_collectivite_libelle} Ajouter l'instructeur depuis le menu ${values.instr_om_utilisateur_nom} ${values.division_libelle} instructeur ${values.instr_om_utilisateur_nom} &{args_affectation} = Create Dictionary ... instructeur=${values.instr_om_utilisateur_nom} (${values.division_code}) ... om_collectivite=${values.om_collectivite_libelle} ... dossier_autorisation_type_detaille=Permis de construire pour une maison individuelle et / ou ses annexes Ajouter l'affectation depuis le menu ${args_affectation} Depuis le contexte d'un enregistrement [Tags] generic [Arguments] ${args} [Documentation] GENERIC - Accède à la fiche de consultation de ... l'enregistrement. ... Liste des valeurs à déclarer dans le dictionnaire **args** : ... * obj (objet de l'enregistrement) ... * selection_col (colonne pour la recherche simple) ... * search_value (valeur pour la recherche simple) ... * click_value (valeur à cliquer) Depuis le listing ${args.obj} Use Simple Search ${args.selection_col} ${args.search_value} Click Element Until No More Element link:${args.click_value} Saisir l'enregistrement [Tags] generic [Arguments] ${values} [Documentation] GENERIC - Saisie un enregistrement. ... Chaque élément de la liste **values** est une liste contenant trois ... valeurs (l'ordre de déclaration est important) : ... * le libelle du champ à saisir ... * la valeur à saisir ... * le keyword à utiliser pour la saisie de la valeur :FOR ${item} IN @{values} \ Run Keyword ${item[2]} ${item[0]} ${item[1]} Ajouter l'enregistrement depuis le menu [Tags] generic [Arguments] ${args} ${values} [Documentation] GENERIC - Ajoute un enregistrement. ... Liste des valeurs à déclarer dans le dictionnaire **args** : ... * obj (objet de l'enregistrement) ... * msg (message de réussite à la validation du formulaire) ... Chaque élément de la liste **values** est une liste contenant trois ... valeurs (l'ordre de déclaration est important) : ... * le libelle du champ à saisir ... * la valeur à saisir ... * le keyword à utiliser pour la saisie de la valeur Depuis le listing ${args.obj} Click On Add Button Saisir l'enregistrement ${values} Click On Submit Button ${exist} = Run Keyword And Return Status Dictionary Should Contain Key ${args} msg Run Keyword If ${exist} == True Valid Message Should Contain ${args.msg} Modifier l'enregistrement depuis le menu [Tags] generic [Arguments] ${args} ${values} [Documentation] GENERIC - Modifie un enregistrement. ... Liste des valeurs à déclarer dans le dictionnaire **args** : ... * obj (objet de l'enregistrement) ... * selection_col (colonne pour la recherche simple) ... * search_value (valeur pour la recherche simple) ... * click_value (valeur à cliquer) ... * msg (message de réussite à la validation du formulaire) ... Chaque élément de la liste **values** est une liste contenant trois ... valeurs (l'ordre de déclaration est important) : ... * le libelle du champ à saisir ... * la valeur à saisir ... * le keyword à utiliser pour la saisie de la valeur Depuis le contexte d'un enregistrement ${args} Click On Form Portlet Action ${args.obj} modifier Saisir l'enregistrement ${values} Click On Submit Button ${exist} = Run Keyword And Return Status Dictionary Should Contain Key ${args} msg Run Keyword If ${exist} == True Valid Message Should Contain ${args.msg} Supprimer l'enregistrement depuis le menu [Tags] generic [Arguments] ${args} [Documentation] GENERIC - Supprime l'enregistrement. ... Liste des valeurs à déclarer dans le dictionnaire **args** : ... * obj (objet de l'enregistrement) ... * selection_col (colonne pour la recherche simple) ... * search_value (valeur pour la recherche simple) ... * click_value (valeur à cliquer) ... * msg (message de réussite à la validation du formulaire) Depuis le contexte d'un enregistrement ${args} Click On Form Portlet Action ${args.obj} supprimer Click On Submit Button ${exist} = Run Keyword And Return Status Dictionary Should Contain Key ${args} msg Run Keyword If ${exist} == True Valid Message Should Contain ${args.msg} Click On Tab Action [Tags] [Arguments] ${idx} ${obj} ${action} ${position}=left ${soustab}=False ${mode}=None ${message}=None # si le mode de confirmation est # new_window: vérifie qu'une nouvelle fenêtre est apparue # modale : vérifie qu'une fenêtre modale est apparue # message : vérifie qu'un message est apparu # * : vérifie que l'élément cliqué a disparu ${selector} = Set Variable If ${soustab} ... css=#action-soustab-${obj}-${position}-${action}-${idx} ... css=#action-tab-${obj}-${position}-${action}-${idx} Run Keyword If '${mode}' == 'new_window' Click Element Until New Window ${selector} ... ELSE IF '${mode}' == 'modale' Click Element Until New Element ${selector} css=.ui-widget-overlay ... ELSE IF '${mode}' == 'message' Click Element Until Message ${selector} ${message} ... ELSE Click Element Until No More Element ${selector} La page ne doit pas contenir d'erreur Constitution du Workflow de gestion d'une incomplétude [Tags] generic [Arguments] ${number} [Documentation] Création du Workflow complet permettant la gestion de l'incomplétude dans un dossier d'instruction # Création des actions # incomplétude Set Suite Variable ${incompletude_libelle} incompletude_${number} &{args_action} = Create Dictionary ... action=${incompletude_libelle} ... libelle=${incompletude_libelle} ... regle_etat=etat ... regle_incompletude=t ... regle_etat_pendant_incompletude=archive_etat Ajouter l'action depuis le menu ${args_action} # incomplétude notifiée Set Suite Variable ${incompletude_notifiee_libelle} incompletude_notifiee_${number} &{args_action} = Create Dictionary ... action=${incompletude_notifiee_libelle} ... libelle=${incompletude_notifiee_libelle} ... regle_etat=etat ... regle_date_complet=null ... regle_date_limite_incompletude=date_evenement+delai ... regle_delai_incompletude=delai ... regle_incomplet_notifie=t ... regle_evenement_suivant_tacite_incompletude=t Ajouter l'action depuis le menu ${args_action} # dépôt de pièce complémentaire Set Suite Variable ${dpc_libelle} dpc_${number} &{args_action} = Create Dictionary ... action=${dpc_libelle} ... libelle=${dpc_libelle} ... regle_date_dernier_depot=date_evenement Ajouter l'action depuis le menu ${args_action} # complétude Set Suite Variable ${completude_libelle} completude_${number} &{args_action} = Create Dictionary ... action=${completude_libelle} ... libelle=${completude_libelle} ... regle_etat=archive_etat_pendant_incompletude ... regle_accord_tacite=accord_tacite ... regle_date_limite=archive_date_dernier_depot+archive_delai ... regle_date_notification_delai=archive_date_dernier_depot+delai_notification ... regle_date_complet=archive_date_dernier_depot ... regle_date_limite_incompletude=null ... regle_delai_incompletude=null ... regle_incompletude=f ... regle_incomplet_notifie=f ... regle_etat_pendant_incompletude=null Ajouter l'action depuis le menu ${args_action} # Création des états # incompletude &{args_etat} = Create Dictionary ... etat=${incompletude_libelle} ... libelle=${incompletude_libelle} ... statut=En cours Ajouter état ${args_etat} # incompletude notifiée &{args_etat} = Create Dictionary ... etat=${incompletude_notifiee_libelle} ... libelle=${incompletude_notifiee_libelle} ... statut=En cours Ajouter état ${args_etat} # Création des événements @{type_di} = Create List PCI - P - Initial # incomplétude notifiée &{args_evenement} = Create Dictionary ... libelle=${incompletude_notifiee_libelle} ... retour=true ... etat=${incompletude_notifiee_libelle} # Non nécessaire car récupéré depuis l'événement parent (incompletude_${number}) # ... delai=3 Mois # ... accord_tacite=Oui # ... restriction=date_evenement<=archive_date_notification_delai ... action=${incompletude_notifiee_libelle} ... evenement_suivant_tacite=rejet tacite Ajouter l'événement depuis le menu ${args_evenement} # incomplétude @{etat_source} = Create List delai de notification envoye &{args_evenement} = Create Dictionary ... libelle=${incompletude_libelle} ... restriction=date_evenement<=archive_date_notification_delai ... etats_depuis_lequel_l_evenement_est_disponible=${etat_source} ... dossier_instruction_type=${type_di} ... etat=${incompletude_libelle} ... delai=3 Mois ... accord_tacite=Oui ... lettretype=piececomplementaire NOTIFICATION D'UNE DEMANDE DE PIECES COMPLEMENTAIRES ... action=${incompletude_libelle} ... evenement_retour_signature=${incompletude_notifiee_libelle} Ajouter l'événement depuis le menu ${args_evenement} # dépôt de pièce complémentaire @{etat_source} = Create List ${incompletude_notifiee_libelle} &{args_evenement} = Create Dictionary ... libelle=${dpc_libelle} ... etats_depuis_lequel_l_evenement_est_disponible=${etat_source} ... dossier_instruction_type=${type_di} ... lettretype=recepisse_DPC RECEPISSE DE DEPOT DE PIECES COMPLEMENTAIRES ... action=${dpc_libelle} Ajouter l'événement depuis le menu ${args_evenement} # completude &{args_evenement} = Create Dictionary ... libelle=${completude_libelle} ... etats_depuis_lequel_l_evenement_est_disponible=${etat_source} ... dossier_instruction_type=${type_di} ... accord_tacite=Oui ... delai_notification=1 Mois ... action=${completude_libelle} Ajouter l'événement depuis le menu ${args_evenement} # Modification de l'événement de récépissé &{args_evenement} = Create Dictionary ... libelle=Notification du delai legal maison individuelle ... evenement_suivant_tacite=accord tacite (sans arrete) Modifier l'événement ${args_evenement}