Segundo Hito: Integración continua

Descripción

El principal objetivo de este hito del proyecto es añadir integración continua al mismo. Los tres subobjetivos son aprender cómo describir la versión del lenguaje de programación que se usa y sus dependencias, elección de un sistema y sitio para integración continua y configuración de la misma.

Prerrequisitos

Haber alcanzado el 60% de los objetivos del tema introductorio tras haber realizado los ejercicios propuestos.

Descripción

En sistemas de desarrollo ágil el desarrollador tiene que asegurar que el código pasa todos los tests antes de ser desplegado o simplemente incorporado a la rama master. Para ello se escriben una serie de tests que se ejecutan automáticamente al añadir o modificar código. Estos tests tienen el fin obvio de asegurar la calidad del mismo, pero también en un entorno de desarrollo colaborativo permiten integrar código fácilmente asegurándose de que no se rompa nada. Si no está testeado, está roto, es el lema del desarrollador.

Aunque más adelante habrá que hacer tests de todo el código que se vaya a desplegar, en este hito es suficiente con que se cree una biblioteca o clase y que se hagan pasar los tests para esa biblioteca o clase, sin necesidad de escribir un programa principal o servicio que los use. Los tests son de funciones y unitarios, y como tales lo pasan las funciones. De hecho, en TDD (desarrollo basado en test) se escriben los tests antes que las funciones.

Preparar un proyecto para integración continua implica varias cosas

Esta fase de integración continua es esencial para el posterior despliegue en un PaaS o IaaS sobre el que se probarán técnicas de despliegue continuo.

Entrega de la práctica

Se tendrá que haber actualizado el repositorio que se usara en los hitos anteriores y añadir al fichero de este hito el nombre del proyecto, el autor y un enlace al mismo y hacer un pull request.

En la documentación de este hito, que se integrará como el resto en el README.md de la documentación del proyecto, se explicará por qué se ha elegido el sistema de test y de integración continua. Se recuerda que la rama master debe incluir solamente documentación sobre el proyecto. Si se quiere incluir documentación adicional se aconseja que se haga como páginas de GitHub en alguna de las formas que permite GitHub. Esta documentación, en caso de ser necesaria para entender como se ha llevado a cabo este hito (no para el proyecto) se podrá enlazar desde el README.md del mismo.

Valoración

Se recuerda que es prerrequisito haber llevado a cabo el 60% de los objetivos del tema correspondiente de la asignatura y del resto de las sesiones hasta el momento de la entrega. En caso contrario no se evaluará este hito del proyecto. Como es habitual, se recuerda al alumno que no se trata simplemente de marcar las cosas que se tienen que hacer para este hito, sino que al proyecto en esta etapa refleje que se ha entendido correctamente el concepto de un proyecto integrado de forma continua.

Si se cumplen los requisitos, la puntuación será:

Si la integración continua no funciona la práctica estará suspensa en cualquier caso, aunque se hayan configurado correctamente las herramientas de construcción.