Ingeniería de Software: Parte 2 Agustín J. González ElO329: Diseño y Programación Orientados a Objeto Adaptado de:

Slides:



Advertisements
Presentaciones similares
Ciclo de vida de desarrollo de software
Advertisements

Metodologías ágiles.
PROCESO Y MODELOS EN LA INGENIERIA DE SOFTWARE
Guía metodológica para la gestión de proyectos de software en PyMEs que no son fábricas de software por medio de Metodologías ágiles.
METODOLOGÍAS ÁGILES “PROCESO UNIFICADO ÁGIL (AUP)
Guía metodológica para la gestión de proyectos de software en PyMEs que no son fábricas de software por medio de Metodologías ágiles.
Rational Unified Process (RUP)
¿Qué es RUP? RUP es un proceso de desarrollo de software: Objetivos:
2010 Enterprise Unified Process (EUP)
Modelos de Proceso del Software
Ingeniería del Software
Ingeniería de Software Agustín J. González ElO329: Diseño y Programación Orientados a Objeto Tomado de:
PLANEACION DE UNA ESTRUCTURA ORGANIZACIONAL
Análisis y Diseño Orientado a Objetos utilizando UML
Propuesta de una metodología para el desarrollo de proyectos informáticos empleando la herramienta para el diseño automatizado GeneXus Autor: Dipl.-Ing.
CARRERA ING.DE SISTEMAS INTEGRANTE: DANIEL SORIA MURILLO DOCENTE: ING. ERVIN FLORES MATERIA: INGENIERIA DE SOFTWARE GESTION 2009.
Ingeniería de Software
3.- Introducción al Proceso Unificado
Ingeniería de Software Orientado a Objetos
Ingeniería de Software: Metodologías Agustín J. González ElO329: Diseño y Programación Orientados a Objeto Adaptado de:
Rational Unified Process (RUP)
Desarrollos de Software Orientados a Objetos usando UML
Gestión de Proyectos Informáticos Sesión N° 5 Ciclo de Vida de un Proyecto Roberto Jijena I.
1 Diseño Orientado a Objetos Agustín J. González ELO-329: Diseño y Programación Orientados a Objetos 1er. Sem
Ingeniería de Software Agustín J. González ElO329: Diseño y Programación Orientados a Objeto Adaptado de:
Ingeniería de Software: Metodologías Agustín J. González ElO329: Diseño y Programación Orientados a Objeto Adaptado de:
Ingeniería del Software
Rational Unified Process (RUP)
2.- Planificación Básica DEPARTAMENTO DE INGENIERÍA INFORMÁTICA
VII Congreso de Expotecnología UVM 2007 Jonás A. Montilva C.
Universidad Central de Venezuela Facultad de Ciencias Postgrado en Ciencias de la Computación Sistemas Distribuidos Albany Márquez.
Ximena Romano – Doris Correa
Ingeniería de Software
1 Diseño Orientado al Objeto Agustín J. González ELO-326: Seminario de Computadores II 2do. Sem
Ingeniería de Software
Motivación ELO329: Diseño y programación orientados a objetos Agustín J. González 1s07.
INTRODUCCIÓN A LA INGENIERÍA DEL SOFTWARE
VISIÓN GENERAL DE LA IS Con independencia del modelo de proceso hay tres fases genéricas: Fase de definición Fase de desarrollo Fase de mantenimiento Cada.
Ingeniería de Software I
Rational Unified Process
Proyecto de Ingeniería de Software Grupo Nº 9 - GXPost (Desarrollo con GeneXus 8.0) Evaluación de la Fase Construcción (Jueves 4 de Noviembre de.
Alexander Aristizabal Ángelo flores herrera
Motivación ELO329: Diseño y programación orientados a objetos Agustín J. González 1s09.
Roles de Open UP.
UML.
METODOLOGÍAS ÁGILES “PROCESO UNIFICADO ÁGIL (AUP)
Relación con otras asignaturas del plan de estudio
Introducción al proceso de verificación y validación.
Actividades en el Proceso de desarrollo de Software
Modelo Prescriptivos de proceso
Estructurar tus ideas para hacerlas realidad
Motivación ELO329: Diseño y programación orientados a objetos Agustín J. González 1s08.
 Requisitos Capturar, definir y validar los casos de uso Realizar los casos de uso Verificar que se satisfacen los casos.
Proceso de desarrollo de Software
CONCEPTO DE CICLO DE VIDA 1 En los departamentos de Sistemas se debe definir un marco de referencia común que debe ser:  Pueda ser empleado por todos.
UTFSM - Departamento de Electrónica1 Noviembre de 2003 “Beneficios del Uso de Metodologías en el Desarrollo de Proyectos”
Software de Comunicaciones
ELO-329: Diseño y Programación Orientados a Objetos1 Proceso de Desarrollo de SW Agustín J. González ElO329: Diseño y Programación Orientados a Objeto.
Fundamentos de Ingeniería de Software
Sobre el Proceso Racional Unificado RUP es un proceso para el desarrollo de un proyecto de un software que define claramente quien, cómo, cuándo y qué.
P ROCESO U NIFICADO R ACIONAL R ATIONAL U NIFIED P ROCESS.
1 Tema 2: Introducción al proceso unificado de desarrollo de software.
Presentación De UML Lenguaje estándar para escribir planos de software Se usa para visualizar, especificar, construir y documentar los artefactos de un.
VERIFICACIÓN Y VALIDACIÓN DE SISTEMAS 3.10 Fase de manejo de requerimientos 4.1 Modelado de pruebas en UML Ponente: ing. Alejandro tapia vazquez.
Entregables del Proyecto
Flujos de Trabajo Fundamentales Proceso Unificado de Desarrollo de Software.
Ingeniería de Software: Metodologías Agustín J. González ElO329: Diseño y Programación Orientados a Objeto Adaptado de:
Fase de Inicio Proceso Unificado de Desarrollo de Software.
1  Introducción a Rational Unified Process (RUP) Profesor Abraham Oliver Jara Miranda – JornSoft S.A.
Transcripción de la presentación:

Ingeniería de Software: Parte 2 Agustín J. González ElO329: Diseño y Programación Orientados a Objeto Adaptado de: entre otras fuentes.

Algunas Metodologías... Personal Software Process y Team software Process XP (Programación Extrema)‏ RUP (Rational Unified Process)‏ La familia Cristal de Cockburn Código Abierto ASD (Desarrollo de Software Adaptable)‏ SCRUM FFD (Desarrollo Manejado por Rasgos)‏ DSDM (Método de desarrollo de sistema dinámico)‏ Yo no conozco todas, pero vale la pena conocer al menos una. Aquellas en rojo son populares.

RUP...

Desarrollo de software: Características de RUP... Guiado y Manejado por Casos de Uso Centrado en la Arquitectura Iterativo e Incremental Desarrollo Basado en Componentes Utilización de UML Proceso Integrado

Casos de uso: Idea general Un caso de uso es una colección de escenarios de éxito y fallas relacionados que describen actores usando el sistema para alcanzar algún objetivo. Un escenario es una secuencia específica de acciones e interacciones entre actores y el sistema bajo discusión. Un actor es algo externo al sistema discusión que interactúa con éste. Por ejemplo: Una persona, otro sistema computacional, un sensor, etc. Los casos de uso muestran el comportamiento observable del sistema.

Principales metodologías en el tiempo Tiempo Modelo Tradicional de Cascada 1980 Tiempo Definición de Requerimientos Análisis & Diseño Implementación y Test Unitarios Construcción/Pruebas t t Iteración 1Iteración 2Iteración 3 P C A&D R P C R P C R Modelo Iterativo Incremental 1990 Integración y test del sistema Operación y mantención

Pruebas funcionales Pruebas de desempeño Gestión de requisitos Gestión de cambios y configuración Ingeniería de Negocio Ingeniería de datos Diseño de interfaces Rational Unified Process 1998 Rational Objectory Process Objectory Process Enfoque Ericsson UML Rational Unified Process (RUP)

Tiempo Esfuerzo Necesario por Actividad TransiciónElaboraciónConstrucciónConcepción Iteración Preliminar.... Iteración 1 Iteración Iteración n Iteración n+1 RUP Define Fases de Desarrollo... Análisis & Diseño Construcción Pruebas Distribución Requerimientos Áreas de trabajo (Workflow)‏ A & D C P D R C P D R C P D R C P D R

Fases del Ciclo de Vida  El ciclo de vida consiste en una serie de ciclos, cada uno de los cuales produce una nueva versión del producto  Cada ciclo está compuesto por fases y cada una de estas fases está compuesta por un número de iteraciones  Las fases son 4: Concepción, Inicio o Estudio de oportunidad Elaboración Construcción Transición

...Fases del Ciclo de Desarrollo  Inicio o Estudio de oportunidad (inception)‏ Define el ámbito y objetivos del proyecto Se define la funcionalidad y capacidades del producto  Elaboración Tanto la funcionalidad como el dominio del problema se estudian en profundidad Se define una arquitectura básica Se planifica el proyecto considerando recursos disponibles

...Fases del Ciclo de Desarrollo Construcción El producto se desarrolla a través de iteraciones donde cada iteración involucra tareas de análisis, diseño e implementación Las fases de estudio y análisis sólo dieron una arquitectura básica que es aquí refinada de manera incremental conforme se construye (se permiten cambios en la estructura)‏ Gran parte del trabajo es programación y pruebas Se documenta tanto el sistema construido como el manejo del mismo Esta fase proporciona un producto construido junto con la documentación

...Fases del Ciclo de Desarrollo Transición Se libera el producto y se entrega al usuario para un uso real Se incluyen tareas de marketing, empaquetado atractivo, instalación, configuración, entrenamiento, soporte, mantenimiento, etc. Los manuales de usuario se completan y refinan con la información anterior Estas tareas se realizan también en iteraciones

 El ciclo de vida iterativo se basa en la evolución de prototipos ejecutables que se muestran a los usuarios y clientes  En el ciclo de vida iterativo, en cada iteración se reproduce el ciclo de vida en cascada a menor escala  Los objetivos de una iteración se establecen en función de la evaluación de las iteraciones precedentes Proceso Iterativo e Incremental

Análisis Diseño Codific. Pruebas e Integración n veces... Proceso Iterativo e Incremental Las actividades se encadenan en una mini- cascada con un alcance limitado por los objetivos de la iteración

... Proceso Iterativo e Incremental Cada iteración comprende: Planificar la iteración (estudio de riesgos)‏ Análisis de los Casos de Uso y escenarios Diseño de opciones arquitectónicas Codificación y pruebas. La integración del nuevo código con el hecho en iteraciones anteriores se hace gradualmente durante la construcción Evaluación de la entrega de ejecutable (evaluación del prototipo en función de las pruebas y de los criterios definidos)‏ Preparación de la entrega (documentación e instalación del prototipo)‏

ConcepciónElaboraciónConstrucciónTransición Compromiso de recursos para fase elaboración Hito Objetivos, visión Hito Arquitectura Hito Capacidad Operacional Aceptación del cliente Liberación Producto Tiempo Importancia de los Hitos en RUP...

 Deployment Set  Project Management Set  Configuration & Change Management Set  Environment Set  Business Modeling Set  Requirements Set  Analysis & Design Set  Implementation Set  Test Set... Elementos en RUP Artefactos Es el Resultado parcial o final que es producido y usado durante el proyecto. Son las entradas y salidas de las actividades Un artefacto puede ser un documento, un modelo o un elemento de modelo Conjuntos de Artefactos

Mejores Prácticas de RUP... Controle los Cambios Administre los Requerimientos Use Arquitectura de Componentes Modele Visualmente Verifique Calidad Desarrolle Iterativamente

Características Esenciales de RUP Proceso Dirigido por los Casos de Uso Proceso Iterativo e Incremental Proceso Centrado en la Arquitectura

La arquitectura de un sistema es la organización o estructura de sus partes más relevantes Un arquitectura ejecutable es una implementación parcial del sistema, construida para demostrar algunas funciones y propiedades RUP establece refinamientos sucesivos de una arquitectura ejecutable, construida como un prototipo evolutivo Architecture InceptionElaborationConstruction Transition

Otra visión similar con más Actividades

Disciplinas o áreas de trabajo Modelado del Negocio Requisitos Análisis y Diseño Implementación Pruebas Despliegue, distribución Entorno Gestión de configuración y cambios Gestión del proyecto Primarios De Apoyo

Requisitos Capturar, definir y validar los casos de uso Realizar los casos de uso Verificar que se satisfacen los casos de uso Análisis & Diseño Implementación Pruebas Casos de Uso integran el trabajo Proceso dirigido por los Casos de Uso

Caso de Uso Realización de Análisis Realización de Diseño Caso de Prueba X «trace» Pruebas Funcionales Pruebas Unitarias [The Unified Software Development Process. I. Jacobson, G. Booch and J. Rumbaugh. Addison-Wesley, 1999]... Proceso dirigido por los Casos de Uso

Enfoque Cascada Enfoque Iterativo e Incremental Proceso Iterativo e Incremental Grado de completitud de cada área de trabajo

Grado de Finalización de Artefactos... Proceso Iterativo e Incremental

15% 10% 15% 30% 15% Preliminary Iteration(s)‏ iter. #1 iter. #2 iter. #n iter. #n+1 iter. #n+2 iter. #m iter. #m+1 InceptionElaborationConstructionTransition Una iteración en la fase de elaboración Requisitos Diseño Implementación Pruebas Análisis Esfuerzo respecto de las Áreas de Trabajo (Workflows)‏

Preliminary Iteration(s)‏ iter. #1 iter. #2 iter. #n iter. #n+1 iter. #n+2 iter. #m iter. #m+1 InceptionElaborationConstructionTransition Una iteración en la fase de elaboración Requisitos Diseño Implementación Pruebas Análisis Esfuerzo: 5%20% 65% 10% Duración: 10%30% 50% 10%...Esfuerzo respecto de las Fases

Un Ejemplo: Comparar con V-Model (Motorola)‏

Dos lecciones importantes El tiempo es independiente del contexto. Ahorrar una semana la comienzo de un proyecto es tan bueno como ahorrarla al final. Una semana es una semana. Es mucho más fácil ahorrar tiempo al inicio del proyecto (cuando los “entregables” son menos claros). Conclusión: Cómo se aplica esto al proyecto del ramo?