Dans une application proposant un grand nombre d'actions différentes, il est fréquent de construire un menu qui présente à l'utilisateur toutes les possibilités qui lui sont offertes sous une forme hiérarchique. Cela peut prendre la forme d'une barre de menu pour les actions toujours disponibles, ou d'un menu contextuel pour les actions associées à l'élément d'interface sélectionné.
Chaque option dans un menu peut correspondre à une action ou à un sous-menu, ce qui permet d'organiser les actions et d'éviter de proposer des listes trop longues.
Le défaut de cette technique est que l'utilisateur risque de ne pas trouver l'action qui l'intéresse car elle est cachée dans un sous-menu. Il est donc très important de rendre la répartition intuitive.
À l'aide du premier programme de ce projet, vous allez permettre à un testeur de visiter un menu à la recherche d'une action particulière. Une fois une batterie de tests enregistrée, le second programme devra aider les concepteurs du menu à analyser les résultats et décider si leur organisation est optimale.
Vous produirez deux programmes écrits en Java, sans emprunt extérieur (sauf l'API officielle). Le travail sera fait en binôme ou trinôme, et devra être terminé avant le dimanche 19 novembre 2023 à 23h59. La partie logicielle sera développée dès le départ à l'aide du serveur Gitea du département.
Chaque test sera basé sur un protocole et donnera un résultat. Ces deux entités seront stockées dans une base de données.
Le protocole est composé de quatre éléments :
Le résultat d'un test enregistre tous les sous-menus visités par le testeur et l'action finalement choisie (qui peut ne pas être la bonne action).
Faites un diagramme de classes des tables nécessaires dans la base de données. Il est fortement recommandé de valider ce diagramme auprès de Luc Hernandez avant d'aller plus loin.
Le premier programme est exécuté par un testeur. Il lui demande (avec une interface appropriée) la référence du protocole à utiliser. Le programme consulte alors la base de données et affiche la description de la tâche à accomplir ainsi que le menu (obligatoirement sous la forme d'un JTree).
Le testeur choisit alors quelle action semble la plus appropriée pour répondre à la question posée. Le programme enregistre les sous-menus qui sont déployés ainsi que l'action finalement choisie. Ce résultat est écrit dans la base de données.
Attention Dans ce programme et le suivant, les problèmes liés à la base de données ne doivent pas terminer le programme.
Le second programme est exécuté par un développeur. Il commence également par demander la référence du protocole en argument. Le programme rassemble tous les résultats de test ayant employé ce protocole et affiche un camembert qui montre la répartition des actions choisies, l'action correcte ayant systématiquement la couleur verte.
Choisir la bonne action, est important, mais trouver la bonne action rapidement est aussi signicatif. Le développeur pourra basculer vers un second camembert qui montre la répartition du nombre de sous-menus déployés lors de chaque test.
Les sources de votre projet (et pas les fichiers .class
)
devront être disponibles à tout moment sur le serveur Gitea du département. Votre dépôt sera privé, nommé
obligatoirement SAE31_2023
et incluera Luc Hernandez (login :
hernand
) dans la liste des collaborateurs. Le nombre de soumissions, leur
date et l'équilibre entre leurs auteurs influeront sur la note finale.
Pour chaque classe, vous prévoierez un fichier source. Suivez les
consignes habituelles
scrupuleusement. La définition de chaque classe et de chaque membre de classe sera
précédée d'un commentaire formaté pour permettre la génération de documentation technique
par l'outil javadoc
(ceci est un exemple de fichier source bien commenté).
Vous devrez respecter l'organisation du code vue au début de l'année. Toutes vos classes
appartiendront à un package. Un fichier Makefile
devra permettre la
compilation de votre projet et la création d'une archive jar. Transcrivez bien
toutes les dépendances entre vos fichiers dans les règles.