691 likes | 1.76k Views
Tema 5. Identificación de fases, tareas y entregables en los proyectos informáticos. Jose Onofre Montesa Andrés Universidad Politécnica de Valencia Escuela Universitaria de Informática 2000. Objetivo. Descomponer el esfuerzo estimado en tareas. Para esto identificaremos:
E N D
Tema 5. Identificación de fases, tareas y entregables en los proyectos informáticos Jose Onofre Montesa Andrés Universidad Politécnica de Valencia Escuela Universitaria de Informática 2000
Objetivo • Descomponer el esfuerzo estimado en tareas. • Para esto identificaremos: • Entregables del proyecto, • Fases del proyecto y • Tareas del proyecto.
Métodos de descomposición: • Por PROCESOS • Diferentes fases conceptuales • ¿Que?, ¿Como?, Realización, Pruebas ... • Por PRODUCTOS • Detectamos diferentes productos que conformaran el sistema que nos piden. • Ej.: Facturación, Control de Stocks, ...
Estará enfocado a un solo producto. • Razones: • Tamaño de un proyecto - riesgo de fracaso. • Costes de coordinación. • Actualmente de desarrollo incremental. • Lo lógico en que la “dirección estratégica” es quien se encargue de identificar los productos más necesarios para la empresa.
Descomposición en actividades del proyecto (WBS). • Work Breakdown Structure (WBS) • método de representar de forma jerárquica los componentes de un proceso o producto.
0.Proyecto Contabilidad. 1.Especificar necesidades. 1.1.Estudiar Sistema Actual. 1.2.Añadir Nuevas Características. 2.Analizar Contabilidad. 2.1.Estudiar Procesos. 2.2.Estudiar Datos. 3.Diseñar Aplicación. 3.1.Diseño B.D. 3.2.Diseño Programas. 4.Codificación. 4.1.Construcción del esquema. 4.2.Codificación de los Programas 5.Pruebas 5.1.Prueba de Unidades 5.2.Prueba del Sistema Representación en lista del WBS
WBS • La numeración facilita la localización de las tareas en el WBS. • Los nodos se leen como: • es un componente de … • forma parte de … • Construcción: • Nombrar el nodo inicial, • Poner en torno a 72 en cada nivel. • Las tareas son las hojas del árbol.
Ficha de Tarea Especificación de tarea Número: 3.1. Nombre: Diseño B.D. Descripción: Se diseñara la base de datos, partiendo del modelo entidad-relación propuesto en el análisis y con el objetivo de tener un sistema funcionando sobre DB2. Esfuerzo Estimado: 2 semanas/hombre Entregables: Estructura de implementación de la B.D. ……………: ……………………………
Entregables de un proyecto informático. • Definición: • "Productos que, en un cierto estado, se intercambian entre los clientes y los desarrolladores a lo largo de la ejecución del proyecto informático". • Relativos: • Al objetivo. • A la gestión proyecto.
Hay que definir un conjunto mínimo de Entregables. • Que nos proveen de: • Del conjunto de componentes que formaran el producto una vez finalizado el desarrollo. • Los medios para medir el progreso y la calidad del producto en desarrollo. • Los materiales necesarios para la siguiente etapa.
Entregables usuales. Estudio de viabilidad: • Descripción breve del sistema propuesto y sus características. • Descripción breve de las necesidades del negocio en el sistema propuesto. • Propuesta de organización del equipo de desarrollo y definición de responsabilidades. • Estudio de los costes, que contendrán estimaciones groseras de la planificación y fechas, tentativas, de entrega de los productos. • Estudio de los beneficios que producirá el sistema.
Entregables del Análisis: • Captura de requisitos: • Análisis del sistema actual (si existe). • Requisitos nuevos de los usuarios. • Descripción del sistema propuesto. • Especificación del sistema • Descripción del sistema (DFDs, etc.). • Requisitos de datos. • Requisitos de telecomunicaciones. • Requisitos de hardware. • Plan de pruebas de integración.
Entregables del Diseño: • Descripción detallada del sistema, contendrá: • Programas, módulos reutilizables y objetos. • Ficheros y bases de datos. • Transacciones • Diccionario de datos • Procedimientos • Carga del sistema y tiempos de respuesta • Interfaces, tanto humanos como de máquinas.
Entregables del Diseño: • Descripción de los controles del sistema propuestos. • Diseños alternativos recomendados. • Estándares de programación y diseño de programas, recomendados. • Técnicas de implementación recomendadas: codificación propia, compra de paquetes, contratación externa, etc. • Plan de pruebas de programas.
Entregables de la Codificación: • Documentos del diseño final del sistema y de cada programa. • Diagramas definitivos del sistema y de los programas. • Descripción detallada de la lógica de cada programa. • Descripción de las Entradas y Salidas (ficheros, pantallas, listados, etc.).
Entregables de la Codificación: • Listado de los programas, conteniendo comentarios. • Cadenas de ejecución si es necesario (JCL, scripts, etc.). • Resultado de las pruebas de cada unidad. • Resultado de las pruebas de cada programa.
Entregables de la Codificación: • Resultado de las pruebas de la integración. • Guía para los operadores del sistema. • Programa de entrenamiento de los operadores. • Manual de usuario del sistema.
Entregables de las Pruebas: • Plan de pruebas del sistema (actualizado). • Informe de los resultados de las pruebas. • Descripción de las pruebas, el resultado esperado, resultado obtenido y acciones a tomar para corregir las desviaciones. • Resultados de las pruebas a la documentación.
Entregables de la Instalación: • Planes detallados de contingencias de explotación, caídas del sistema y recuperación. • Plan de revisión post-instalación. • Informe de la instalación. • Carta de aceptación del sistema.
Entregables del Mantenimiento: • Listado de fallos detectados en el sistema. • Listado de mejoras solicitadas por los usuarios (si no dan lugar a nuevos proyectos). • Traza detallada de los cambios realizados en el sistema. • Actas de las revisiones regulares del sistema y aceptación de los niveles de soporte.
A todos estos documentos hay que añadir en todas las fases documentos con la estimación y planificación de la próxima fase y del resto del proyecto. También habrá que ir actualizando el índice de todo el material relacionado.
Descomposición en fases del desarrollo de un sistema. • Desde hace tiempo muchas empresas clasifican los tipos de tareas que se realizan en un proyecto y analizan el esfuerzo dedicado a cada una. • Veremos los ejemplos que da Martyn A. Ould, así como un ejemplo de HP.
Descomposición del desarrollo de la aplicación en tareas. • Por entregables (¿más de una semana?) • Dos niveles del horizonte. • Inmediato • Medio Plazo
Enfoque de equipo en identificar tareas, por actividades • Implicar a los desarrolladores. • Utilizar sus conocimientos y experiencia. • La percepción del trabajador. • Sumisión a los objetivos • Responsabilización
Formas usuales de identificar tareas asociadas a un entregable. • Documentarse, Buscar o Investigar, • Organizar, Escribir Documentos, • Verificar, Comprobar, • Revisar, Actualizar Documentos, • Entregar, Finalizar • Otros medios: • Descomposición que nos proveen las técnicas utilizadas
Tareas usuales de un proyecto informático. • Estudio de viabilidad • Análisis • Diseño • Codificación • Pruebas • Instalación • Mantenimiento
Estudio de viabilidad: • Analizar el sistema propuesto • Escribir una descripción. • Definir y documentar posibles sistemas. • Analizar el coste de sistemas similares. • Estimar el tamaño del sistema, la planificación y los costes. (tener en cuenta los entregables mas importantes).
Estudio de viabilidad: • Definir cualitativa y cuantitativamente los beneficios del sistema propuesto. • Realizar una planificación inicial del plazo de recuperación de la inversión. • Realización de una estimación detallada de costes, planificación, recursos, etc., de la siguiente fase (Análisis).
Estudio de viabilidad: • Asignar director del proyecto. • Composición del documento de estudio de viabilidad. • Presentación del documento de viabilidad a la dirección para su aprobación.
Análisis: Captura de requisitos: • Definir el ámbito del sistema propuesto • Funciones, Dimensiones, Usuarios, Restricciones • Entrevista a todos los usuarios propuestos y actuales: • Determinar: • Utilización del sistema actual • Deficiencias del sistema actual • Requisitos nuevos del sistema
Análisis: Captura de requisitos: (continua) • Documentar: • Descripción del sistema actual • Deficiencias del sistema actual • Producir el documento de requisitos del nuevo sistema • Requisitos del usuario priorizados • Resoluciones sobre las deficiencias del sistema actual
Análisis: Captura de requisitos: (continua) • Producir una lista de los beneficios tangibles e intangibles ( un refinamiento de la lista del estudio de viabilidad) • Realización de una estimación detallada de costes, planificación, recursos, etc., de la siguiente fase (Especificación del sistema).
Análisis: Captura de requisitos: (continua) • Producir una estimación revisada de costes, planificación, recursos, etc., para el resto del proyecto. • Producir el documento de definición de requisitos; esta tarea incluye la construcción de un prototipo.
Análisis: Captura de requisitos: (continua) • Realizar una revisión final del documento de requisitos. • Tomar la decisión de continuar o no con el proyecto. • Definir las responsabilidades en la próxima fase para el director, miembros del equipo de desarrollo y otros.
Análisis: Especificación del sistema: • Definir el tipo de sistema propuesto: ¿Sistema basado en transacciones? ¿Distribuido o centralizado? ¿Estaciones de trabajo o terminales? • Esquematizar el sistema propuesto: transformar los requerimientos del usuario de la fase anterior en unas especificaciones funcionales.
Análisis: Especificación del sistema: • Construir el diccionario de datos. Si existe DD de la empresa, hacerlo compatible. • Revisar y expandir el análisis de coste beneficio. • Realización de una estimación detallada de costes, planificación, recursos, etc., de la siguiente fase (Diseño del sistema).
Análisis: Especificación del sistema: • Producir una estimación revisada de costes para el resto del proyecto. • Producir el documento de especificación del sistema. • Realizar una revisión final del documento de especificación del sistema.
Análisis: Especificación del sistema: • Tomar la decisión de continuar o no con el proyecto. • Definir las responsabilidades en la próxima fase para el director, miembros del equipo de desarrollo y otros.
Diseño: • Producir el diseño global del sistema. • Localización de paquetes software. • Desarrollar un diseño detallado del sistema, por alternativa de diseño planteada • Revisar y expandir el análisis de coste beneficio para cada alternativa. • Evaluar las alternativas de diseño, para cada alternativa.
Diseño: • Desarrollo de un plan de test del sistema: • Desarrollar un plan de test diferenciado para cada alternativa. • Identificar las necesidades de entrenamiento y documentación de los usuarios; definir las guías. • Producir el documento de diseño del sistema.
Diseño: • Realizar una revisión final del documento de diseño del sistema. • Tomar la decisión de continuar o no con el proyecto. • Recomendar una alternativa.