Proceso Unificado de Desarrollo

Embed Size (px)

DESCRIPTION

procesos

Citation preview

Proceso Unificado de DesarrolloProceso Unificado de Desarrollo

Concepto:Un proceso define quin est haciendo qu, cundo y cmo para alcanzar un determinado objetivo

Proceso Unificado de Desarrollo (RUP):es una metodologa de desarrollo de software que est basado en componentes e interfaces bien definidas, y junto con elLenguaje Unificado de Modelado (UML), constituye la metodologa estndar ms utilizada para el anlisis, implementacin y documentacin de sistemas orientados a objetos.Es un proceso que puede especializarse para una gran variedad de sistemas de software, en diferentes reas de aplicacin, diferentes tipos de organizaciones, diferentes niveles de aptitud y diferentes tamaos de proyecto.RUP no es un sistema con pasos firmemente establecidos, sino un conjunto de metodologas adaptables al contexto y necesidades de cada organizacin.Es el resultado de varios aos de desarrollo y uso prctico en el que se han unificado tcnicas de desarrollo, a travs del UML, y trabajo de muchas metodologas utilizadas por los clientes. La versin que se ha estandarizado vio la luz en 1998 y se conoci en sus inicios como Proceso Unificado de Rational 5.0; de ah las siglas con las que se identifica a este proceso de desarrollo.

Un poco de historiaLos orgenes deRUPse remontan al modelo espiral original de Barry Boehm. Ken Hartman, uno de los contribuidores claves de RUP colabor con Boehm en la investigacin. En1995Rational Software compr una compaa sueca llamada Objectory AB, fundada por Ivar Jacobson, famoso por haber incorporado los casos de uso a los mtodos de desarrollo orientados a objetos.El Rational Unified Process fue el resultado de una convergencia de Rational Approach y Objectory (el proceso de la empresa Objectory AB). El primer resultado de esta fusin fue el Rational Objectory Process, la primera versin de RUP, fue puesta en el mercado en1998, siendo el arquitecto en jefe Philippe Kruchten.Principales ElementosComo RUP es un proceso, en su modelacin define como sus principales elementos:Trabajadores (quin):Define el comportamiento y responsabilidades (rol) de un individuo, grupo de individuos, sistema automatizado o mquina, que trabajan en conjunto como un equipo. Ellos realizan las actividades y son propietarios de elementos.Actividades (cmo):Es una tarea que tiene un propsito claro, es realizada por un trabajador y manipula elementos.Artefactos (qu):Productos tangibles del proyecto que son producidos, modificados y usados por las actividades. Pueden ser modelos, elementos dentro del modelo, cdigo fuente y ejecutables.Flujo de actividades (cundo):Secuencia de actividades realizadas por trabajadores y que produce un resultado de valor observable.Caractersticas Principales de RUPo Unifica los mejores elementos de metodologas anteriores.o Preparado para desarrollar grandes y complejos proyectos.o Orientado a Objetos.o Utiliza el UML como lenguaje de representacin visual.Principales ventajaso Coste del riesgo a un solo incremento.o Reduce el riesgo de no sacar el producto en el calendario previsto.o Acelera el ritmo de desarrollo.o Se adapta mejor a las necesidades del cliente.Ciclo de vida de RUPEl ciclo de vida de RUP se caracteriza por:Dirigido por casos de uso:Los casos de uso reflejan lo que los usuarios futuros necesitan y desean, lo cual se capta cuando se modela el negocio y se representa a travs de los requerimientos. A partir de aqu los casos de uso guan el proceso de desarrollo ya que los modelos que se obtienen, como resultado de los diferentes flujos de trabajo, representan la realizacin de los casos de uso (cmo se llevan a cabo).

Centrado en la arquitectura:La arquitectura muestra la visin comn del sistema completo en la que el equipo de proyecto y los usuarios deben estar de acuerdo, por lo que describe los elementos del modelo que son ms importantes para su construccin, los cimientos del sistema que son necesarios como base para comprenderlo, desarrollarlo y producirlo econmicamente. RUP se desarrolla mediante iteraciones, comenzando por los CU relevantes desde el punto de vista de la arquitectura. El modelo de arquitectura se representa a travs de vistas en las que se incluyen los diagramas de UML.

Iterativo e Incremental:Una iteracin involucra actividades de todos los flujos de trabajo, aunque desarrolla fundamentalmente algunos ms que otros.Por ejemplo, una iteracin de elaboracin centra su atencin en el anlisis y diseo, aunque refina los requerimientos y obtiene un producto con un determinado nivel, pero que ir creciendo incrementalmente en cada iteracin.Es prctico dividir el trabajo en partes ms pequeas o miniproyectos. Cada miniproyecto es una iteracin que resulta en un incremento. Las iteraciones hacen referencia a pasos en los flujos de trabajo, y los incrementos, al crecimiento del producto. Cada iteracin se realiza de forma planificada es por eso que se dice que son miniproyectos.Flujo de Trabajo de RUPEn RUP se han agrupado las actividades en grupos lgicos definindose 9 flujos de trabajo principales, los 6 primeros son conocidos como flujos de ingeniera y los tres ltimos como flujos de apoyo.oModelo del Negocio:Describe los procesos de negocio, identificando quines participan y las actividades que requieren automatizacin.oRequerimiento:Define qu es lo que el sistema debe hacer, para lo cual se identifican las funcionalidades requeridas y las restricciones que se imponen.oAnlisis y Diseo:Describe cmo el sistema ser realizado a partir de la funcionalidad prevista y las restricciones impuestas (requerimientos), por lo que indica con precisin lo que se debe programar.oImplementacin:Define cmo se organizan las clases y objetos en componentes, cules nodos se utilizarn y la ubicacin en ellos de los componentes y la estructura de capas de la aplicacin.oPrueba (Testeo):Busca los defectos a los largo del ciclo de vida.oInstalacin o despliegue:Produce release del producto y realiza actividades (empaque, instalacin, asistencia a usuarios, etc.) para entregar el software a los usuarios finales.oAdministracin del proyecto:Involucra actividades con las que se busca producir un producto que satisfaga las necesidades de los clientes.oAdministracin de configuracin y cambios:Describe cmo controlar los elementos producidos por todos los integrantes del equipo de proyecto en cuanto a: utilizacin/actualizacin concurrente de elementos, control de versiones, etc.oAmbiente:Contiene actividades que describen los procesos y herramientas que soportarn el equipo de trabajo del proyecto; as como el procedimiento para implementar el proceso en una organizacin.FasesCada fase representa un ciclo de desarrollo en la vida de un producto de software.

La fase deconcepcin o iniciotiene por finalidad definir la visin, los objetivos y el alcance del proyecto, tanto desde el punto de vista funcional como del tcnico, obtenindose como uno de los principales resultados una lista de los casos de uso y una lista de los factores de riesgo del proyecto. El principal esfuerzo est radicado en el Modelamiento del Negocio y el Anlisis de Requerimientos. Es la nica fase que no necesariamente culmina con una versin ejecutable.Lafase deelaboracintiene como principal finalidad completar el anlisis de los casos de uso y definir la arquitectura del sistema, adems se obtiene una aplicacin ejecutable que responde a los casos de uso que la comprometen. A pesar de que se desarrolla a profundidad una parte del sistema, las decisiones sobre la arquitectura se hacen sobre la base de la comprensin del sistema completo y los requerimientos (funcionales y no funcionales) identificados de acuerdo al alcance definido.

Lafase deconstruccinest compuesta por un ciclo de varias iteraciones, en las cuales se van incorporando sucesivamente los casos de uso, de acuerdo a los factores de riesgo del proyecto. Este enfoque permite por ejemplo contar en forma temprana con versiones el sistema que satisfacen los principales casos de uso. Los cambios en los requerimientos no se incorporan hasta el inicio de la prxima iteracin.Lafase detransicinse inicia con una versin beta del sistema y culmina con el sistema en fase de produccin.HitosFasesHitos

Conceptualizacin - InicioObjetivos (visin)

ElaboracinArquitectura

ConstruccinFuncionalidad operativa

TransicinRelease del sistema

Diferencias de RUP con las dems metodologasAlgunos aspectos que diferencian a RUP de las dems metodologas y lo que lo hace nico es que en RUP, los casos de uso no son slo una herramienta para especificar los requisitos del sistema, sino que tambin guan su diseo, implementacin y prueba. Los casos de uso constituyen un elemento integrador y una gua del trabajo.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. Tambin este propone que cada fase se desarrolle en iteraciones.

Fuente E.V.A. UCI, I. D. S.Conferencia #1. Introduccin a la Ingeniera de Software, ISW 1. http://www.ecured.cu/index.php/Proceso_Unificado_de_Desarrollo