El Ciclo de Vida del Software

Documentos relacionados
El Ciclo de Vida del Software

El Ciclo de Vida del Software

Webinar Avantare. Dr Jorge Rafael Aguilar Cisneros Depto. Ingenierías, UPAEP.

TEMA 2: CICLO DE VIDA DEL SOFTWARE. Profesora: Elisa Herrmann

TEMA 5: INTRODUCCIÓN A LA INGENIERÍA DEL SOFTWARE. Definición de Ingeniería del Software

Conceptos Básicos de Ingeniería del Software

Desarrollo de Software a gran escala. Sesión 2: Administración de Proyectos de Software

TEMA 10: Metodologías de desarrollo de aplicaciones. El ciclo de vida según Métrica.

DESARROLLO GUIADO POR CARACTERÍSTICAS FEATURE DRIVEN DEVELOPMENT

AUTORES SOBRE DISEÑO DE SISTEMAS: 1.- KENDALL Y KENDALL:

Participantes ÍNDICE

Departamento de Lenguajes y Sistemas Informáticos. Ciclo de vida del software

ITIL V3 Entender el enfoque y adoptar las buenas prácticas

Introducción a Extreme Programming

LAS ETAPAS DE LA METODOLOGIA METRICA

Framework Atlas. Introducción. Unidad de Arquitectura y Soporte de Aplicaciones Área de Aplicaciones Especiales y Arquitectura de Software DIAS

:Universidad Salesiana de Bolivia. :Ingeniería de Sistemas PLAN DE DISCIPLINA GESTIÓN II

UNIVERSIDAD NACIONAL ABIERTA Y A DISTANCIA UNAD. ESCUELA DE CIENCIAS BASICAS TECNOLOGIA E INGENIERIA Gerencia de Proyectos Informáticos

Gerencia de la Informática

Capítulo 2 Metodologías y procesos de análisis de software

Unidad II: Metodologías de Desarrollo. 2.1 Metodologías clásicas Cascada

8 horas semanales 32 horas semestral. Suficientable

MODELO DE CASCADA PURA. Son métodos que indican cómo hacer más eficiente el desarrollo de sistemas de

Gerencia de Informática. Contexto Organizacional

Administración n de Proyectos

PLANIFICACIÓN DE INGENIERÍA DEL SOFTWARE

240EO035 - Sistemas de Información

Bloque 1. La sociedad de la información y el ordenador

Licitación Servicios de Desarrollo y Mantención de Aplicaciones AS400 y WEB. Bases Técnicas

IBM Rational Rhapsody V7.5 ofrece un ágil entorno de desarrollo de software para la creación rápida de software, documentación, requisitos y pruebas

Sistemas de Información para la Gestión

METODOLOGÍAS PARA EL DESARROLLO DE SOFTWARE EDUCATIVO Jorge Calderón William Díaz, Zulix Angulo, Neila Márquez

PERFIL COMPETENCIA ANALISTA DESARROLLADOR DE APLICACIONES DE SOFTWARE (TIC-PROG)

Overview GeneXus Qué es y para qué sirve GeneXus? Principales características y beneficios.

Ingeniería en Desarrollo de Software 3 er semestre. Programa de la asignatura: Introducción a la ingeniería de software

Norma ISO 9001: Sistema de Gestión de la Calidad

Norma ISO 15189: 2013

GERENCIA DE PROYECTOS APLICADA. Justificación:

RESUMEN EJECUTIVO DE LA VALORACIÓN DE ACTIVOS SOFTWARE DE SGAE

EL DESARROLLO DE PROYECTOS DE AUTOMATIZACIÓN DE ARCHIVOS: Cómo estructurarlos

ANEXO TÉCNICO SERVICIO DE PRUEBAS DE SOFTWARE

TÉCNICO SUPERIOR EN AUDITORÍA Y GESTIÓN DE LA CALIDAD

Desempeño Alineación Riesgo

SÍLABO DE ANÁLISIS Y DISEÑO DE SISTEMAS

Tema 2. El Ciclo de Vida del Software (ISG1-ITIG)

PROCESO DE DESARROLLO DE SOFTWARE...

Capítulo III. Fundamentos de la Manufactura Global. 3.1 Definición de manufactura Global

CURSO DE INTRODUCCIÓN A LA INGENIERÍA DEL SOFTWARE

Universidad del Este Carolina, PR Programa AHORA

TEMA 4. PROCESO UNIFICADO

Análisis y Diseño de Sistemas Departamento de Sistemas - Facultad de Ingeniería

UNIVERSIDAD DE SAN CARLOS DE GUATEMALA FACULTAD DE INGENIERIA ESCUELA DE CIENCIAS Y SISTEMAS FICHA TÉCNICA DEL CURSO: Análisis y diseño de sistemas 1

PROGRAMA DE ASIGNATURA DE ANÁLISIS Y DISEÑO DE SISTEMAS

GUÍA DEL SELLO DE EXCELENCIA EUROPEA

METODOLOGÍA COMMONKADS.

INSTITUTO DE EDUCACIÓN SUPERIOR TECNOLÓGICO HUAYCÁN (Decreto Supremo No ED y Resolución Directoral No ED)

Guía para la Administración de Riesgos

LA INTEGRACIÓN DE SISTEMAS

PLANEACIÓN ESTRATÉGICA

Algoritmos y Diagramas de flujo

Techniks es una empresa comprometida con el desarrollo de sistemas de. información de calidad y requiere de la recomendación o desarrollo de un método

La calidad. como decisión estratégica ISO 9001:2015

PMP Test C02_ La persona de la organización que autoriza el comienzo de un proyecto es:

PLAN ESTRATÉGICO DEL SERVICIO DE GESTIÓN ACADÉMICA

Tema 3. Análisis de riesgo. Tema 3. Análisis de riesgo

1 Dirección y motivación de equipos 2 Delegación de funciones 3 Cómo organizar su equipo

EVS. Estudio de Viabilidad del Sistema

La actualización de las normas ISO 9001 e ISO y la transición de la certificación de los sistemas de gestión ICONTEC

Ciclo de vida de un producto (CVP)

PERFIL DEL INGENIERO EN INFORMÁTICA DE LA UNELLEZ

Dirección y Gestión de Proyectos

CARRERA PROFESIONAL. D Electricidad Industrial Profesional Técnico D Mantenimiento de Sistemas Eléctricos Técnico

DENOMINACIÓN DE LA ACCIÓN FORMATIVA: FACEBOOK EN LA EMPRESA MODALIDAD: MIXTA NÚMERO DE HORAS: 76 (18 PRESENCIALES+ 58 DISTANCIA)

EL PROYECTO TECNOLOGICO

AUDITORIAS DEL SISTEMA DE GESTION AMBIENTAL

LECCIÓN 2 "EL PROYECTO EN LA EMPRESA"

SATCA 1 : Carrera: En la Unidad 2, Antecedentes y Estructura del CMMI proporciona al alumno las estructuras del CMMI.

CICLO DE VIDA DE LOS PROYECTOS

Sistemas de Información para la Gestión

UNIVERSIDAD TECNOLÓGICA DE PANAMÁ SECRETARÍA GENERAL FACULTAD DE INGENIERÍA INDUSTRIAL DESCRIPCION DE CURSO DE POSTGRADO EN ALTA GERENCIA

Administración de Proyectos de Tecnología Informática Unidad I Introducción

Resolución provisional de reconocimiento de créditos para el título de Grado en Ingeniería Informática

Transcripción:

23/09/2015 El Ciclo de Vida del Software Grupo de Ingeniería del Software y Bases de Datos Departamento de Lenguajes y Sistemas Informáticos Universidad de Sevilla septiembre 2015 Objetivos de este tema Conocer el concepto de del. Conocer los ciclos de vida más habituales. Conocer cómo plantean el las propuestas metodológicas más relevantes. 1 IISSI 1

23/09/2015 Qué es el del? Un marco de referencia que contiene los procesos, las actividades y las tareas involucradas en el desarrollo, la explotación y el mantenimiento de un producto, abarcando la vida del sistema desde la definición hasta la finalización de su uso (ISO 12207). 2 Qué es el del? El de un proyecto especifica el enfoque general del desarrollo, indicando los procesos, actividades y tareas que se van a realizar y en qué orden, y los productos que se van a generar, los que se van a entregar al cliente y en qué orden se van a entregar. 3 IISSI 2

23/09/2015 Ciclo de vida (en cascada) Cada fase comienza cuando termina la anterior. Asume que se conocen todos los requisitos. Se tarda mucho en disponer del. Es mejor que no seguir ningún. Es el más fácil de planificar, es el ciclo ideal. Mantenimiento 4 Por qué evolutivo? Cuanto mayor es un proyecto, menor es la probabilidad de éxito (informe CHAOS). Obtener todos los requisitos al comienzo es prácticamente imposible, las necesidades de clientes y usuarios evolucionan durante el desarrollo. Ciclos requisitos-desarrollo-evaluación El resultado de la evaluación permite evolucionar hacia la siguiente versión. Versiones Dr. Barry Boehm Creador del modelo espiral Evaluación 5 IISSI 3

23/09/2015 Ciclo de vida incremental (I) Repetición de varios ciclos de vida en cascada. Se suele aplicar a desarrollos de gran tamaño. Al final de cada ciclo se entrega una versión parcial del incrementada con cierta funcionalidad nueva respecto a las anteriores. 1 1 2 1 2 3 Versión 1 Funcionalidad 1 Versión 2 Funcionalidad 2 Versión 3 Funcionalidad 3 6 Ciclo de vida incremental (II) Los ciclos se repiten hasta obtener un producto completo. Los usuarios disponen antes del, aunque no sea completo y pueden sugerir mejoras (nuevos requisitos). 1 1 2 1 2 3 Versión 1 Funcionalidad 1 Versión 2 Funcionalidad 2 Versión 3 Funcionalidad 3 7 IISSI 4

23/09/2015 Ciclo de vida iterativo (I) Repetición de varios ciclos de vida en cascada. Se suele aplicar a desarrollos en los que los requisitos no están claros. Al final de cada ciclo se entrega una versión completa del mejorada respecto a la anterior. Versión 1 Versión 2 Versión 3 Iteración 1 Iteración 2 Iteración 3 8 Ciclo de vida iterativo (II) Las primeras versiones pueden ser prototipos que se desechan posteriormente. Los ciclos se repiten hasta obtener un producto satisfactorio. Los usuarios deben evaluar el producto en cada iteración y proponer mejoras. Versión 1 Versión 2 Versión 3 Iteración 1 Iteración 2 Iteración 3 9 IISSI 5

23/09/2015 Incremental frente a iterativo Don t Know What I Want, But I Know How to Get It Jeff Patton, 2008. http://jpattonassociates.com/ 10 Sobre los prototipos... Su uso no es exclusivo del iterativo. Se pueden usar como una herramienta para obtener y validar los requisitos de clientes y usuarios en cualquier. Lo habitual es usar prototipos de interfaz de usuario, que pueden reutilizarse (ejecutables) o desecharse (usualmente en papel, denominados mockups). 11 IISSI 6

23/09/2015 Sobre los prototipos... Siempre se debe evaluar si el esfuerzo de desarrollo del prototipo merece la pena. Es fundamental la implicación de los usuarios. Siempre se debe tener en cuenta que el prototipo no es el producto final, ya que su calidad no suele ser la necesaria. Otro tipo de prototipos, los funcionales, se utilizan para evaluar diferentes algoritmos antes de tomar decisiones de diseño. 12 Ciclo de vida en los métodos Son ciclos de vida con iteraciones de corta duración (2 semanas a 2 meses) para favorecer la comunicación con clientes y usuarios. En cada iteración se incorporan nuevas peticiones de clientes y usuarios (requisitos). Versión 1 Versión 2 Versión 3 Iteración 1 Iteración 2 Iteración 3 13 IISSI 7

23/09/2015 Ciclo de vida en los métodos Desarrollo ágil frente a tradicional Waterfall, Agile & the Triple Constraint Tom Sylvester, 2013. http://tom-sylvester.com/ 14 Ciclo de vida en los métodos Iterativo e incremental a la vez Revisiting the Iterative Incremental Mona Lisa Steven Thomas, 2012. http://itsadeliverything.com 15 IISSI 8

23/09/2015 El manifiesto ágil de 2001... 16 El manifiesto ágil de 2001... Individuos e interacciones sobre procesos y herramientas Software que funcione sobre documentación detallada Colaboración con el cliente sobre negociación de contratos Respuesta al cambio sobre seguimiento de un plan 17 IISSI 9

23/09/2015 El manifiesto ágil de 2001... No confundir los métodos con escribir código desde el primer momento sin planificar ni documentar. Fuente: http://dilbert.com/strip/2007-11-26 18 Individuos e interacciones sobre procesos y herramientas La gente es el principal factor de éxito de un proyecto. Es más importante construir un buen equipo que construir el entorno. Muchas veces se comete el error de construir primero el entorno y esperar que el equipo se adapte automáticamente. Es mejor crear el equipo y que éste configure su propio entorno de desarrollo en base a sus necesidades. 19 IISSI 10

23/09/2015 Software que funcione sobre documentación detallada La regla a seguir es no producir documentos a menos que sean necesarios de forma inmediata para tomar un decisión importante. Estos documentos deben ser cortos y centrarse en lo fundamental. 20 Colaboración con el cliente frente a negociación de contratos Se propone que exista una interacción constante entre el cliente y el equipo de desarrollo. Esta colaboración entre ambos será la que marque la marcha del proyecto y asegure su éxito. 21 IISSI 11

23/09/2015 Respuesta al cambio sobre seguimiento de un plan La habilidad de responder a los cambios que puedan surgir a los largo del proyecto (cambios en los requisitos, en la tecnología, en el equipo, etc.) determina también el éxito o fracaso del mismo. Por lo tanto, la planificación no debe ser estricta sino flexible y abierta. 22 Desarrollo ágil vs. desarrollo tradicional Ágil Basadas en heurísticas provenientes de prácticas de producción de código Especialmente preparados para cambios durante el proyecto Impuesta internamente menos controlado, con pocos principios El contrato es flexible El cliente es parte del equipo de desarrollo Equipos pequeños y/o en contacto físico Pocos artefactos Pocos roles Menor énfasis en la arquitectura Tradicional Basadas en normas provenientes de estándares seguidos por el entorno de desarrollo Presenta cierta resistencia al cambio Impuesta externamente muy controlado, con numerosas políticas y normas Contrato prefijado El cliente interactúa formalmente en reuniones Grupos grandes y/o distribuidos Numerosos artefactos Numerosos roles Arquitectura y modelos fundamentales 23 IISSI 12

23/09/2015 Técnicas de apoyo para los métodos Refactorización (refactoring) Mejoras sobre el código fuente sin cambiar su funcionalidad. automáticas programadas en lugar de realizadas a mano. Integración continua Automatización de la compilación y ejecución de pruebas automáticas. Gestión de configuración Especialmente diseñada para apoyar la interacción y la integración continua. 24 Metodología Scrum Metodología ágil más usada actualmente. Se basa en iteraciones de 30 días, sprints : Producen código potencialmente entregable. No se admiten cambios ni de requisitos ni de miembros del equipo de desarrollo http://heliosobjects.com/2014/02/20/requirements-management-in-agile-projects/ 25 IISSI 13

23/09/2015 Metodología Scrum Agile meeting: reuniones cortas y frecuentes donde cada miembro del equipo expone: Qué ha hecho desde la última reunión Qué problemas ha tenido Qué va a desarrollar hasta la próxima reunión Backlog: lista priorizada de tareas Reemplaza a los diagramas de Gantt Backlogs de producto y backlogs de iteración 26 Modelo de procesos de Scrum http://heliosobjects.com/2014/02/20/requirements-management-in-agile-projects/ 27 IISSI 14

23/09/2015 Ciclo de vida del iterativo e incremental propuesto por los creadores de UML. Define 6 fases: inicio, elaboración, construcción, transición, producción y retirada. 28 Ciclo de vida del En cada fase del desarrollo se producen una o más iteraciones y se obtiene una versión evaluable del. Desarrollo 29 IISSI 15

23/09/2015 Ciclo de vida en Metodología oficial de las Administraciones Públicas en España. permite aplicar diferentes ciclos de vida. Sus procesos básicos son: Plan de Sistemas de Información (PSI) Desarrollo de Sistemas de Información Estudio de Viabilidad del Sistema (EVS) del Sistema de Información (ASI) del Sistema de Información (DSI) Construcción del Sistema de Información (CSI) Implantación y Aceptación del Sistema (IAS) Mantenimiento de Sistemas de Información (MSI) 30 Ciclo de vida en También incluye procesos de apoyo Gestión de proyectos Seguridad Gestión de la Configuración Aseguramiento de la Calidad Puede descargarse desde http://administracionelectronica.gob.es 31 IISSI 16

23/09/2015 El modelo en V Asocia un tipo de pruebas a cada producto de cada fase según su nivel de abstracción. de Cliente Software Arquitectura validan validan validan de Sistema de Integración de Aceptación Componentes validan Unitarias 32 Ingeniería A veces es necesario mantener sistemas heredados (legacy systems) de los que no se dispone de documentación. Consiste en analizar el resultado de una fase del desarrollo de para obtener el resultado de la anterior, normalmente analizar el código para obtener el diseño. 33 IISSI 17

23/09/2015 Reingeniería La reingeniería utiliza la información obtenida por la ingeniería para aplicar cualquier tipo de mantenimiento. El mantenimiento preventivo del efecto 2000 ha sido el mayor esfuerzo de ingeniería y reingeniería en la historia de la Ingeniería del Software hasta la fecha. 34 IISSI 18