TDD - (Spanish)

9
Test-Driven Development(TDD) twitter: @trukuxzo

description

Test-Driven Development

Transcript of TDD - (Spanish)

Page 1: TDD - (Spanish)

Test-Driven Development(TDD)

twitter: @trukuxzo

Page 2: TDD - (Spanish)

Test-Driven Development(TDD)

• Una metodología en la que primero se hace un test y luego el código necesario para que el test pase.

• Para escribir las pruebas generalmente se utilizan las pruebas unitarias.

• En primer lugar se escribe una prueba y se verifica que las pruebas fallen, luego se implementa el código que haga que la prueba pase satisfactoriamente y seguidamente se refactoriza el código escrito.

• La idea es que los requisitos sean traducidos a pruebas, de este modo, cuando las pruebas pasen se garantizará que los requisitos se hayan implementado correctamente.

Page 3: TDD - (Spanish)

TDD = Test-First Development + Refactoring

Realizar los cambios

Verificar si el test falla

(Re)Escribir un test

Ejecutar los tests

[Pasa]

[Falla]

[Falla]

[Pasa, continúa desarrollo]

[Pasa, finaliza desarrollo]

TDD involucra otras dos prácticas:

• Test-First Development(TFD) y

• Refactoring.

Page 4: TDD - (Spanish)

El lema del TDD “Rojo, Verde, Refactor"

Crear una prueba y hacer que falle

Escribir el mínimo código para hacer pasar la prueba.

Cambiar el código para eliminar la duplicación y para mejorar el diseño al tiempo que se garantice que todas las

pruebas anteriores pasen el test.

Page 5: TDD - (Spanish)

Características

• Una ventaja de esta forma de programación es el evitar escribir código innecesario ("You Ain't Gonna Need It" (YAGNI)).

• Se intenta escribir el mínimo código posible, y si el código pasa una prueba aunque sepamos que es incorrecto nos da una idea de que tenemos que modificar nuestra lista de requerimientos agregando uno nuevo.

• La generación de pruebas para cada funcionalidad hace que el programador confíe en el código escrito.

• Otra característica del TDD es que requiere que el programador primero haga fallar los casos de prueba. La idea es asegurarse de que los casos de prueba realmente funcionen y puedan recoger un error.

Page 6: TDD - (Spanish)

Ventajas

• Cuando se utiliza el TDD en un proyecto virgen se encuentra que en raras ocasiones se tiene la necesidad de utilizar el depurador o debugger.

• El desarrollo con TDD puede proporcionar un gran valor añadido en la creación de software, produciendo aplicaciones de más calidad y en menos tiempo.

• El poder del TDD radica en la capacidad de avanzar en pequeños pasos cuando se necesita.

• Inicialmente no se consideran los casos excepcionales y el manejo de errores. Estos, se implementan después de que se haya alcanzado la funcionalidad principal.

• Otra ventaja es que, cuando es utilizada correctamente, se asegura de que todo el código escrito está cubierto por una prueba.

Page 7: TDD - (Spanish)

Limitaciones

Resulta complejo en los siguientes dominios:

– Interfaces Gráfica de usuario (GUIs), aunque hay soluciones parciales propuestas.

– Objetos distribuidos, aunque los objetos simulados (MockObjects) pueden ayudar.

– Bases de datos. Hacer pruebas de código que trabaja con base de datos es complejo porque requiere poner en la base de datos unos datos conocidos antes de hacer las pruebas y verificar que el contenido de la base de datos es el esperado después de la prueba.

Page 8: TDD - (Spanish)

Conclusión

Test-Driven Development(TDD) es una técnica avanzada que utiliza las pruebas unitarias para impulsar el diseño de software.

El propósito del Test-Driven Development(TDD) es lograr un código limpio que funcione.

Page 9: TDD - (Spanish)

Fin