Slide 1

Slide 1 text

Unit Testing Unit Testing

Slide 2

Slide 2 text

Federico Lozada Mosto http://www.mostofreddy.com.ar @mostofreddy @mostofreddy @federicolozadamosto

Slide 3

Slide 3 text

Una prueba unitaria es una forma de probar el correcto funcionamiento de una unidad funcional de forma aislada. Esto sirve para asegurar que cada unidad funcione correctamente.

Slide 4

Slide 4 text

Características

Slide 5

Slide 5 text

Automatizable Deben poder ejecutarse de forma automática sin intervención manual Predecible Deben devolver el mismo resultado sin importar la cantidad de veces que se corran Enfocada Cada test se debe estar enfocado a una unidad funcional

Slide 6

Slide 6 text

Ejecución rápida Deben ejecutarse rápidamente Aisladas/independiente No deben afectar a otro test, unidada funcional ni acceder a recursos del sistema Desarrollo rápido Simples y fáciles de desarrollar Profesional Debe ser código como si fuera producción

Slide 7

Slide 7 text

Ventajas

Slide 8

Slide 8 text

Mejora la calidad del código y su arquitectura Facilita la refactorización Documenta el código Detecta bugs tempranamente Ayuda a tener un código mas desacoplado Simplifica la integración entre sistemas

Slide 9

Slide 9 text

Excusas

Slide 10

Slide 10 text

El código es fácil de testear El test no forma parte del desarrollo Los desarrolladores no quieren escribir los test Cuesta mucho tiempo hacer los test Testing es para QA

Slide 11

Slide 11 text

Estructura de un test

Slide 12

Slide 12 text

Arrange: Es la parte del test donde se configura e inicializa el test unitario Act Es la parte donde se ejecuta el código de la prueba unitaria Assert Es la parte donde se prueba el resultado del test unitario

Slide 13

Slide 13 text

Técnicas para hacer nuestro código más testeable There is no secret to writing tests… … there are only secrets to writing testable code! by Misko Hevery

Slide 14

Slide 14 text

Programar orientado a interfaces Usar la ley de Demeter y los principios SOLID Definir la correcta responsabilidad en cada clase y método Evitar métodos largos Aislar dependencias y utilizar Inversión de Control No realizar tareas en el método constructor Preferir la dependencia ante la herencia Evitar el patrón Singleton

Slide 15

Slide 15 text

Buenas prácticas

Slide 16

Slide 16 text

Cada test debe ser independiente al resto Un test debe probar solo una unidad lógica Debe haber un solo assert por test Nombre descriptivo Implementar test dobles para las dependencias

Slide 17

Slide 17 text

Mocks & test doubles

Slide 18

Slide 18 text

Sometimes it is just plain hard to test the system under test (SUT) because it depends on other components that cannot be used in the test environment. This could be because they aren't available, they will not return the results needed for the test or because executing them would have undesirable side effects. In other cases, our test strategy requires us to have more control or visibility of the internal behavior of the SUT. When we are writing a test in which we cannot (or chose not to) use a real depended-on component (DOC), we can replace it with a Test Double. The Test Double doesn't have to behave exactly like the real DOC; it merely has to provide the same API as the real one so that the SUT thinks it is the real one! – Gerard Meszaros

Slide 19

Slide 19 text

Mock: Un mock de una interfaz nos sirve para confirmar que los métodos de la interfaz se han llamado correctamente durante la ejecución del test. Stub Reemplaza/simula una dependencia a una clase/módulo. El test tiene el control sobre el Stub y puede predefinir valores de respuesta. Fake Clase programada para generar objetos que aparentan un funcionamiento correcto.

Slide 20

Slide 20 text

Dummy: Objetos usados para rellenar o ser pasados por parámetro. De implementación pueden estar vacíos, ya que no van a ser usados directamente. Spy Stub pero además de cumplir su función, almacena información como los métodos llamados.

Slide 21

Slide 21 text

Herramientas

Slide 22

Slide 22 text

PHP ............................. phpunit Java ............................... JUnit Net ................................ NUnit Smalltalk ................. Sunit Python ..................... PyUnit Ruby ....................... Test::Unit

Slide 23

Slide 23 text

¿Preguntas?

Slide 24

Slide 24 text

@mostofreddy @mostofreddy @federicolozadamosto Federico Lozada Mosto http://www.mostofreddy.com.ar