INFORMACION ADICIONAL

Manual Basico de Architec Enterprise

1. Introducción

Siempre que me toca dar un curso de UML o técnicas de análisis y diseño, dedico un rato a revisar las herramientas y ponerme un poco al día ... todo cambia.
En este caso voy a probar la versión de evaluación de Enterprise Architect 7.5 y aprovechar para ver alguna peculiaridad como podría ser su proposición de modelos, las matrices de trazabilidad y la edición tabular de diagramas de estados.
Como es costumbre, voy a capturar unas pantallas y compartirlas con mis compañeros de Autentia y con todos vosotros aunque no pretende ser completo ni exhaustivo aunque si daré unas pinceladas de cómo me gusta usarlos.

2. Entorno.

El tutorial está escrito usando el siguiente entorno:

3. Instalación y arranque.

Lo primero que haremos por tanto es bajarnos la herramienta: Nos vamos al site http://www.sparxsystems.es/New/products/ea.html

Recordad que a lo mejor yo escribo el tutorial ahora (Enero de 2009) y tú lo lees dentro de años por lo que es posible que las cosas no sean exactamente iguales: pues nada, tampoco estará tan lejos.
Con pinchar evaluar ya tenemos automáticamente el fichero para la descarga.
Desde la página en argentina te la puedes descargar en castellano pero francamente pienso que si trabajas con varias herramientas UML distintas utilices la versión en Inglés porque te puedes volver loco con las traducciones que aporta cada herramienta (aunque de esta me quejo poco).

Nos lo bajamos e instalamos en castellano.

Como estamos en evaluación, podemos elegir simular la versión de Enterprise Architect que queremos utilizar … todo un detalle. Yo elijo la profesional.

El aspecto es inmejorable aunque choca el orden respecto a otras herramientas (aunque siempre suele ser configurable): Aparece el menú de navegación a la derecha y los artilugios a utilizar en la izquierda.

Lo primero que hacemos es crear un proyecto. Vemos como queda en el reciente Windows 7.


4. Elección de modelos.

Nuestro trabajo podría ser muy distinto:
  • Modelar los procesos de negocio.
  • Definir los requisitos de un proyecto.
  • Diseñar una solución y construir el esqueleto.
  • Codificar utilizando técnicas ágiles y desarrollo guiado por pruebas.
  • Etc.
Entreprise Architect nos permite elegir los modelos que queremos utilizar. Fijaros en la opción “seleccionar desde” porque nos filtrará entre los modelos propios y otras opciones (como lo particulares del proceso unificado de desarrollo de software).Una vez elegidos nos crea una estructura con elementos de ejemplo que nos pueden guiar muy bien en donde poner cada cosa (que para un principiante es uno de los mayores de los problemas).
Vemos todos los modelos

Filtramos por UP. Recordemos que el proceso unificado es:
  • Guiado por casos de uso.
  • Centrado en la arquitectura.
  • Iterativo e incremental.
Esto nos da ya la idea de por donde empezar a modelar los diagramas: POR ENTENDER EL COMO SE GANA DINERO EN LOS PROCESOS DEL NEGOCIO (era para despistar).

Creamos un proyecto basado en el proceso unificado eligiendo todos lo modelos inicialmente. La verdad es que para alguien que no trabaje habitualmente con estas herramientas o que no posea un esqueleto propio para organizar los elemento te va a crear una estructura base excelente, poco confusa y hasta con un pequeño ejemplito de cada diagrama UML o artilugio.
El programa es básicamente como todos los demás: Si pinchas sobre cualquier elemento aparece una flecha inteligente que te permite crear los elementos posibles a asociar.

Creamos nuestra jerarquía de actores y casos de uso.
Para cacharrear con las opciones podemos crear un proyecto nuevo donde ir probando los distintos modelos de un modo aislado.
Una de las cosas más interesantes que debemos hacer es pasarnos por la documentación online: http://www.sparxsystems.com.ar/new/resources/uml2_tutorial.php (si en castellano no encontráis contenido, quitar el punto .ar y probar buscar en ingles).
La ayuda es de las mejores que encontrareis en este tipo de herramientas. De hecho hay veces que estoy dando un curso de UML y directamente re direcciono a este Web a mis alumnos, aunque estemos usando otra herramienta.
Además tiene un detallazo … cuando navegas en la propia herramienta en su ayuda, te referencia a lo que dice la especificación (por cierto, suele caber todo en la misma)


5. Diagramas de casos de uso.

Vemos el aspecto de modelo de casos de uso (árbol de la derecha). Recordad que si lo hacéis así (eligiendo solo un modelo y colocando los elementos donde mejor os parece) y luego vais añadiendo otros modelos, posteriormente tendréis que mover cada elemento al sitio adecuado (si no queréis volveros locos).

Todo es bastante intuitivo


6. Matrices de trazabilidad requisitos-casos de uso.

Si hubiéramos empezado a modelar el sistema desde los requisitos (por ejemplo partiendo de una oferta estándar, concurso o en una metodología tipo Metrica 3) podríamos representarlos visualmente y asociarlos (como una realización) a los casos de uso. Es lo bueno de añadir modelos en cualquier momento (aunque no sean UML … que tampoco hay que ser tan purista)..

Si relacionas los requisitos con los casos de uso visualmente luego podemos acceder a las matrices de trazabilidad. Vamos al menú ver… matriz de relaciones.

Es sencillo y me recuerda a las matrices de otras herramientas como Requisit Pro.

Como en casi cualquier herramienta, podemos detallar un diagrama con otros.

7. Diagramas de actividad.

Añadimos un diagrama que ha cambiado un poquito más de la primera versión de UML a la 2.x, el de actividad que utilizamos para explicar un caso de uso. Pulsando el botón derecho sobre el caso de uso …

Recordad que una buena práctica podría ser limitar el número de elementos a pintar en un diagrama. También que representamos una abstracción del mundo, no un mundo a distintos niveles de zoom: No hay que representar todo en el mismo esquema sino solamente lo significativos. Es más, la mayoría de las veces no existe ni siquiera consenso entre usuarios de UML sobre como representar distintas cosas por lo que siempre es aconsejable abusar de las notas o aclaraciones textuales adicionales.


8. Diagramas de secuencia.

Un caso de uso (o casi mejor dicho una colaboración concreta) se puede representar también como un diagrama de secuencia.
A alto nivel y tirando de los patrones de GRASP y de las clases de análisis, podemos reducir un sistema a interfaces, controladores (me gusta más la palabra gestores) y entidades.
En Enterprise Architect quedan realmente bonitos. Ahora entramos con la guerra de cómo pintan/ocultar los mensajes de retorno.
Para mi gusto, no se pintan los mensajes de retorno en diagramas de secuencia a menos estemos a muy alto nivel (a nivel de diagrama de secuencia de sistema) o que se quiera resaltar algún valor concreto (ya que la estructura de un mensaje es auto-explicativa). Los valores de retorno también se pueden utilizar para indicar salidas excepcionales.
En las opciones de Enterprise Architect se pueden indicar que los mensajes de derecha a izquierda son de retorno.
En UML 2 se puede mostrar bloques alternativos, bucles, etc. dentro de un diagrama de secuencia. Enterpise Architect lo hace muy bien pero francamente es una práctica que no me acaba de gustar demasiado. Veo más un diagrama de secuencia como una colaboración lineal que como un árbol donde representar varias colaboraciones (aunque supongo que es cuestión de gustos).


9. Diagramas de comunicación.

Los diagramas de colaboración evolucionaron a diagramas de comunicación donde fundamentalmente es una misma vista de una secuencia pero con el objetivo de ver el nivel de acoplamiento. Yo los uso poco.

Echo de menos tener a mano la opción de convertir diagramas de secuencia en comunicación y al revés. Seguro que está (incluso he leído que hay una extensión para ello).

9. Diagramas de estado.

Unos de los diagramas más importantes, para mi gusto, en UML son los diagramas de estados. Recordad que para que algo cambie de estado o bien debe haber una pantalla o bien un proceso (batch) que provoque la transición. ¿Cómo podemos dimensionar un sistema si no somos capaces de acotar los estados de las entidades?
Tiene una herramienta en forma de tabla para permitirnos ver y editar las transiciones. Empezamos del modo clásico pintando un diagrama con su punto de inicio y final (no es obligatorio hacerlo así).Y conmutamos al editor tabular.

Podemos añadir estados y transiciones

Vemos la ventana de detalle.

Y se nos va conformando la tabla.

Sobre la cuadrícula pinchamos en insertar transición.

Y si cambiamos a modo gráfico, vemos que se une todo. Probablemente no os quede muy bonito pero podéis dar a auto-organizar (aunque normalmente te toca organizarlo a mano igual)

Tenemos más modos de ver la misma tabla de estados comprobar de cual pasa a cual.

Tampoco me voy a enrolar mucho más. Enterprise Architect me parece una herramienta muy buena, rápida y no ha me ha hecho cosas raras.
Ahora solo hay que sacarle partido pero recordad una cosa (siempre bajo mi criterio), es más importante tener un método secuencial para descubrir un proyecto en base a unos diagramas concretos que saber para que vale la última bolita de la herramienta (que siempre puede y debe aclararse con notas) o forzar usar todos los tipos de diagramas.