Skip to content

Latest commit

 

History

History
513 lines (418 loc) · 26.7 KB

metodologias-agiles-de-desarrollo-de-software.md

File metadata and controls

513 lines (418 loc) · 26.7 KB

Metodologías ágiles de desarrollo de software

  • En esta sesión realizaremos una introducción a los temas y conceptos que vamos a estudiar en la asignatura.
  • Repasaremos algunos conceptos que todos conocemos, pero dándoles la orientación específica que vamos a utilizar en la asignatura.

  • Es importante comprobar qué entendemos por desarrollo de software antes de empezar la asignatura.
  • Hay tantas formas de hacer un desarrollo como empresas/desarrolladores.
  • No hay que ser dogmático: en la asignatura vamos a estudiar una idea general de cómo se debe hacer un buen desarrollo de un proyecto usando las denominadas metodologías ágiles. Cada empresa/desarrollador adapta estas ideas a sus propios procesos. Y cada metodología tiene sus condiciones de uso y situaciones en las encaja mejor.
  • Haremos un esquema en la pizarra conforme se contestan las preguntas.

  • Las metáforas ayudan a establecer una cultura, un estilo común de trabajo en el equipo o en la empresa. Una cultura proporciona un conjunto de reglas invisibles que todos cumplimos de forma casi automática. Estas reglas proporcionan un contexto común y favorecen que todos nos movamos en una dirección similar.
  • Un excelente ejemplo de cultura ingenieril es la de Spotify, explicada en dos excelentes vídeos de Henrik Kniberg: Spotify engineering culture (part 1) y Spotify engineering culture (part 2).

  • El software es multidimiensional, se puede considerar desde muchos puntos de vista. Por eso hay múltiples metáforas, todas ellas correctas porque resaltan uno de sus aspectos.

  • Una metáfora que no se ha comentado demasiado es el software como una publicación periódica. Igual que en un periódico o una revista, de forma periódica se lanza una nueva versión en la que hay que introducir nuevas funcionalidades. Cada vez se populariza más la idea de entregas (releases) con una periodicidad fija.

    También se está empezando a utilizar la suscripción como forma de monetizar software (por ejemplo, el editor Ulysses en la AppStore Why we’re switching Ulysses to Subscription).

  • El artículo de Martin Fowler The new methodology explica perfectamente por qué la metáfora de la construcción no es buena: el desarrollo de software no es una actividad predictiva, sino adaptativa (más sobre ello en otras diapositivas).

  • Una de las características distintivas más importantes del software, frente a otros productos desarrollados por otras ingenierías, es la facilidad de su modificación. Una casa, una vez construida, es muy difícil de modificar. Los ciclos de modificación de productos de consumo como teléfonos móviles, ordenadores, televisores, automóviles, etc. son de meses o años.
  • El software es totalmente distinto en este aspecto: es posible escribir y publicar una actualización en minutos o horas.
  • El software debe ser soft.

  • Obligatorio leer y estudiar el artículo de Martin Fowler The new methodology que explica la diferencia entre las ingenierías tradicionales y la ingeniería del software. El artículo también proporciona una buena introducción a las metodologías ágiles (la nueva metodología):
    • Uno de los puntos más importantes del artículo es el que argumenta que los requerimientos de un proyecto software no son predecibles.
    • La forma de controlar un proceso no predecible es mediante iteraciones cortas.
    • El enlace original al artículo de Martin Fowler es este.

  • En agosto de 2017 tuvo mucha repercusión el caso de un ingeniero de Google (James Damore) que distribuyó entre las redes internas de la empresa un informe escrito por él que ponía en cuestión la política de diversidad de Google (consultar en la Wikipedia). Google promueve de forma activa la incorporación de mujeres en los distintos equipos de la empresa, para intentar compensar el problema de la falta de mujeres en empresas tecnológicas. El informe salió a la luz pública, creó una gran polémica y Google zanjó el tema despidiendo a Damore por incumplir el código de conducta de la empresa.

  • Se publicaron en las redes muchas opiniones en contra del informe y la postura de Damore. Un artículo en concreto, el escrito en Medium por Yonathan Zunger (So, about this Googler’s manifesto.) merece que le dediquemos un tiempo, por hacer una reflexión muy interesante sobre qué considera el autor que es una ingeniería (en concreto, el desarrollo de software):

    • La gente que está empezando a hacer ingeniería piensa que lo fundamental es pasarse todo el día delante del ordenador haciendo cosas como hyper-optimizar un bucle o limpiar el API de una clase. Es cierto que cuando estás empezando en un trabajo de ingeniero/a en esto consiste la mayor parte de tu trabajo: algo directo y limitado que puede hacerse bien o mal, sin matices, y en donde vas aprendiendo las habilidades básicas. Más adelante, cuando coges experiencia, llega el momento en el que haces ingeniería de verdad: tu trabajo ya no sólo es hacer, sino tomar decisiones.

    • La ingeniería no es el arte de construir dispositivos; es el arte de resolver problemas, mejorar la vida de las personas. Los dispositivos (software en nuestro caso) no son un fin, sino un medio. Resolver problemas significa lo primero de todo entenderlos. Y eso significa entender a las personas, sus preferencias, las formas en las que interactuarán con nuestro sistema. Todo esto es fundamental cuando estamos construyendo un sistema. Todo el equipo debe conocer profundamente el producto que se está construyendo.

    • Una gran parte del trabajo del desarrollo de software es comunicación y colaboración; dentro del equipo y con otros grupos.

      • De esta forma se consigue construir un único sistema, coherente y con características claras, en lugar de veinte sistemas diferentes.
      • La comunicación es fundamental para gestionar las dependencias y los riesgos.
      • Así se puede diseñar los límites de modularidad correctos que hacen fácil continuar evolucionando el producto en el futuro.
  • En septiembre de 2018 Linus Torvald publicó una disculpa sobre su actitud en la comunidad de desarrollo del kernel de Linux (de la que es líder), en la que a veces ha utilizado un tono arrogante, irrespetuoso y nada comprensivo con los errores.

  • Juego de palabras en inglés: build the right thing y build the thing right.
  • Una buena metodología sirve para construir un producto fiable, mantenible, en el tiempo correcto.
  • Tan importante como eso es diseñar el conjunto de características (features) que satisfacen mejor los objetivos finales del proyecto: software que funciona (working software).

  • La forma de desplegar un producto software para que pueda ser usado por los clientes ha cambiado mucho en los últimos años.
  • Las aplicaciones web hacen posible despliegues instantáneos de nuevas versiones.
  • Un enlace a la wikipedia con la explicación de qué es un disquete, para todos los que no los hayan conocido.

  • El valor de un proyecto, o de una funcionalidad, es lo satisfecho que se queda el cliente cuando lo usa.
  • Es difícil comprobar el valor de una funcionalidad hasta que no se usa de verdad.
  • El software en funcionamiento es un sistema complejo en el que participan usuarios, otro software, datos, etc.

  • El concepto de deuda técnica aparecerá más de una vez en la asignatura: parches, o arreglos rápidos que hacemos en el software para que funcione, pero que son muy difíciles de mantener y adaptar.
  • Es una metáfora. Como cualquier deuda, tarde o temprano tendremos que pagarla. Una buena explicación sobre el concepto, con bastante detalle, la puedes encontrar en este post de Javier Garzás.

  • Cada proyecto se puede ver como la combinación de un presupuesto (dinero), un alcance (lo que hay que hacer) y el tiempo disponible. Y estos tres factores se condicionan, unos a otros. Si se reduce el presupuesto, se puede ver afectado el alcance o el tiempo del proyecto. Si se reduce el tiempo, habrá que reducir el alcance o aumentar el presupuesto. Y si, por ejemplo, se aumenta el alcance (las cosas que hay que entregar), habrá que aumentar el presupuesto y/o el tiempo. Todo ello si se quiere mantener la misma calidad.

  • Una práctica usual de gestión de proyectos software dice que el cliente puede fijar hasta dos de estas tres dimensiones, pero tiene que dejar libre la tercera. Así, si fija el presupuesto y el alcance, debe dejar que sea el equipo de desarrollo quien diga cuánto tiempo. Si el cliente fija tiempo y alcance, debe ser flexible en presupuesto. Y si fija tiempo y presupuesto, debe ser flexible en el alcance.

  • El mito del hombre-mes se desmonta (entre otros mitos) en el famoso libro de Frederick Brooks.

  • Un proyecto con éxito es el resultado de una buena combinación de cuatro elementos: personas, proceso (metodología), producto (alcance y complejidad del software a desarrollar) y tecnología utilizada.
  • Un cambio grande en alguna de estas dimensiones es una decisión de gran calado, que habría que realizar al comienzo de un nuevo proyecto. En los proyectos en marcha se pueden realizar ajustes y pequeños experimentos que permitan comprobar cómo mejorar.

  • En el modelo de cascada el conjunto de requisitos está totalmente definido y cerrado.
  • Se piensa que el trabajo creativo, de diseño, es sólo la fase de especificación de requisitos, y que el resto del proceso es "picar código".
  • El cliente sólo prueba el producto desarrollado al final de todo el proceso.
  • Problemas: demasiado tiempo para probar una versión en funcionamiento, el testing al final hace muy difícil la rectificación, la integración con otros desarrollos es es misión imposible, el software entregado no cumple con las necesidades del cliente, porque los requisitos desarrollados no son los que realmente resuelven su problema.

  • Una de las características más importantes del modelo en V es que se muestra gráficamente la relación los distintos niveles de abstracción del desarrollo. Además, cada nivel de desarrollo tiene pruebas específicas que lo validan. Existen pruebas de aceptación de los requisitos, pruebas de diseño del sistema, que validan la arquitectura, pruebas de integración y pruebas unitarias. Las pruebas se diseñan al mismo tiempo que el software en cada uno de los niveles.
  • Aunque se ha mejorado en lo referente a las pruebas, el problema sigue siendo el mismo que el anterior: no hay retroalimentación del software en funcionamiento hasta el momento final.

  • Ya os habrán contado el chiste del columpio en el árbol en alguna otra asignatura. La moraleja es muy visual: cada uno interpreta a su manera lo que el cliente necesita. Es un ejemplo muy visual de la importancia de escuchar bien al cliente y saber interpretar y descubrir sus necesidades.
  • Las distintas imágenes están sacadas de un artículo en el que se explica la historia del chiste.

  • El modelo en espiral es un antecesor de los modelos de desarrollo ágil.
  • Un desarrollo basado en prototipos permite tener una retroalimentación rápida y determinar pronto que funcionalidades son las que sirven y cuáles las que no. También permite mejorar la estimación del tiempo necesario para terminar el proyecto final.
  • Un prototipo no tiene el 100% de la implementación de cada funcionalidad, pero permite comprobar el funcionamiento de distintos aspectos (usabilidad de las funcionalidades de cara al usuario, rendimiento, funcionamiento de la arquitectura, etc.).
  • El cliente puede probar pronto el prototipo e indicar posibles modificaciones.
  • El uso de prototipos es habitual en otros disciplinas, como el diseño de productos (con impresoras 3D) o el cine y los videojuegos (con modelos y escenas de baja fidelidad).

  • Cada ciclo contiene las 4 fases importantes del desarrollo de software:

    • Análisis de requisitos: recogida de requisitos necesarios que debe cumplir el software.
    • Diseño: estudio y descomposición de esos requisitos en partes a implementar.
    • Codificación: implementación de cada una de las partes del diseño.
    • Integración y prueba: integración del desarrollo en el producto y prueba de que se cumplen los requisitos.
  • Al final de cada iteración se debe tener un producto completo, usable y entregable (no un prototipo).

  • Muchas palabras en un único cartel: adaptabilidad, automatización, cadencia, frecuencia, propiedad, calidad, transparencia, unidad, tubería, backlogs, burnchats, velocidad, tests, producción, despliegue, flujo de trabajo, build, integración, testing, XP, colaboración, devops, ...
  • Veremos muchas de ellas en la asignatura.
  • La imagen del samurai la hemos tomado prestada de la portada de un interesante libro: The Agile Samurai.

  • El objetivo del desarrollo es resolver un problema del cliente. Ya hemos comentado que esto implica un proceso iterativo de diseño en el va a ser obligado reajustes de dirección y cambios en el proyecto.
  • "No sabemos lo que no sabemos": el proceso de desarrollo también es un proceso de exploración en las necesidades del cliente mediante la comunicación continua.
  • Una vez terminado el proyecto siempre va a haber que mantenerlo. Se puede cobrar una licencia semestral o anual para mantenimiento básico: actualizaciones básicas, solución de bugs, adaptación a nuevas versiones de librerías y dependencias.
  • Las necesidades de cambios en el negocio serán también oportunidades de nuevos contratos de desarrollo.

  • Es fundamental utilizar herramientas, frameworks, diseños de código, etc. que permitan introducir cambios fácilmente en la aplicación.
  • También es básico diseñar y ejecutar tests de los distintos módulos y funcionalidades del producto conforme se va desarrollando. De esta forma tenemos una red de seguridad con la que asegurarnos de que los nuevos cambios no rompan ninguna funcionalidad ya introducida. Esto es lo que se denomina regression testing.

  • ¿Cuánto de corta debe ser una iteración? 2 o 3 semanas es una cantidad de tiempo razonable.
  • La iteración es importante para definir una cadencia de hitos (por ejemplo, reuniones con el cliente para hacer demostraciones), pero es tan importante o más que el flujo de trabajo permita introducir funcionales nuevas de forma continua. Veremos que Kanban refuerza más este concepto de flujo continuo.
  • En inglés se habla siempre de features para referirse a elementos de la aplicación que el proporcionan valor al usuario. Nosotros traduciremos el término por característica o funcionalidad. Frente a estos términos, el término de requisito no es demasiado apropiado en un marco moderno de metodologías ágiles, es más propio de modelos antiguos de desarrollo en cascada.

  • Los veremos con más detalle la semana que viene, cuando hablemos del manifiesto ágil y de lean.

  • Cuando realizamos un desarrollo incremental hay que incluir en cada incremento todas las capas de la aplicación (acceso a datos, lógica de negocio, presentación) para que el cliente pueda comprobar la aplicación. La capa de presentación puede no estar terminada, o ser sólo un prototipo, pero debe funcionar correctamente, tal y como funcionará el producto final.
  • Debemos intentar siempre descomponer una funcionalidad grande en varias sub-funcionalidades más pequeñas. Pero todas ellas deben tener todas las capas de la aplicación.
  • La gráfica es muy buena: indica cómo va creciendo el valor del producto dependiendo del tamaño de las funcionalidades. Además las funcionalidades que aportan mayor valor deberían introducirse al principio del desarrollo, dejando para el final las funcionalidades menos valiosas (ajustes de interfaces de usuario, características para usuarios avanzados, etc.)

  • El concepto de Producto Mínimo Viable (MVP, Minimum Viable Product) tiene su origen en la necesidad de las startups de lanzar muy rápido algo con lo que poder captar usuarios (e inversores).
  • Es uno de los elementos de la propuesta de Eric Ries para aplicar la filosofía lean a las startups denominada lean startup methodology.

  • No existe ninguna bala de plata (silver bullet) que de la respuesta mágica al desarrollo de software (artículo de Brooks: No Silver Bullet).

  • La entrega continua es la respuesta a las prácticas tradicionales en las que la integración y el despliegue se hace al final de todo el proceso de desarrollo, de forma manual y costosa.
  • Muy importante las nuevas herramientas y tecnologías: Git, Docker, Cloud.
  • Hablaremos de que el continuous delivery es un paso más allá de la propuesta de integración continua en la que todas las noches un servidor de integración continua lanza automáticamente los tests sobre la rama de desarrollo y saltan las alarmas si no se pasan todos los tests.
  • Muchas de estas ideas vienen del desarrollo de software open source, en el que múltiples desarrolladores colaboran de forma remota para lanzar releases coherentes y sin fallos de productos de gran complejidad (el desarrollo de Linux es un de los ejemplos principales). Ver, por ejemplo, el documento Understanding the Open Source Development Model de Ibrahim Haddad en 2011.

  • Buen diseño: código modificable, testable, clases pequeñas (responsabilidad única), minimizar dependencias, uso de abstracciones, encapsulación, etc. Todo lo que hemos aprendido en la carrera. Pero cuidado con la sobreingeniería: un defecto tan malo como el de escribir mal código es escribir código demasiado general con la excusa de que así podemos cambiar cualquier cosa. Muchas veces ese código es más difícil de entender, tarda más en escribirse y en escribir sus tests y termina siendo más complicado de modificar.

  • Para que las metodologías ágiles funcionen es necesario una base técnica importante. Es muy recomendable el post de Luis Artola (@artolamola en Twitter): Lo que los gurús nunca te cuentan sobre Kanban y SCRUM.

  • Las gráficas la evolución de cuatro métricas respecto al tiempo de desarrollo de un proyecto en metodologías tradicionales (cascada) y ágiles:
    • Coste de la introducción de cambios en el proyecto
    • Valor entregado
    • Transparencia y participación del cliente
    • Intensidad de trabajo y estrés

  • En España cada vez más empresas están introduciendo estas metodologías. Sobre todo empresas nuevas y startups. En la diapositiva mostramos algunas startups y empresas de desarrollo de software españolas relevantes:
  • Cada vez más asistencia a eventos como la Conferencia Agile Spain (vídeo resumen CAS 2017). Este año la CAS 2018 se celebra en Alicante.

Enlaces de la bibliografía: