200 likes | 397 Views
Test Driven Development. Técnicas de Diseño Facultad de Ingeniería Universidad de Buenos Aires. Agenda. Qué es TDD? Diseño Simple Refactoring El proceso de TDD Ejemplo Herramientas. Agenda. Qué es TDD? Diseño Simple Refactoring El proceso de TDD Ejemplo Herramientas. Qué es TDD?.
E N D
Test Driven Development Técnicas de Diseño Facultad de Ingeniería Universidad de Buenos Aires
Agenda • Qué es TDD? • Diseño Simple • Refactoring • El proceso de TDD • Ejemplo • Herramientas
Agenda • Qué es TDD? • Diseño Simple • Refactoring • El proceso de TDD • Ejemplo • Herramientas
Qué es TDD? • Proceso iterativo en el cual el desarrollo está guiado por los test. • Los tests representan los requerimientos que nuestro código busca satisfacer. • Primero escribimos los test que expresan los requerimientos a cumplir luego desarrollamos para cumplir con dichos requerimientos.
Qué es TDD? Dos reglas importantes: • Nunca escribir una línea de código a menos que tengamos un test fallando. Los tests representan los requerimientos que el código debe satisfacer, si no hay requerimiento es porque no hay nada que implementar. • Eliminar duplicación de código.
Agenda • Qué es TDD? • Diseño Simple • Refactoring • El proceso de TDD • Ejemplo • Herramientas
Diseño Simple • Nuestro código debe satisfacer los requerimientos (tests) ni menos ni más. • Si no escribimos el código necesario para satisfacer los requerimientos no estamos cumpliendo con lo solicitado, si escribimos de más agregamos complejidad innecesaria que luego hay que mantener.
Diseño Simple • Guías para lograr ni menos ni más: • El código es apropiado para quien está dirigido. • El código pasa todos los tests. • El código comunica todo lo necesario. • El código tiene la menor cantidad de clases. • El código tiene la menor cantidad de métodos.
Agenda • Qué es TDD? • Diseño Simple • Refactoring • El proceso de TDD • Ejemplo • Herramientas
Refactoring • Proceso que permite mejorar el código existente sin cambiar su funcionalidad externa. • Esencial para TDD porque es necesario refinar el diseño del código escrito a medida que agregamos tests.
Agenda • Qué es TDD? • Diseño Simple • Refactoring • El proceso de TDD • Ejemplo • Herramientas
El proceso de TDD • Armar una lista de tests. Esto permite describir los requerimientos de forma no ambigua e indicar el scope de los mismos. • Red • Green • Refactor • El proceso se debe realizar en pasos pequeños lo que permite determinar rápidamente donde cometimos un error en caso de hacerlo.
El proceso de TDD • Escribir el código asociado a un test. • Compilar el código asociado al test. (no compila porque aún no se ha implementado) • Implementar sólo lo suficiente para que el código escrito compile. • Correr el test y ver si falla. • Implementar sólo lo suficiente para que el test pase. • Correr el test y ver que efectivamente pasa. • Refactorizar para aclarar y eliminar duplicación. • Repetir con todos los tests de la lista.
Agenda • Qué es TDD? • Diseño Simple • Refactoring • El proceso de TDD • Ejemplo • Herramientas
Agenda • Qué es TDD? • Diseño Simple • Refactoring • El proceso de TDD • Ejemplo • Herramientas
Herramientas • xUnit (JUnit, NUnit, DbUnit, HttpUnit, etc.) • Easy Mock • JMock • TestNG • Selenium