10 actividades crÃticas a incluir en todo plan de desarrollo de
Transcription
10 actividades crÃticas a incluir en todo plan de desarrollo de
Facultad de Ciencias Naturales e Ingenierías Tecnología en Desarrollo de Sistemas Informáticos Planeación de Sistemas Informáticos Página 1 de 5 TALLER 1. 2. 3. 4. En grupos de tres personas. Realice la Lectura la lectura que se encuentra a continuación. Hagan una análisis de las actividades y discutan cuales consideran de mayor relevancia. Seleccione 5 que ustedes consideren de mayor importancia y justifique su Respuesta. 10 actividades críticas a incluir en todo plan de desarrollo de un software Tomado de: http://www.pmoinformatica.com/2012/10/10-actividades-criticas-incluir-en-todo.html En el mundo de la informática, los clientes e inclusive nuestros Gerentes y Directores, esperan que cuando nos presenten un problema de ingeniería de software estemos en capacidad de responder de inmediato ¿para qué fecha cree usted que podría estar desarrollado y entregado? Sin embargo, debe tenerse extremo cuidado al proporcionar fechas, pues los desarrollos de software suelen presentar muchos imponderables, que deben ser cuidadosamente analizados. Una de las peores situaciones que se le pueden presentar a un analistas-programador de software, arquitecto, líder de equipo o Gerente de proyecto, es darse cuenta en la mitad de la ejecución, que actividades críticas no fueron consideradas cuando se planificó y comunicó una fecha de entrega. En este artículo, se exploran una serie aspectos con frecuencia omitidos, pero que deben considerarse en la planificación de todo desarrollo de software. Estos aspectos van desde los tiempos para aprobaciones de los diseños, integraciones de códigos, instalación de ambientes de prueba, entre otros. Para ayudar a los analistas-programadores, líderes de grupo y Gerentes de Proyectos de Software en esta tarea, presentamos a continuación las actividades críticas que no deben faltar en un plan de desarrollo de software. Introducción La planificación toma tiempo de realizar, tratar de acelerarla es incrementar innecesariamente los riesgos de proyectos de software, los cuales de por sí ya son de alto riesgo debido a los retos que suelen enfrentar. Ing. Karina Ramírez Duran catedrajkarinar@gmail.com Facultad de Ciencias Naturales e Ingenierías Tecnología en Desarrollo de Sistemas Informáticos Planeación de Sistemas Informáticos Página 2 de 5 Las actividades que debe incluir un plan de desarrollo de un software son conocidas por la comunidad informática, Análisis, Diseño, Desarrollo, Pruebas e Implementación. La secuencia en que se ejecutan puede cambiar dependiendo del enfoque metodológico, si es predictivo, iteraciones planeadas, o ágil. Estas actividades macro esconden aspectos críticos que deben ser anticipados y gestionados para llevar a feliz término el proyecto. Las actividades expuestas a continuación, deben ser consideradas en la planificación de tiempo o (el cronograma) y de recursos del proyecto, es decir tiempo y esfuerzo de analistasprogramadores, analistas de pruebas u otros integrantes. Actividades críticas a incluir en todo plan de proyecto de desarrollo de software 1.- Lapsos de correcciones y aprobación de los diseños de software: Al recibirse un diseño del software, debe asumirse que presentará errores o dudas, por lo que es necesario considerar tiempos para revisarlo, comunicar las correcciones, realizaras y volver a revisar. Adicionalmente, el diseño debe ser aprobado, lo cual puede suponer enviar un correo o documento físico y buscar las firmas. Entre más larga sea la lista de involucrados, más puede tardar la aprobación. Por supuesto, siempre se podrá comenzar a desarrollar para no retrasar el proyecto, sin embargo, si se solicita algún cambio después podría implicar retrabajo. 2.- Instalación del ambiente de desarrollo La instalación del ambiente de desarrollo para cada analista programador, así como de los servidores de aplicación, base de datos o de otro tipo compartidos por el equipo es una actividad predecesora obligatoria para comenzar el desarrollo. Se puede realizar en paralelo con el análisis y diseño, sin embargo, debe tomarse en cuenta que depende de recursos como equipos de computación y personal del área de tecnología e implica configuraciones de aplicaciones, bases de datos y de otro tipo que pudieran tener incertidumbre en su duración. Adicionalmente, si es un desarrollo complejo con múltiples desarrolladores, podría implicar la habilitación de un controlador de versiones, descarga de las últimas fuentes de código, homologación de fuentes de código y bases de datos con el ambiente de producción. Ing. Karina Ramírez Duran catedrajkarinar@gmail.com Facultad de Ciencias Naturales e Ingenierías Tecnología en Desarrollo de Sistemas Informáticos Planeación de Sistemas Informáticos Página 3 de 5 3.- Dudas sobre los diseños que se presenten durante el desarrollo No existe el diseño de software que sobreviva intacto la fase de desarrollo, siempre surgirán dudas funcionales y técnicas, sobre las cuales será necesario hacer comunicaciones y esperar respuestas de personas, las cuales, al no estar dedicadas al proyecto, pudieran ocasionar retraso. Por ende, se debe asumir en la planificación que las dudas sobre el diseño se presentarán, asignando tiempo y esfuerzo para su resolución. 4.- Integraciones de código de distintos desarrolladores Durante el desarrollo, múltiples trabajos podrían estarse realizando en paralelo por distintos analistas programadores en distintas capas (por ejemplo Bases de datos, aplicación y presentación). Cada una de estas partes será probada, pero ¿Qué hay de la integración? y ¿no debemos probar después de integrar?. Deben contemplarse tiempos para integraciones de código y las pruebas de esa integración antes de entregarlo al equipo de pruebas. 5.- Integraciones de código de otros proyectos En el punto anterior abarcamos las integraciones de código de un mismo proyecto, pero, ¿qué ocurre si tenemos varios proyectos en paralelo sobre un mismo sistema o aplicación?, o por ejemplo si algún otro equipo de desarrollo realizó una implementación en producción durante la ejecución de nuestro proyecto. Será necesario integrar con la última fuente de código y homologar nuevamente los ambientes de bases de datos. Asimismo, ¿qué ocurre cuando existen varios proyectos paralelos?, pues debe analizarse la hoja de ruta del conjunto de proyectos, verificando la fecha de implementación en producción, decidiendo en función de esto las integraciones a realizar, tomando en consideración que esto crea dependencias entre proyectos. 6.- Instalación del ambiente de pruebas El hecho que el producto desarrollado este empaquetado y entregado al equipo de pruebas no significa que estas pueden comenzar, primero se necesita realizar la instalación o despliegue (dependiendo de la tecnología en que se desarrolle) en el ambiente de pruebas. Si se trata de un ambiente compartido en la organización, esto podría implicar solicitar tiempo al administrador en horario no laborable, realizar la instalación, probar, corregir posibles errores de despliegue, entre otras actividades. Por ende, es recomendable contemplar las mismas en la planificación. 7.- Preparación de pruebas Ing. Karina Ramírez Duran catedrajkarinar@gmail.com Facultad de Ciencias Naturales e Ingenierías Tecnología en Desarrollo de Sistemas Informáticos Planeación de Sistemas Informáticos Página 4 de 5 ¿Y qué hay de la preparación de las pruebas?, en cuanto al diseño de casos y recopilación de los datos de prueba. ¿Qué ocurriría si esperamos a que el desarrollo esté entregado para comenzar a hacer esto?, ¿no retrasaría esto el proyecto? Por ende, lo recomendable es contemplar la actividad en la planificación y comenzar a ejecutarla en paralelo con el desarrollo, para que esté terminada al momento de iniciar las pruebas. 8.- Correcciones de errores (bugs) ¿Podemos asumir que la ejecución de pruebas ocurrirá sin errores?, consideramos que no, de hecho, la experiencia indica que algunos errores pueden ser difíciles de analizar y corregir, e inclusive tardar más en ser remediados que la prueba en sí. Debe considerarse en la planificación los tiempos y recursos (léase tiempo de los analistasprogramadores) para corregir estas incidencias. Usualmente, se pueden calcular como una fracción o porcentaje de la ejecución de pruebas. 9.- Cambios de alcance La teoría del desarrollo de sistemas y de la gerencia de proyectos nos dice que si ocurre un cambio de alcance, el impacto del mismo debe ser considerado en tiempo y recursos, resultando en muchos casos en un incremento del presupuesto y movimiento de la fecha, pero, ¿ocurre así en la realidad?, ¿está dispuesto un cliente final a aprobarle un cambio en la fecha o presupuesto?, ¿Qué ocurre si son muchos cambios de bajo esfuerzo?. Usualmente este tipo de situaciones resultan en negociaciones con el cliente, en la cual se dicen cosas como, ¿no se realizó una fase de análisis del proyecto?, ¿Por qué es un cambio de alcance, no debió haber sido identificado en esa fase?, ¿No es el trabajo del Gerente de Proyectos el prevenir estas situaciones? En todo caso, los proyectos de desarrollo de software por su naturaleza intangible están sujetos a tener cambios cuando el cliente los prueba, por ende, ¿Por qué no considerar dichos posibles cambios en la planificación?, (por ejemplo como una holgura para ajustes y modificaciones). Ing. Karina Ramírez Duran catedrajkarinar@gmail.com Facultad de Ciencias Naturales e Ingenierías Tecnología en Desarrollo de Sistemas Informáticos Planeación de Sistemas Informáticos Página 5 de 5 Cabe destacar que los enfoques de desarrollo ágil atiende este tema de forma muy eficiente, al incorporar la elaboración progresiva que permite al cliente realizar cambios a su producto de software. 10.- Período de soporte posimplantación ¿El desarrollo del software termina con su puesta en producción?, ¿qué hay del llamado período de estabilización de la solución?, ¿Quién atiende las dudas de los usuarios con el uso del producto?, ¿Quién evalúa si se están reportando falsos errores?, o ¿Cómo se responde ante un error real?. En todo caso, y dado que el software por lo general se produce bajo períodos de garantía, es necesario contemplar en la planificación la ocupación de analistas programadores y analistas de pruebas, quienes brindarán soporte durante el período de estabilización. Durante este período, se realizará la transferencia de conocimientos al equipo de soporte de la organización, hasta que esté en capacidad de brindar dicho soporte y termine el período de garantía. Conclusión Las actividades que se han mencionado son con frecuencia omitidas en la planificación, sobre todo cuando es preparada de forma apresurada y no se le da tiempo suficiente al desarrollador, al equipo de trabajo y al Gerente de proyectos de analizar todas las premisas, ocasionando la no identificación de todos los recursos y riesgos antes de presentar una fecha de entrega. Ing. Karina Ramírez Duran catedrajkarinar@gmail.com