Común problema de desarrollo software

Solución

Test Driven Development

Una práctica de desarrollo software que se basa en escribir las pruebas primero y luego refactorizar. En primer lugar, se escribe una prueba y se verifica que las pruebas fallan. A continuación, se implementa el código que hace que la prueba pase satisfactoriamente. Una vez pase la prueba unitaria refactorizamos y volvemos a repetir el ciclo.

  1. Elegir un requisito
  2. Escribir una prueba
  3. Verificar que la prueba falla
  4. Escribir la implementación
  5. Ejecutar las pruebas automatizadas
  6. Eliminación de duplicación
  7. Actualización de la lista de requisitos

Behauvior Driven Development

(Behavior-Driven Development - BDD) deriva de TDD, y combina los principios de domain-driven design con ideas del uso de un lenguaje común (domain-specific language - DSL) para elaborar el testing. Utiliza sintaxis como Given, When, Then para expresar el comportamiento y salida esperada. Las pruebas se escriben usando historia de usuario, el que ya esta escrito en un documento dedicado. Un problema común de TDD es el test depende de la implementation la función. En BDD afrontamos este problema en testear el comportamiento de la función sin tener en cuenta la detalle de su implementación.

Especificaciones del comportamiento

El comportamiento deseado deber ser especificado por el DSL(Domain-Specific-Language) por ejmplo Gherkin, que usa 5 sentencias

Fuature: Un título claro y explícito de la historia
Una pequeña sección de introducción que especifique

Criterios de aceptación o escenarios
Scenario: Una descripción de un ejemplo específico de la feature

Acceptance Test Driven Development

Es una práctica en la que todo el equipo analiza y determina de forma colaborativa los criterios ejemplificativos de aceptación, y son divididos en un conjunto de pruebas antes de comenzar el desarrollo.

Diferencia

Diferencia ATDD TDD BDD
Colaboradores Cliente Desarrollador y Tester ATDD + TDD
Objetivo Participa los usuarios en la fase de diseño Una practica de desarrollo Unit tester y negocio con un lenguaje común
Documento Criterio de aceptación ejemplificativos Documento de requisito documento escrito en lenguaje Gherkin
Automatización No es necesario necesario necesario
Testing Cada historia de usuario Cada funcionalidad Cada historia de usuario