You are on page 1of 8

Historia

El antecedente ms importante se ubica en 1967 con la Metodologa Ericsson


elaborada por Ivar Jacobson, una aproximacin de desarrollo basada en
componentes, que introdujo el concepto de Caso de Uso. Entre los aos de 1987 a
1995 Jacobson fund la compaa Objectory AB y lanza el proceso de desarrollo
Objectory (abreviacin de Object Factory).

Posteriormente en 1995 Rational Software Corporation adquiere Objectory AB y


entre 1995 y 1997 se desarrolla Rational Objectory Process (ROP) a partir de
Objectory 3.8 y del Enfoque Rational (Rational Approach) adoptando UML como
lenguaje de modelado.
Desde ese entonces y a la cabeza de Grady Booch, Ivar Jacobson y James Rumbaugh,
Rational Software desarroll e incorpor diversos elementos para expandir ROP,
destacndose especialmente el flujo de trabajo conocido como modelado del negocio.
En junio del 1998 se lanza Rational Unified Process.

Caractersticas esenciales
Los autores de RUP destacan que el proceso de software propuesto por RUP
tiene tres caractersticas esenciales: est dirigido por los Casos de Uso, est
centrado en la arquitectura, y es iterativo e incremental.

Proceso dirigido por Casos de Uso


Los Casos de Uso son una tcnica de captura de requisitos que fuerza a pensar en
trminos de importancia para el usuario y no slo en trminos de funciones que sera
bueno contemplar. Se define un Caso de Uso como un fragmento de funcionalidad
del sistema que proporciona al usuario un valor aadido. Los Casos de Uso
representan los requisitos funcionales del sistema.
En RUP los Casos de Uso no son slo una herramienta para especificar los requisitos
del sistema. Tambin guan su diseo, implementacin y prueba. Los Casos de Uso
constituyen un elemento integrador y una gua del trabajo.

Los Casos de Uso no slo inician el proceso de desarrollo sino que proporcionan un
hilo conductor, permitiendo establecer trazabilidad entre los artefactos que son
generados en las diferentes actividades del proceso de desarrollo.
Basndose en los Casos de Uso se crean los modelos de anlisis y diseo, luego la
implementacin que los lleva a cabo, y se verifica que efectivamente el
producto implemente adecuadamente cada Caso de Uso. Todos los modelos deben
estar sincronizados con el modelo de Casos de Uso.

Proceso centrado en la arquitectura


La arquitectura de un sistema es la organizacin o estructura de sus partes ms
relevantes, lo que permite tener una visin comn entre todos los involucrados
(desarrolladores y usuarios) y una perspectiva clara del sistema completo, necesaria
para controlar el desarrollo.
La arquitectura involucra los aspectos estticos y dinmicos ms significativos del
sistema, est relacionada con la toma de decisiones que indican cmo tiene que
ser construido
el sistema y ayuda a determinar en qu orden. Adems la
definicin de la arquitectura debe tomar en consideracin elementos de calidad del
sistema, rendimiento, reutilizacin y capacidad de evolucin por lo que debe ser
flexible durante todo el proceso de desarrollo. La arquitectura se ve influenciada por
la plataforma software, sistema operativo, gestor de bases de datos, protocolos,
consideraciones de desarrollo como sistemas heredados. Muchas de estas
restricciones constituyen requisitos no funcionales del sistema.
En el caso de RUP adems de utilizar los Casos de Uso para guiar el proceso se
presta especial atencin al establecimiento temprano de una buena arquitectura
que no se vea fuertemente impactada ante cambios posteriores durante la
construccin y el mantenimiento.
Cada producto (documento, modelo, elemento del modelo) tiene tanto una funcin
como una forma. La funcin corresponde a la funcionalidad reflejada en los Casos de
Uso y la forma la proporciona la arquitectura. Existe una interaccin entre los Casos
de Uso y la arquitectura, los Casos de Uso deben encajar en la arquitectura cuando se
llevan a cabo y la arquitectura debe permitir el desarrollo de todos los Casos de Uso
requeridos, actualmente y en el futuro. Esto provoca que tanto arquitectura como
Casos de Uso deban evolucionar en paralelo durante todo el proceso de desarrollo de
software.
La evolucin de la arquitectura durante las fases de RUP es una implementacin
parcial del sistema, construida para demostrar algunas funciones y propiedades
RUP establece refinamientos sucesivos de una arquitectura ejecutable, construida
como un prototipo evolutivo.

Es conveniente ver el sistema desde diferentes


perspectivas para comprender mejor el diseo por lo
que la arquitectura se representa mediante varias
vistas que se centran en aspectos concretos del
sistema, abstrayndose de los dems. Para RUP,
todas las vistas juntas forman el llamado
modelo 4+1 de la arquitectura, el cual recibe este
nombre porque lo forman las vistas lgica, de
implementacin, de proceso y de despliegue, ms la
de Casos de Uso que es la que da cohesin a todas.
Al final de la fase de elaboracin se obtiene una primera aproximacin de la
arquitectura donde fueron seleccionados una serie
de
Casos
de
Uso
arquitectnicamente relevantes, aquellos que ayudan a mitigar los riesgos ms
importantes, aquellos que son los ms importantes para el usuario y aquellos que

cubran las funcionalidades significativas.


Durante la construccin los diversos modelos van desarrollndose hasta completarse.
La descripcin de la arquitectura sin embargo, no debera cambiar significativamente
(abajo a la derecha) debido a que la mayor parte de la arquitectura se decidi
durante la elaboracin. Se incorporan pocos cambios a la arquitectura.

Proceso iterativo e incremental


El equilibrio correcto entre los Casos de Uso y la arquitectura es algo muy parecido al
equilibrio de la forma y la funcin en el desarrollo del producto, lo cual se consigue
con el tiempo. Para esto, la estrategia que se propone en RUP es tener un proceso
iterativo e incremental en donde el trabajo se divide en partes ms pequeas o mini
proyectos. Permitiendo que el equilibrio entre Casos de Uso y arquitectura se vaya
logrando durante cada mini proyecto, as durante todo el proceso de desarrollo. Cada
mini proyecto se puede ver como una iteracin (un recorrido ms o menos completo
a lo largo de todos los flujos de trabajo fundamentales) del cual se obtiene un
incremento que produce un crecimiento en el producto.
Una iteracin RUP puede realizarse por medio de una cascada de etapas. Se pasa por
los flujos fundamentales (Requisitos, Anlisis, Diseo, Implementacin y Pruebas),
tambin existe una planificacin de la iteracin, un anlisis de la iteracin y algunas
actividades especficas de la iteracin. Al finalizar se realiza una integracin de los
resultados con lo obtenido de las iteraciones anteriores.
El proceso iterativo e incremental consta de una secuencia de iteraciones. Cada
iteracin aborda una parte de la funcionalidad total, pasando por todos los flujos de
trabajo relevantes y refinando la arquitectura. Cada iteracin se analiza cuando
termina. Se puede determinar si han aparecido nuevos requisitos o han cambiado los
existentes, afectando a las iteraciones siguientes. Durante la planificacin de los
detalles de la siguiente iteracin, el equipo tambin examina cmo afectarn los
riesgos que an quedan al trabajo en curso. Toda la retroalimentacin de la iteracin
pasada permite reajustar los objetivos para las siguientes iteraciones. Se contina
con esta dinmica hasta que se haya finalizado por completo con la versin actual del
producto.

Principios clave
El RUP est basado en 3 principios clave que son:

Adaptar el proceso
El proceso deber adaptarse a las caractersticas propias del proyecto u
organizacin. El tamao del mismo, as como su tipo o las regulaciones que lo
condicionen, influirn en su diseo especfico. Tambin se deber tener en
cuenta el alcance del proyecto.

Equilibrar prioridades
Los requerimientos de los diversos participantes pueden ser diferentes,
contradictorios o disputarse recursos limitados. Debe encontrarse un equilibrio
que satisfaga los deseos de todos. Gracias a este equilibrio se podrn corregir
desacuerdos que surjan en el futuro.

Demostrar valor iterativamente


Los proyectos se entregan, aunque sea de un modo interno, en etapas iteradas.
En cada iteracin se analiza la opinin de los inversores, la estabilidad y calidad
del producto, y se refina la direccin del proyecto as como tambin los riesgos
involucrados

Ciclo de vida
El ciclo de vida RUP es una implementacin del Desarrollo en espiral. Fue creado
ensamblando los elementos en secuencias semi-ordenadas. El ciclo de vida organiza
las tareas en fases e iteraciones.
RUP divide el proceso en cuatro fases, dentro de las cuales se realizan varias
iteraciones en nmero variable segn el proyecto y en las que se hace un mayor o
menor hincapi en las distintas actividades. En la Figura muestra cmo vara el
esfuerzo asociado a las disciplinas segn la fase en la que se encuentre el proyecto
RUP.

FASES (iteraciones)

Esfuerzo en actividades segn fase del proyecto (ciclo de vida del proyecto)

Las primeras iteraciones (en las fases de Inicio y Elaboracin) se enfocan hacia la
comprensin del problema y la tecnologa, la delimitacin del mbito del proyecto, la

eliminacin de los riesgos crticos, y al establecimiento de una primera aproximacin o


lnea base de la arquitectura.
Durante la fase de inicio las iteraciones hacen mayor nfasis en actividades de
modelado del negocio y de requerimientos.
En la fase de elaboracin, las iteraciones se orientan al desarrollo de la lnea base de
la arquitectura, abarcan ms los flujos de trabajo de requerimientos, modelo de
negocios (refinamiento), anlisis, diseo y una parte de implementacin orientado a la
lnea base de la arquitectura.
En la fase de construccin, se lleva a cabo la construccin del producto por medio de
una serie de iteraciones (implementacin, pruebas y muestra del sistema).
Para cada iteracin se selecciona algunos Casos de Uso, se refina su anlisis y diseo y
se procede a su implementacin y pruebas. Se realiza una pequea cascada para cada
ciclo. Se realizan tantas iteraciones hasta que se termine la implementacin deseada
de la nueva versin del producto.
En la fase de transicin se pretende garantizar que se tiene un producto preparado
para su entrega a la comunidad de usuarios con el fin de que la prueben.
Como se puede observar en cada fase participan todas las disciplinas, pero que
dependiendo de la fase el esfuerzo dedicado a una disciplina o actividad vara.

Otras prcticas
RUP identifica 6 prcticas deseables con las que define una forma efectiva de trabajar
para los equipos de desarrollo de software.

Gestin de requisitos
RUP brinda una gua para encontrar, organizar, documentar, y seguir los cambios
de los requisitos funcionales y restricciones. Utiliza una notacin de Caso de Uso y
escenarios para representar los requisitos.

Desarrollo de software iterativo


Desarrollo del producto mediante iteraciones con hitos bien definidos, en las
cuales se repiten las actividades pero con distinto nfasis, segn la fase del
proyecto.

Desarrollo basado en componentes


La creacin de sistemas intensivos en software requiere dividir el sistema en
componentes con interfaces bien definidas, que posteriormente sern
ensamblados para generar el sistema. Esta caracterstica en un proceso de
desarrollo permite que el sistema se vaya creando a medida que se

obtienen o se desarrollan sus componentes.

Modelado visual (usando UML)


UML es un lenguaje para visualizar, especificar, construir y documentar los
artefactos de un sistema software. Es un estndar de la OMG. Utilizar
herramientas de modelado visual facilita la gestin de dichos modelos,
permitiendo ocultar o exponer detalles cuando sea necesario. El modelado visual
tambin ayuda a mantener la consistencia entre los artefactos del sistema:
requisitos, diseos e implementaciones. En resumen, el modelado visual ayuda a
mejorar la capacidad del equipo para gestionar la complejidad del software.

Verificacin continua de la calidad


Es importante que la calidad de todos los artefactos se evale en varios puntos
durante el proceso de desarrollo, especialmente al final de cada iteracin. En
esta verificacin las pruebas juegan un papel fundamental y se integran a lo
largo de todo el proceso. Para todos los artefactos no ejecutables las revisiones e
inspecciones tambin deben ser continuas.

Gestin de los cambios


Los cambios son un factor de riesgo crtico en los proyectos de software. Los
artefactos de software cambian no slo debido a acciones de mantenimiento
posteriores a la entrega del producto, sino que durante el proceso de desarrollo,
especialmente importantes por su posible impacto son los cambios en los
requisitos. Por otra parte, otro gran desafo que debe abordarse es la
construccin de software con la participacin de mltiples desarrolladores,
posiblemente distribuidos geogrficamente, trabajando a la vez en una entrega y
quizs en distintas plataformas. La ausencia de una disciplina rpidamente
conducira al caos. La Gestin de Cambios y de Configuracin es la disciplina de
RUP encargada de este aspecto.

Estructura del proceso


El proceso puede ser descrito en dos dimensiones o ejes.
Eje horizontal: Representa el tiempo y es considerado el eje de los aspectos
dinmicos del proceso. Indica las caractersticas del ciclo de vida del proceso
expresado en trminos de fases, iteraciones e hitos. Se puede observar en la
Figura 8 que RUP consta de cuatro fases: Inicio, Elaboracin, Construccin y
Transicin. Como se mencion anteriormente cada fase se subdivide a la vez en
iteraciones.
Eje vertical: Representa los aspectos estticos del proceso. Describe el proceso en
trminos de componentes de proceso, disciplinas, flujos de trabajo, actividades,
artefactos y roles.
Los casos de uso integran el flujo o las actividades.

Estructura Dinmica del proceso. Fases e iteraciones

RUP se repite a lo largo de una serie de ciclos que constituyen la vida de un producto.
Cada ciclo concluye con una generacin del producto para los clientes. Cada ciclo
consta de cuatro fases: Inicio, Elaboracin, Construccin y Transicin. Cada fase se
subdivide a la vez en iteraciones, el nmero de iteraciones en cada fase es variable.
Cada fase se concluye con un hito (entregable) bien definido, un punto en el tiempo
en el cual se deben tomar ciertas decisiones crticas y alcanzar las metas clave
antes de pasar a la siguiente fase, ese hito principal de cada fase se compone de
hitos menores que podran ser los criterios aplicables a cada iteracin. Los hitos para
cada una de las fases son:

Inicio - Lifecycle Objectives


Elaboracin - Lifecycle Architecture
Construccin - Initial Operational Capability
Transicin - Product Release.

La duracin y esfuerzo dedicado en cada fase es variable dependiendo de las


caractersticas del proyecto. Sin embargo, Se ilustra porcentajes frecuentes al
respecto.

Inicio
Esfuerzo

5%

Tiempo
Dedicado
Recursos

10 %
10 %

Elaboraci
n
20
30
15 %

Construcci
n
65

Transici
n
10%

50
50 %

10%
25 %

Distribucin tpicas de esfuerzo y tiempo


Consecuente con el esfuerzo sealado, se ilustra una distribucin tpica de recursos
humanos necesarios a lo largo del proyecto.

You might also like