IV. Modèle d'analyse▲
Cette partie est la réponse technique au Use Case Model.
Le modèle d'analyse est construit à partir d'un ensemble d'éléments de modélisation (les classes, les composants, les diagrammes de classes, les diagrammes de séquence) et structuré en plusieurs parties.
IV-1. Description des éléments de modélisation du modèle d'analyse▲
IV-1-1. Les Classes▲
IV-1-1-1. Multiplicité▲
1..n : on peut avoir une ou plusieurs classes.
IV-1-1-2. Utilisation d'une classe▲
A l'instar du Use Case Model, en analyse les classes modélisées ne représentent toujours pas des objets logiciels implémentables mais résultent de la conceptualisation objet du système attendu.
Certaines de ces classes, les entités, sont directement issues de l'expression des besoins. Leur spécification se poursuit et se précise en analyse.
Les autres classes, services et médiations, sont identifiées au cours de l'analyse essentiellement en fonction des nécessités liées à la modélisation des scénarios.
IV-1-1-3. Contenu▲
Une classe peut contenir :
- 1..n attributs.
- 1..n opérations.
IV-1-1-4. Documentation d'une classe▲
Elle doit contenir la définition de la classe et l'ensemble des commentaires et contraintes pertinents portant sur la classe dans son ensemble.
Il est également nécessaire de valoriser certains métas-attributs comme la volumétrie. La volumétrie indique le nombre d'instances possibles de la classe dans le système (il s'agit généralement plus d'un ordre de grandeur que d'une valeur précise).
IV-1-2. Composant▲
On distingue 2 types de composants : les composants métiers et les composants services.
Les composants métiers modélisent la partie la plus stable du système d'information c'est-à-dire celle susceptible d'évoluer le moins dans le temps. Elle correspond en général aux entités stables du Système d'Information.
A la différence des composants métiers, les composants services modélisent la partie la plus instable du système d'information c'est-à-dire celle susceptible d'évoluer le plus dans le temps. Elle correspond en général aux processus métiers dont le rôle est d'orchestrer les composants métiers.
Les services rendus par un composant service doivent être à terme exprimés à travers des interfaces présentées par le composant mais réalisées par les entités du composant de manière à renforcer l'encapsulation des objets et donc le faible couplage des composants entre eux.
Exemple : pour un projet Serveur un composant métier peut être constitué de :
- Classes pour les services simples (SISV pour service simple).
- Classes pour la DAO (Data Access Object) : ce sont les classes pour les accès aux données.
- Classes d'objets du domaine : DTO (Data Transfert Object), Criteria.
IV-1-2-1. Multiplicité▲
1..n : on peut avoir un ou plusieurs composants.
IV-1-2-2. Convention de nommage▲
Pour les composants métiers : <<composant>> <nom du composant métier>
Pour les composants Services : <<service>> <nom du composant service>
IV-1-2-3. Contenu▲
Pour un composant métier :
- 1..n entités représentant les objets métiers du composant.
- 1..n diagrammes de classes manifestant ces entités et les associations qu'elles partagent avec des entités du même composant ou des entités d'autres composants métiers.
Pour un composant service :
- 1..n contrôles représentant les processus métiers du système.
- 1..n diagrammes de classes manifestant ces control et les associations qu'ils partagent avec des médiateurs donnant accès aux composants métiers.
IV-1-3. Diagramme de Classe▲
IV-1-3-1. Multiplicité▲
1..n : on peut avoir un ou plusieurs diagramme de classe.
IV-1-3-2. Conventions de nommage▲
Si le diagramme de classes est le seul présent dans le package considéré, son nom doit être <Structure> .
S'il doit y avoir plusieurs diagrammes de classes dans un même package, les noms possibles sont les suivants :
- pour un diagramme présentant une partie de la structuration des classes généralement autour d'une classe donnée, le nom devra être : Structure - <nom de la classe centrale > .
- si autour d'une même classe plusieurs diagrammes doivent être présentés, le nom de chacun devra être :
Structure - <nom de la classe centrale > - <nom qualifiant l'objectif du diagramme> .
- pour un diagramme présentant un arbre de généralisation-spécialisation particulier, le nom devra être :
Classification - <nom de la super-classe> .
IV-1-3-3. Utilisation▲
Un ou plusieurs diagrammes de classes doivent être fournis pour chacun des packages (cf IV-2IV-2) présents dans les différentes couches du modèle statique d'analyse. Chacun présente un ensemble cohérent des classes du package éventuellement accompagnées d'un ensemble de classes d'autres packages du modèle avec lesquelles les premières partagent des associations (ou mieux, les interfaces d'autres composants), en fonction de l'objectif exact du diagramme tel qu'il est présenté par son nom et par sa documentation.
Par ailleurs des diagrammes de classes doivent également être utilisés pour représenter graphiquement les packages formant l'architecture logique en couches du système à ses différents niveaux et les relations de dépendance qui les structurent.
IV-1-3-4. Documentation d'un diagramme de classe▲
Elle doit contenir une description de l'objectif du diagramme c'est-à-dire la raison pour laquelle le diagramme a été créé, de manière à manifester un ensemble particulier de classes avec un ensemble particulier de relations (associations, arbres de généralisation ou de spécialisation) qu'elles partagent.
IV-1-4. Diagramme de Séquence▲
IV-1-4-1. Multiplicité▲
1..n : On peut avoir un ou plusieurs diagrammes de séquence.
IV-1-4-2. Conventions de nommage▲
SC<numéro d'ordre du scénario>-<type du scénario>-<nom du scénario>
Les différents paramètres du nommage ci-dessus sont identiques à ceux définies pour le diagramme de séquence de niveau système du modèle des cas d'utilisation (voir III-1-4III-1-4)
IV-1-4-3. Utilisation d'un diagramme de séquence▲
En analyse les diagrammes de séquence spécifiés présentent les interactions entre instances des classes. Là où les diagrammes de séquence de niveau système exprimaient les scénarios de déroulement des cas d'utilisation avec une vue <boite noire> sur le système, les diagrammes de séquence du modèle dynamique d'analyse expriment ces mêmes scénarios en s'appuyant sur les objets du système tels qu'ils ont été définis. L'objet système est <explosé> pour faire apparaître ses constituants.
Chacun de ces diagrammes de séquence d'analyse doit être créé dans le package contenant la réalisation de cas d'utilisation correspondant au package de cas d'utilisation qui contient le diagramme de séquence de niveau système auquel il est lié.
Chacun diagramme de séquence présente :
- Les acteurs sous la forme d'une ou plusieurs de leurs instances.
- Les objets pertinents du système dans le cadre du scénario c'est-à-dire intervenant effectivement dans son déroulement sous la forme d'instances de classes du modèle statique d'analyse, quelle que soit la nature de ces classes (frontières, services ou entités). Globalement on trouvera dans chacun de ces diagrammes :
- Une instance de l'acteur initiateur du cas d'utilisation dont la réalisation est spécifiée à travers le diagramme de séquence considéré.
- Une ou plusieurs instances de classes frontières, notamment celle de la frontière assurant la médiation avec l'acteur initiateur mais également toutes celles des frontières représentant les médiateurs avec tous les autres acteurs impliqués dans le scénario considéré.
- Une ou plusieurs instances des classes contrôles responsables des services métier utilisés dans le cadre de la réalisation du scénario considéré.
- Une ou plusieurs instances des classes entités utilisées ou manipulées utilisés dans le cadre de la réalisation du scénario considéré.
- L'enchaînement des interactions, des actions et réactions, entre les acteurs et le système sous la forme de messages ordonnancés temporellement entre les instances des acteurs et les constituants du système.
IV-2. Contenu du modèle d'analyse▲
Le modèle d'analyse est composé de quatre packages principaux :
- Le package des composants métiers
- Le package des médiations
- Le package des composants services
- Le package des Uses Case Realization
Chacun de ces packages représente une unité de regroupement d'entités fortement cohérentes autour d'un concept central dont on envisage qu'elles rendent collectivement des services
IV-2-1. Package des composants métiers▲
C'est dans ce package qu'on regroupe tous les composants métiers du système. Rappelons que les composants métiers représentent la partie la plus stable du système.
IV-2-1-1. Multiplicité▲
1..n : on peut avoir un ou plusieurs package de composants.
IV-2-1-2. Nommage▲
Ce package porte le nom <<layer>>BusinessComponent. A l'intérieur de <<layer>>BusinessComponent on trouve tous nos composants métiers (cf )
IV-2-1-3. Documentation▲
Elle doit contenir une description de l'intention du package c'est-à-dire des composants regroupés dans le package.
Pour un projet Serveur on peut par exemple avoir comme l'illustre la figure 12, un package de composants métiers :
IV-2-2. Package des composants services▲
C'est dans ce package qu'on regroupe tous les composants service du système. Rappelons que les composants service représentent la partie la plus instable du système c'est-à-dire celle en charge d'orchestrer les services proposés par la couche de composants métiers.
IV-2-2-1. Multiplicité▲
1..n : on peut avoir un ou plusieurs packages services.
IV-2-2-2. Nommage▲
Pour un projet serveur le package des services est symbolisé par <<layer>>Services. A l'intérieur on retrouve tous nos composants services (cf IV-1-2IV-1-2).
Pour un projet front-end ce pourrait être les classes d'actions qui sont en charge d'orchestrer les services offerts par le serveur. Les classes d'actions peuvent dans ce cas être regroupées dans <<layer>><Front-End Action>.
IV-2-3. Package des médiations▲
On y met les médiations entre les différents composants du système ainsi qu'entre le système et les acteurs extérieurs.
IV-2-3-1. Multiplicité▲
1..n : on peut avoir un ou plusieurs package de médiation.
IV-2-3-2. Nommage▲
<<interface>><nom du regroupement des médiations>
IV-2-3-3. Contenu▲
1..n frontières (classes stéréotypées avec le stéréotype standard <boundary>) représentant les objets médiateurs des interactions entre les composants ainsi qu'entre le système et ses acteurs.
Pour un projet Serveur on peut avoir un médiateur pour l'accès aux composants service : SVCOFinder. Il peut aussi exister un médiateur pour l'accès aux composants métiers : SISVFinder. Il peut enfin exister un médiateur pour l'accès aux entités d'accès aux données : DAOController.
IV-2-4. Package Use Case Realization▲
Le contenu de ce package forme le modèle dynamique d'analyse.
IV-2-4-1. Package des Regroupements de réalisation des cas d'utilisation▲
Un tel package regroupe un sous-ensemble des réalisations de cas d'utilisation correspondant aux sous-ensembles de cas d'utilisation identifiés dans le modèle des cas d'utilisation.
IV-2-4-1-1. Multiplicité▲
1..n : on peut avoir un ou plusieurs packages de regroupement des réalisations de cas d'utilisation.
IV-2-4-1-2. Convention de Nommage▲
<<UCR Package>> <nom du regroupement de réalisations de cas d'utilisation>
Un package de regroupement des réalisations de cas d'utilisation doit être créé par package de regroupement de cas d'utilisation du modèle des cas d'utilisation en portant le même nom que ce dernier.
IV-2-4-1-3. Contenu▲
- 1..n packages de réalisation de cas d'utilisation (voir figure 15).
- 1 diagramme de cas d'utilisation manifestant la traçabilité des cas d'utilisation par leurs réalisations respectives.
IV-2-4-2. Package de réalisation de cas d'utilisation▲
Chacun de ces packages représente une unité de modélisation cohérente détenant la spécification de la réalisation d'un cas d'utilisation sur la base des objets identifiés dans le système. La réalisation d'un cas d'utilisation consiste à <éclater> l'entité <Système> présente sur les diagrammes de séquence du cas d'utilisation origine afin de faire apparaître les classes boundary, service et métier qui constituent le système.
IV-2-4-2-1. Multiplicité▲
1..n : on peut avoir un ou plusieurs packages de réalisation de cas d'utilisation.
IV-2-4-2-2. Convention de Nommage▲
<<Use Case Realization>> <nom de la réalisation de cas d'utilisation>
Un package de réalisation de cas d'utilisation doit être créé par package de cas d'utilisation du modèle des cas d'utilisation en portant le même nom que ce dernier (à l'exception du préfixe qui doit être <UCR-> et non <UC-x->.
IV-2-4-2-3. Contenu▲
- 1 réalisation de cas d'utilisation (cas d'utilisation stéréotypé)
- 1..n diagrammes de séquence manifestant chacun un scénario de réalisation du cas d'utilisation (nominal, alternatif ou d'erreur) faisant intervenir des instances des classes identifiées dans le modèle d'analyse.