Académique Documents
Professionnel Documents
Culture Documents
ARCHITECT
INTRODUCCION
Bienvenidos a la guía de usuario de Enterprise Architect de Sparx Systems. Esta guía lo
ayudará a usar Enterprise Architect, una herramienta CASE basada en UML, para realizar
modelado, construcción y administración de software.
Desde que UML fue adoptado por el OMG como el lenguaje estándar para el modelado,
se ha definido un buen número de modelos de proceso para el desarrollo de aplicaciones
orientadas a objetos (OO), que utilizan este lenguaje como medio de expresión de los
diferentes modelos que se crean durante el desarrollo. Estas propuestas suelen estar
dirigidas por los casos de uso, de manera que éstos se emplean para definir los requisitos
funcionales del sistema, y todas las etapas del proceso (planificación de las iteraciones,
análisis, diseño y pruebas) se articulan en torno a los casos de uso identificados.
Actualmente, en muchas discusiones sobre casos de uso se coincide en señalar que con
frecuencia son mal interpretados, y que no hay guías precisas para resolver los aspectos
que tienen que ver con su organización. En este sentido, se han publicado diferentes
propuestas (por ejemplo [3, 7, 8]) en las que se discuten cuestiones tales como la
granularidad de los casos de uso, el nivel de detalle en que deben describirse, o la
conveniencia de crear una jerarquía de casos de uso.
En este trabajo describimos nuestra propuesta para realizar el modelado del negocio y su
conexión con el análisis de requisitos (modelos conceptual y de casos de uso). Esta
propuesta ha sido experimentada en el marco de un proyecto cuyo objetivo ha sido
proporcionar un modelo de proceso, basado en requisitos, para el desarrollo de sistemas
de información de gestión con uso intensivo de datos [10]. El ámbito de este trabajo ha
sido la DGSIC (Dirección General de Servicios de Información y de las Comunicaciones)
de la CARM (Comunidad Autónoma de la Región de Murcia).
CONCEPTOS BÁSICOS
Enterprise Architect soporta la especificación UML 2.0, que describe un lenguaje visual
que permite la definición de los modelos de un proyecto. Se trata de una herramienta
progresiva que cubre todos los aspectos del ciclo de un desarrollo, proporcionando una
completa trazabilidad desde la fase inicial de diseño hasta el desarrollo y posterior
mantenimiento. Así mismo, también proporciona soporte para testing y control de
cambios.
Enterprise Architect soporta todos los modelos/diagramas de UML 2.0. Permite diseñar
desde procesos de negocio, sitios web, interfaces de usuario, configuraciones hardware,
hasta estimar el esfuerzo del proyecto en horas. El repositorio está basado en DBMS
proporciona buenos tiempos de respuesta cuando se trabaja con varios usuarios debido a
su estructura interna. Además, cualquier problema de conexión que se produzca, debería
ser cubierto por las habilidades del servidor DBMS, permitiendo deshacer cualquier
transacción interrumpida por problemas externos. En nuestro caso se ha seleccionado
SQL Server 7.0 como repositorio de proyectos, y la licencia.
EA es una herramienta progresiva que soporta todos los aspectos del ciclo de desarrollo,
proporcionando una trazabilidad completa desde la fase inicial del diseño a través del
despliegue y mantenimiento. También provee soporte para pruebas, mantenimiento y
control de cambio.
Con más de 100,000 licencias vendidas, Enterprise Architect ha probado ser muy popular
a través de un rango amplio de industrias y es usado por miles de compañías en todo el
mundo. Desde organizaciones conocidas y multinacionales hasta compañías y consultoras
independientes y pequeñas, Enterprise Architect se ha convertido en la herramienta de
modelado UML de elección para los desarrolladores, consultores y analistas en más de
60 países.
EA le permite:
CASO DE USO
Cada caso de uso tiene una descripción que describe la funcionalidad que se construirá
en el sistema propuesto. Un caso de uso puede "incluir" la funcionalidad de otro caso de
uso o "extender" a otro caso de uso con su propio comportamiento.
Actores
Un actor es un usuario del sistema. Incluye usuarios humanos y otros sistemas
computarizados. Un actor usa un caso de uso para desempeñar alguna porción de trabajo
que es de valor para el negocio. El conjunto de casos de uso al que un actor tiene acceso
define su rol global en el sistema y el alcance de su acción.
Diagrama de Secuencia
El UML provee un medio gráfico para representar la interacción entre los objetos
a lo largo del tiempo en los diagramas de secuencia. Éstos muestran típicamente
a un usuario o a un actor y los objetos y componentes con los que interactúen
durante la ejecución de un Caso de Uso. Un diagrama de secuencia representa
típicamente un único escenario de Caso de Uso o flujo de eventos.
Los diagramas son una vía excelente para documentar los escenarios de uso, para
capturar los objetos necesarios de manera temprana en el análisis y para verificar
el uso de los objetos más tarde en el diseño. Los diagramas de secuencia muestran
el flujo de mensajes de un objeto a otro y, como tales, representan los métodos y
los eventos soportados por un/a objeto/clase.
El diagrama ilustrado abajo muestra un ejemplo de un diagrama de secuencia, con
el usuario o actor a la izquierda iniciando un flujo de eventos y mensajes que
corresponden al escenario del caso de uso. Los mensajes que pasan entre objetos
se convertirán en operaciones de clases en el modelo final.
Diagrama de Implementación
Un Caso de Uso es una descripción formal de la funcionalidad que el sistema
tendrá cuando se construya. Un diagrama de implementación se asocia
típicamente con un caso de uso para documentar qué elementos de diseño (por
ejemplo, componentes y clases) implementará la funcionalidad del Caso de Uso
en el nuevo sistema. Esto provee un alto grado de trazabilidad al diseñador, al
cliente y al equipo que construirá el sistema. La lista de casos de uso a los que se
asocia un componente o una clase documenta la funcionalidad mínima que debe
ser implementada por el componente.
El ejemplo de arriba muestra que el caso de uso "Acceso" implementa el requisito
Resumen
Autonómica.
Introducción
Motivación
Actualmente, la mayor parte de los modelos de proceso propuestos para UML se definen
como dirigidos por los casos de uso. Un caso de uso puede ser definido como una
secuencia de acciones, incluyendo variaciones, que el sistema puede ejecutar y que
produce un resultado observable de valor para un actor que interactúa con el sistema.
Aunque el éxito de los casos de uso se suele justificar con el hecho de que constituyen
una técnica simple e intuitiva, algunos autores señalan las dificultades que entraña la
obtención y la especificación de casos de uso verdaderamente útiles, y la falta de consenso
sobre cómo organizarlos y manejarlos. Estas son las razones que nos llevan a pensar que
es necesario establecer un conjunto de guías para la identificación, descripción y
organización de los casos de uso.
Algunas discusiones interesantes acerca del manejo de casos de uso son las
proporcionadas por T. Korson y A. Cockburn. Korson defiende que los requisitos (y por
tanto los casos de uso) han de ser organizados jerárquicamente, y establece que i) cada
nivel de casos de uso no debe añadir nuevos requisitos, sino refinar los del nivel superior,
y ii) la jerarquía de casos de uso no debe ser el resultado de una descomposición funcional,
y ha de ser desarrollada de manera iterativa e incremental.
Por otro lado, Cockburn utiliza el concepto de objetivo (goal) para organizar
jerárquicamente los casos de uso. Distingue básicamente entre objetivos estratégicos (los
procesos del negocio de la organización) y objetivos de usuario (las funciones del
sistema). Los objetivos estratégicos se corresponden con un conjunto de objetivos de
usuario y, de igual modo, un objetivo de usuario puede ser descompuesto, a su vez, en un
conjunto de objetivos de usuario. Aparece, por tanto, el concepto de objetivo compuesto,
que corresponde bien a un conjunto de objetivos de usuario, o bien a un objetivo
estratégico.
Otra cuestión importante es la ubicación del modelado de casos de uso dentro del modelo
de proceso. Normalmente se concibe el modelado de casos de uso como un paso previo
al modelado conceptual. Sin embargo, Korson que no es posible crear casos de uso
adecuados y útiles (ni implementarlos correctamente) sin comprender el dominio, y por
tanto, el modelado de casos de uso y el modelado conceptual deben ser actividades
realizadas en paralelo.
Nuestra Propuesta
Para conseguir sus objetivos, una empresa organiza su actividad por medio de un conjunto
de procesos de negocio. Cada uno de ellos se caracteriza por una colección de datos que
son producidos y manipulados mediante un conjunto de tareas, en las que ciertos agentes
(por ejemplo, trabajadores o departamentos) participan de acuerdo a un flujo de trabajo
determinado. Además, estos procesos se hallan sujetos a un conjunto de reglas de negocio,
que determinan las políticas y la estructura de la información de la empresa. Por tanto, la
finalidad del modelado del negocio es describir cada proceso del negocio, especificando
sus datos, actividades (o tareas), roles (o agentes) y reglas de negocio.
El primer paso del modelado del negocio consiste en capturar los procesos de negocio de
la organización bajo estudio. La definición del conjunto de procesos del negocio es una
tarea crucial, ya que define los límites del proceso de modelado posterior. De acuerdo con
el concepto de objetivo estratégico de Cockburn, capturamos los procesos del negocio a
partir de los objetivos principales de la empresa. En primer lugar, consideramos los
objetivos estratégicos de la organización. Teniendo en cuenta que estos objetivos van a
ser muy complejos y de un nivel de abstracción muy alto, serán descompuestos en un
conjunto de subobjetivos más concretos, que deberán cumplirse para conseguir el objetivo
estratégico. Estos subobjetivos pueden a su vez ser descompuestos en otros, de manera
que se defina una jerarquía de objetivos. En nuestro estudio, hemos experimentado que
dos o tres niveles de descomposición son suficientes. Para cada uno de estos subjetivos
de segundo nivel definimos un proceso de negocio que deberá dar soporte a dicho
subobjetivo. Representamos cada proceso del negocio como un caso de uso del negocio,
que inicialmente será descrito de forma textual.
En el resto del trabajo, ilustramos el proceso mediante el ejemplo de una compañía que
fabrica productos bajo demanda (siguiendo un esquema just in time). Los objetivos
estratégicos de dicha compañía podrían incluir Satisfacer un pedido de un cliente,
Incrementar en un 25% las ventas, o Disminuir el tiempo de fabricación en un 15%.El
objetivo Satisfacer un pedido de un cliente puede ser dividido en subobjetivos tales como:
Registrar Pedido de Cliente, Fabricar Producto Pedido, Gestionar Almacén y Realizar
Pedidos a Proveedores. Éstos serán los objetivos que utilizaremos para definir nuestros
procesos del negocio.
Una vez se han identificado los procesos de negocio, es preciso encontrar los agentes
involucrados en su realización. Cada uno de estos agentes o actores del negocio
desempeña cierto papel (juega un rol) cuando colabora con otros para llevar a cabo las
actividades que conforman dicho caso de uso del negocio. De hecho, identificaremos los
roles que son jugados por agentes de la propia empresa (que incluyen trabajadores,
departamentos y dispositivos físicos) o agentes externos (como clientes u otros sistemas).
Por el momento nos centraremos en este último tipo de roles, con los que la organización
interactúa para llevar a cabo sus procesos de negocio. En nuestro ejemplo tenemos los
roles Cliente y Proveedor, claramente externos al sistema.
Para tener una visión general de los diferentes procesos de negocio de la organización,
puede construirse un diagrama de casos de uso del negocio, en el cual aparece cada
proceso del negocio como un caso de uso. Este diagrama permite mostrar los límites y el
entorno de la organización bajo estudio. Sólo se mostrarán en este diagrama los actores
del negocio correspondientes a los roles externos al sistema, deforma que los procesos de
negocio en los que sólo tomen parte roles internos a la organización no estarán conectados
a ningún actor. En la Figurase muestra el diagrama de casos de uso del negocio para
nuestro ejemplo; es un diagrama de casos de uso UML formado por casos de uso del
negocio y actores. En el diagrama se muestra además que el agente Cliente arranca la
realización del caso de uso relacionado, mientras que Proveedor simplemente participa
en el caso de uso asociado.
Diagrama de casos de uso del negocio para el sistema de producción just in time
El siguiente paso dentro del modelado del negocio es introducirse en cada uno de los
casos de uso del negocio identificados, para describirlo en detalle. Nos centraremos en
uno de los casos de uso del negocio de nuestro ejemplo, Registrar Pedido, cuya
descripción se muestra en la figura. Esta descripción puede ser validada fácilmente por
los usuarios.
A continuación, hemos de determinar los agentes internos que juegan un rol en cada caso
de uso del negocio. Hasta el momento hemos identificado los roles que pertenecen al
entorno de la organización. Ahora es necesario estudiar la descripción de cada caso de
uso del negocio, y observar el conjunto completo de roles involucrados, tanto externos
como internos a la organización. Los roles del caso del uso del negocio Registrar pedido
son Cliente, Comercial, Jefe_Técnico, y Jefe_Producción (siendo los tres últimos internos
al sistema).
Fig. 3. Descripción del caso de uso del negocio Registrar pedido
El aspecto estructural de la colaboración entre los roles para llevar a cabo un caso de uso
del negocio, puede ser representado en un diagrama de roles, en el que cada rol (una clase
UML estereotipada) aparece asociado con los roles con los que puede colaborar (ver Fig.
4). Por tanto, este diagrama permite expresar el conocimiento que unos roles tienen de
otros, así como las características (como la multiplicidad) de cada relación entre roles.
Además, este diagrama permite también mostrar las características de los roles
identificados, tales como sus atributos y responsabilidades. Ortín y García Molina [11]
discuten con más detalle el modelado de roles con UML.
Fig. 4. Diagrama de roles para el caso de uso del negocio Registrar Pedido
Fig. 5. Diagrama de secuencia para el caso de uso del negocio Registrar Pedido
En cada proceso podemos distinguir entre el flujo básico o normal de la interacción
(en nuestro ejemplo, solicitud de un pedido que es aceptado) y los posibles flujos
alternativos (por ejemplo, rechazo o cancelación de un pedido). Para mejorar la
legibilidad, es conveniente asociar varios escenarios a un mismo caso de uso del negocio,
en lugar de mostrar en una única secuencia todas las posibilidades.
La Fig. Nuestra el diagrama de proceso que incluye el escenario de la figura. Existe una
calle por cada rol participante en el escenario, que incluye las actividades que realiza
dicho rol. El diagrama también muestra la información que necesita y produce cada
actividad, y la sincronización requerida entre las diferentes actividades. Los datos
aparecen como objetos que fluyen entre las actividades y pueden tener un estado. Por
ejemplo, la actividad Cursar pedido recibe un pedido propuesto e inicia su revisión (ver
Figura Nos referimos a estos objetos como objetos de información.
|
Diagrama de proceso para el caso de uso del negocio Registrar Pedido
En una organización, tanto los procesos como los datos que estos manejan, están
restringidos por las reglas del negocio. Con el fin de tener en cuenta todos los tipos de
reglas que aparecen en la especificación de requisitos, hemos utilizado la clasificación
descrita por James Odell [9], que distingue entre reglas de restricción (reglas de estímulo-
respuesta, reglas de restricción de operación y reglas estructurales) y reglas de derivación.
De acuerdo con esta clasificación, recogemos de manera explícita cada tipo de regla en
el modelo del negocio mediante la especificación de las actividades y objetos de
información que aparecen en los diagramas de proceso. Estas especificaciones se reúnen
en un glosario. La Fig. 7 muestra la especificación del objeto de información Pedido y de
las actividades Ordenar fabricación y Notificar aceptación de pedido.
... ...
Apartir del modelo del negocio descrito en la sección anterior, es posible obtener de
manera sistemática y directa, tanto la colección inicial de casos de uso del sistema como
el modelo conceptual preliminar. A continuación vamos a describir de manera separada
cómo obtener cada modelo.
Según nuestra experiencia, las actividades del diagrama de proceso tienen el nivel de
granularidad adecuado para ser asociadas a un caso de uso del sistema. De esta manera,
crearemos un caso de uso del sistema por cada actividad del diagrama de proceso que
deba ser soportada por el sistema software. Por tanto, el rol que lleva a cabo la actividad
será el actor principal del caso de uso. Nótese que, de acuerdo con la definición de caso
de uso, no todas las actividades del diagrama de proceso serán consideradas como casos
de uso, sino solamente aquellas que sean de valor para algún actor.
Los casos de uso se pueden organizar en varios niveles (recomendamos dos o tres como
máximo) de acuerdo con la descomposición jerárquica propuesta en el modelado del
negocio.
Cada caso de uso se describirá mediante una plantilla que puede rellenarse a partir de la
especificación de la actividad asociada, que se encuentra recogida en el glosario como ya
hemos visto. Hemos elegido la plantilla propuesta por Coleman [4] porque combina
simplicidad y completitud, como se muestra en la Fig..Una vez descrito el caso de uso, se
conectará a la especificación de la actividad asociada en el glosario, con el objeto de
mantener la trazabilidad entre los casos de uso del negocio y del sistema.
También podrían encontrarse relaciones entre los casos de uso, tales como include, si se
detectan aspectos comunes entre varios casos de uso, y extend, para expresar caminos
opcionales o alternativos en un caso de uso. No obstante, estamos de acuerdo con las
recomendaciones ampliamente extendidas de no abusar de estas relaciones y no
mostrarlas en los diagramas de casos de uso.
Para completar esta fase debemos establecer los requisitos no funcionales. Cuando estén
asociados a un caso de uso, podrán especificarse en la plantilla de caso de uso propuesta.
Los requisitos no funcionales globales se recogerán en el apartado correspondiente de la
plantilla de ERS elegida.
Los objetos de información que fluyen entre las actividades de un caso de uso del negocio
representan datos del dominio, por lo que suponen una buena base para crear el modelo
conceptual inicial. Este modelo incluirá los conceptos y sus relaciones y se describirá
mediante un diagrama de clases UML, en el que los conceptos se representan mediante
clases (del dominio).
De igual forma que conectábamos en el glosario las actividades con los casos de uso del
sistema, vincularemos cada objeto de información con la clase del dominio que lo
representa en el sistema. La Figura muestra el diagrama de clases que describe el primer
modelo conceptual de nuestro ejemplo.
Modelo conceptual inicial para el caso de uso del negocio Registrar Pedido
En esta etapa del desarrollo, merece la pena detenerse en la identificación de los conceptos
y no tanto en las relaciones entre ellos. Deberíamos concentrarnos en las asociaciones del
tipo debe conocer. Por ejemplo, a partir del glosario podemos establecer que un pedido
debe conocer al cliente que lo realiza y los productos que lo componen (ver Fig. 7). De
esta forma, alguno de los roles identificados en el modelo del negocio, y por tanto
especificado en el modelo de roles, podría ser incluido como una clase en el modelo
conceptual. Es el caso de la clase Cliente en nuestro ejemplo.
A partir del modelo del negocio, es posible identificar también qué clases tienen un
comportamiento que depende de un conjunto no trivial de estados alcanzables. En estos
casos, sería interesante definir una máquina de estados mediante un diagramas tatechart
UML. Estas clases se detectan con facilidad en los diagramas de proceso, puesto que se
corresponden con objetos de información etiquetados con varios estados diferentes. En
nuestro ejemplo, Pedido sería candidato para construir una máquina de estados que
mostrase los estados de un pedido (propuesto, en_evaluación, evaluado, aceptado y
rechazado) y los eventos que producen los cambios entre estados.
Conclusiones
Este trabajo presenta una estrategia para abordar el modelado del negocio y el análisis de
requisitos, en la que los casos de uso y el modelo conceptual se obtienen de forma sencilla,
a partir del modelo del negocio basado en el uso de diagramas de actividades UML.
Las clases del modelo conceptual se obtienen a partir de los objetos de información que
fluyen entre las actividades. Nos gustaría subrayar, como una característica importante de
nuestro enfoque, que el modelado de los casos de uso del sistema y el modelado
conceptual se realizan en paralelo, de acuerdo con Korson, quien establece que esto es
crucial para obtener casos de uso correctos, puesto que es necesario entender bien el
dominio para poder escribir casos de uso que sean realmente útiles.
El Proceso Unificado de desarrollo de software (UP) definido por Rational para UML,
incluye también el modelado del negocio como un paso más dentro de las iteraciones
necesarias que conforman el modelo del proceso. Jacobson et al. Presentan algunos pasos
que son similares a los nuestros, pero no se considera la descomposición jerárquica de los
casos de uso de nivel superior, ni tampoco se proporciona una guía clara para detectar los
casos de uso del sistema. Nuestro enfoque para el modelado del negocio constituye una
guía completa y detallada, a diferencia de las indicaciones generales presentadas en el
UP.
Consejo: La guía del usuario de EA se aprecia mejor con Internet Explorer versión 4.0
o superior.
Sus comentarios
Sparx Systems desea permanecer en contacto con las necesidades de los usuarios de
Enterprise Architect para que ejecuten sus tareas eficientemente. Nosotros evaluamos
cualquier sugerencia, comentarios que pueda tener respecto a este producto, la
documentación o el proceso de instalación. Puede acceder nuestras páginas de
comentarios en línea en:
• www.sparxsystems.com.au/bug_report.htm y
• www.sparxsystems.com.au/feature_request.htm.
Alternativamente, puede contactar a Sparx Systems en español por mail a:
suporte@sparxsystems.com.ar.
Edición Corporativa de EA
La edición Corporativa, que apunta a equipos de desarrollo grandes, soporta todo lo que
soportan las versiones de Escritorio y Profesional, más la capacidad de conectarse a los
DBMS de MySQL, SQL Server, PostgreSQL, Sybase Adaptive Server Anywhere y
Oracle 9i y 10g como repositorios compartidos. Esto provee escalabilidad adicional y
concurrencia mejorada sobre el enfoque de archivos .EAP compartidos para el uso
compartido del modelo. El soporte para Tecnologías MDG y Vínculo MDG (vendidos
por separado) está incluido con la versión Corporativa de EA. Esta edición también
soporta seguridad de usuario, acceso de usuario, grupos de usuario y bloqueo de elemento
a nivel de usuario. El soporte de la edición Corporativa para la seguridad basada en el
usuario/grupo comprende bloqueos en el diagrama y niveles de elementos. La seguridad
se provee de dos modos: en el primer modo, todos los elementos se consideran "editables"
hasta que sean explícitamente bloqueados por el usuario o grupo; en el segundo modo,
todos los elementos se consideran bloqueados hasta que sean verificados con un bloqueo
de usuario.
Edición de Escritorio de EA
Consejo: Con el fin de ayudar a comprender las diferencias entre estas ediciones y las
ventajas y restricciones de cada una, la versión de evaluación de Enterprise Architect se
puede abrir en cualquiera de las configuraciones que se desee. Cuando se inicie
Enterprise Architect, seleccione el modo que desea probar; puede reiniciar en otro modo
la próxima vez si lo desea.
Enterprise Architect soporta muchos métodos diferentes para abrir un archivo del
proyecto de EA.
Tener en cuenta:
• Muestra y trabaja en en su modelo en la ventana Explorador del proyecto, y mostrar y trabajar en un diagrama
en la Vista del diagrama.
• En el Explorador del proyecto, los contenidos de un paquete se listan en el orden diagramas | paquetes hijos |
elementos. Los elementos se arreglan aún más en el orden tipo. Dentro de sus tipos, los componentes se listan
inicialmente en orden alfabético o numérico.
Las plantillas del modelo incluidas en Enterprise Architect se designan para asistir en la creación de Proyectos y
modelos tanto para usuarios nuevos como para aquellos que ya tienen experiencia. Cada plantilla provee una
estructura sobre la cual puede crear su proyecto.
Formato de la plantilla
Todas las plantillas del modelo proporcionadas con Enterprise Architect siguen el formato que se describe a
continuación.
Nota
La nota lo introducirá a la plantilla del modelo y delinea su propósito.
Vínculos de ayuda
Estos vínculos proveerán más información acerca de como usar el modelo. Dependiendo de la plantilla del modelo,
ejemplos y otra información útil será también vinculada aquí.
Patrones
La sección del patrón en la plantilla del modelo debería darle una estructura para crear su propio modelo.
Las secciones listadas abajo proveen una introducción a la terminología e íconos usados en los plantillas del
modelo. Esto le proporcionará una guía rápida a los conceptos importantes del UML, y como estos se aplican en
Enterprise Architect.
Como un modelo temprano de actividad de negocios, permite al analista capturar eventos significantes, entradas,
recursos y salidas asociados con los procesos de negocios. Conectando después los elementos diseñados (tales
como Casos de Uso) hacia el modelo de procesos de negocio a través de vínculos de implementación, es posible
construir una trazabilidad completa del modelo desde los procesos a los requisitos funcionales y eventualmente a
los artefactos de software que están siendo construidos actualmente.
Como el Modelo de Procesos de Negocio generalmente tiene un amplio y más exclusivo rango que el sistema de
software que está siendo considerado, también permite al analista asignar claramente cual es el alcance del sistema
propuesto y que será implementado de otra manera.
Modelo de requisito
El Modelo de requisitos es un catálogo estructurado de requerimientos del usuario final y las relaciones entre ellos.
La Administración de requisitos compilada en Enterprise Architect se puede usar para definir elementos de
requerimientos, vincular requerimientos para los elementos del modelo, vincular requerimientos juntos en una
jerarquía y reportar requerimientos.
MODELO DE CASO DE USO
El Modelo de casos de uso describe la funcionalidad de un sistema en términos de Casos de uso. Cada Caso de uso
representa una sola interacción repetida que el usuario o "actor" experimenta cuando usa el sistema, acentuando la
perspectiva de los usuarios del sistema y las interacciones. Ver Casos de uso para obtener más información.
• La multiplicidad de las relaciones; por ejemplo, un empleado puede ser asignado a ningún vuelo, un vuelo o
muchos vuelos (representado por 1 y * en los finales de la relación).
MODELO DE CLASES
El Modelo de clase es un modelo riguroso y lógico del sistema de software bajo construcción. Las clases
generalmente tienen una relación directa con el código fuente y otros artefactos de software que se pueden agrupar
juntos en componentes ejecutables.
El Modelo del componente define como las clases, artefactos y otros elementos de bajo nivel se agrupan en
componentes de alto nivel, y las interfaces y conexiones entre ellos. Los componentes son artefactos de software
compilados que trabajan juntos para proveer el comportamiento requerido dentro de las restricciones de operación
definidas en el modelo de requisitos.
MODELO DE DESPLIEGUE
El Modelo de despliegue describe cómo y dónde un sistema se desplegará. Las máquinas físicas y los procesadores
son representados por nodos, y la construcción interna se puede describir embebiendo nodos y artefactos. Como los
artefactos se ubican en los nodos para modelar el despliegue del sistema, la ubicación se guía por el uso de
especificaciones de despliegue.
MODELO DE PRUEBAS
El Modelo de pruebas describe y mantiene un catálogo de pruebas, planes de prueba y resultados que se ejecutan
en comparación con el modelo actual.
MODELO DE MANTENIMIENTO
El Modelo de mantenimiento permite una representación visual de incidencias que surgen durante y después del
desarrollo del producto de software. El modelo puede ser mejorado con la integración de elementos de cambios y
pruebas.
DIAGRAMAS
Tipos de Diagramas
La figura debajo muestra la taxonomía de los 13 diagramas UML, como está definido
por la especificación de UML 2.0 de Grupos de Desarrollo de Objetos. Como se
puede ver, hay dos grupos mayoritarios de diagramas: diagramas Estructurales los
cuales muestran una vista estática del modelo; y diagramas de Comportamiento los
cuales muestran una vista dinámica del modelo. Para más detalles acerca de la
construcción de estos diagramas, haga clic en los siguientes vínculos:
DIAGRAMAS ESTRUCTURALES
DIAGRAMA DE CLASES
El diagrama de Clases captura la estructura lógica del sistema - las clases y cosas que constituyen el modelo -. Es
un modelo estático, describiendo lo que existe y qué atributos y comportamiento tiene, más que cómo se hace algo.
Los diagramas de Clases son los más útiles para ilustrar las relaciones entre las clases e interfaces. Las
generalizaciones, las agregaciones y las asociaciones son todas valiosas para reflejar la herencia, la composición o
el uso y las conexiones respectivamente.
Diagrama de ejemplo
El diagrama de abajo ilustra las relaciones de agregación entre clases. La agregación con la punta de flecha en
color claro indica que la clase Cuenta es usada por LibroDeDirecciones, pero que no está contenida
necesariamente. La agregación con la punta de flecha en color oscuro indica la posesión o la contención de las
clases destino (en el extremo del rombo) por las clases origen.
Elementos y Conectores de la Caja de Herramientas
Seleccione los elementos y conectores del diagrama de Clases desde las página Clase de la caja de herramientas
del UML de EA
Consejo: Haga clic sobre los siguientes elementos y conectores para obtener más
información.
DIAGRAMA DE OBJETOS
Un diagrama de Objetos está relacionado de cerca con un diagrama de Clases, con la diferencia de que éste
describe las instancias de los objetos de clases en un punto en el tiempo. Esto podría parecer similar al diagrama de
Estructura Compuesta, que modela el comportamiento en tiempo de ejecución; la diferencia es que el diagrama de
Objetos ejemplifica al diagrama de Clases estático, mientras que los diagramas de Estructura Compuesta refleja las
arquitecturas diferentes de sus contrapartes estáticas. Los diagramas de Objetos no presentan arquitecturas que
varíen de sus correspondientes diagramas de Clases, pero reflejan la multiplicidad y los roles a los que las clases
instanciadas podrían servir. Ellos son muy útiles en la comprensión de diagramas de Clases complejos, al crear
diferentes casos en los que se aplican las relaciones y las clases. Un diagrama de Objetos puede ser también un tipo
de diagrama de Comunicaciones, el cual modela también las conexiones entre pares de objetos y además las
secuencias de eventos a lo largo de cada camino.
Tenga en cuenta: Los diagramas de Comunicación se conocían como diagramas de Colaboración en UML 1.4.
Diagrama de ejemplo
El siguiente ejemplo primero muestra un diagrama de Clases simple, con dos elementos clase conectados.
DIAGRAMA DE COMPONENTE
Un diagrama de Componentes ilustra los fragmentos de software, controladores embebidos, etc. que
conformarán un sistema. Un diagrama de componentes tiene un nivel de abstracción más elevado que un
diagrama de clase - usualmente un componente se implementa por una o más clases (u objetos) en tiempo de
ejecución. Estos son bloques de construcción, como así eventualmente un componente puede comprender una
gran porción de un sistema.
Diagrama de ejemplo
El siguiente diagrama muestra algunos componentes y sus relaciones internas. Los conectores emsamble
"vinculan" las interfaces proporcionadas suministrada por Producto y Cliente a las interfaces requeridas
especificadas por Orden. Una relación de dependencia asigna los detalles de cuenta asociados del cliente a la
interfaz requerida, "pago", indicado por Orden.
Conectores y Elementos de la Caja de Herramientas
Seleccione los elementos y conectores del diagrama de Componente desde las páginas de Componente de la caja
de herramientas del UML de EA.
Consejo: Haga clic sobre los siguientes elementos y conectores para obtener más
información.
En un diagrama de Estructura Compuesta, las clases se acceden como partes o instancias en tiempo de ejecución
cumpliendo un rol en particular. Estas partes pueden tener multiplicidad, si el rol ocupado por la clase requiere
múltiples instancias. Los puertos definidos por una clase de parte deberían representarse en la estructura
compuesta, asegurando que todas las partes conectadas provean las interfaces requeridas especificadas por el
puerto. Hay una flexibilidad extensa, y una complejidad resultante que viene con el modelado de estructuras
compuestas. Para optimizar su modelado, considere las colaboraciones de compilación para representar los
patrones reusables respondiendo a su problemas de diseño.
Diagrama de ejemplo
El siguiente diagrama muestra una colaboración usada en diagramas de Estructura Compuesta para modelar
patrones comunes. Este ejemplo en particular muestra un relación para realizar una instalación.
El siguiente diagrama usa la colaboración instalar en una ocurrencia de colaboración, y lo aplica a la clase
UtilLoad a través de una relación <<represents>>. Esto indica que el clasificador UtilLoad usa el patron
colaboración dentro de su implementación. Para más ejemplos acerca de los diagramas de estructura
compuesta, referirse los elementos de la caja de herramientas listados a continuación.
DIAGRAMA DE DESPLIEGUE
Un diagrama de Despliegue muestra cómo y dónde se desplegará el sistema. Las máquinas físicas y los
procesadores se representan como nodos, y la construcción interna puede ser representada por nodos o artefactos
embebidos. Como los artefactos se ubican en los nodos para modelar el despliegue del sistema, la ubicación es
guiada por el uso de las especificaciones de despliegue.
Diagrama de ejemplo
Debajo hay un diagrama de Despliegue. Los dos nodos tienen una ruta de comunicación TCP/IP indicada. Las
relaciones de Despliegue indican el despliegue de artefactos. Además, una especificación de despliegue define el
proceso de despliegue para el artefacto networkScanner. Las relaciones manifestadas revelan la implementación
física de los componentes ReposCustomer y ReposInternalRecords.
Consejo: Haga clic en los siguientes elementos y conectores para obtener más información.
Diagrama de ejemplo
El ejemplo siguiente muestra un diagrama de Paquetes básico. El conector anidado entre ConnSeq y Controller
refleja lo que revela el contenido del paquete. El contenido del Paquete se puede listar accediendo en el fondo del
diagrama par amostrar la ventana Propiedades del diagrama, seleccionando la pestaña Elementos y seleccionando
la Casilla de contenidos del paquete.
El conector «import» indica que los elementos en el paquete Entero destino, que en este ejemplo es una única
clase, Entero, se importará en el paquete Controlador. El nombre de espacio del Controlador obtendrá acceso a la
clase Entero; el nombre de espacio de Entero no se afecta.
El conector «merge» indica que los elementos del paquete Controlador se importarán en GenApply, incluyendo los
contenidos anidados e importados de Controlador. Si un elemento ya existe en GenApply, tal como Cargador y
Tiempo, las definiciones de estos elementos se expandirán por aquellas que se incluyen en el paquete Controlador.
Todos los elementos agregados o actualizados por la mezcla son representados por una relación de generalización
de vuelta a este paquete.
Consejo: Haga clic sobre los siguientes elementos y conectores para obtener más
información.
Tenga en cuenta: Los Diagramas de Análisis (de Actividades simplificados) contienen los elementos que se deben
usar para modelar el proceso de negocio, que se puede crear usando la opción Nuevo Diagrama
Diagrama de Ejemplo
El siguiente diagrama muestra algunas características de los diagramas de Actividades, incluyendo actividades,
acciones, nodos de inicio, nodos de finalización y puntos de decisión.
Consejo: Haga clic en los siguientes elementos y conectores para obtener más información.
Activity Diagram Elements Activity Diagram Connectors
DIAGRAMA DE CASO DE USO
Un diagrama de Casos de Uso captura las interacciones de los casos de uso y los
actores. Describe los requisitos funcionales del sistema, la forma en la que las cosas
externas (actores) interactúan a través del límite del sistema y la respuesta del
sistema.
Diagrama de Ejemplo
El diagrama de ejemplo de abajo ilustra algunas características de los diagramas de
Casos de Uso:
Elementos y Conectores de la Caja de Herramientas
Consejo: Haga clic sobre los elementos y conectores de abajo para más
información.
Un diagrama de Máquina de estados ilustra cómo un elemento (a menudo una clase) se puede mover entre
estados, clasificando su comportamiento de acuerdo con los disparadores de transiciones y las guardas de
restricciones. Otros aspectos de los diagramas de Máquinas de Estados describen y explican el movimiento y el
comportamiento. Las representaciones de máquinas de estado en UML se basan en la notación de cuadro de
estado Harel (vea la especificación de la superestructura del UML de la OMG 2.1.1, sección 15, Máquinas de
estado), y por esta razón algunas veces se refieren a estas como cuadro de estado.
Puede mostrar un Máquina de estado como un diagrama (como a continuación) o como una tabla en uno de tres
formatos de relaciones. En todos los formatos, usa la misma caja de herramientas del UML de EA elementos and
conectores.
Diagrama de ejemplo
El diagrama de abajo ilustra algunas características de los diagramas de Máquina de Estados. El estado Guardado
es un estado compuesto, y los estados contenidos son sub-estados. Los pseudo-estados inicial y final indican la
entrada y la salida de la máquina de estados. Los estados compuestos y sub-estados son elementos de estado, un
estado compuesto es un elemento de estado extendido que comprende otros elementos de estado, los cuales son
luego referenciados como sub-estados.
Consejo: Haga clic en los siguientes elementos y conectores para obtener más información.
Elementos del diagrama de Máquina de Estado Conectores del diagrama de Máquina de estado