¿Qué es ObjectMother y cuáles son los escenarios de uso común para este patrón?¿Qué es una ObjectMother?
Respuesta
ObjectMother comienza con el patrón de fábrica, entregando objetos prefabricados listos para prueba a través de una simple llamada a un método. Se mueve más allá del ámbito de la fábrica por facilitando la personalización de objetos creados, proporcionando métodos para actualizar los objetos durante las pruebas, y si es necesario, eliminando el objeto de la base de datos al finalizar la prueba.
Algunas razones para utilizar ObjectMother:
* Reducir la duplicación de código en las pruebas, el aumento de capacidad de mantenimiento de prueba
* Hacer prueba de objetos súper fácil acceso, alentando a los desarrolladores escribir más pruebas.
* Todas las pruebas se ejecutan con datos nuevos.
* Las pruebas siempre se limpian después de ellas.
Me pregunto, ¿hay un nombre alternativo para "Object Mother"? Tal vez 'TestDataProvider', o algo así? – vikingsteve
Ver "Test Data Builders: an alternative to the Object Mother pattern" para un argumento de por qué utilizar un constructor de datos de prueba en lugar de un objeto Madre. Explica lo que ambos son.
Como se indica en otra parte, ObjectMother es una fábrica para generar objetos normalmente (¿exclusivamente?) para usar en pruebas unitarias.
Donde son de gran utilidad es para generar objetos complejos donde los datos no son de particular importancia para la prueba.
donde es posible que haya creado una instancia vacía bajo como
Order rubishOrder = new Order("NoPropertiesSet");
_orderProcessor.Process(rubishOrder);
que usaría una sensata desde el ObjectMother
Order motherOrder = ObjectMother.SimpleOrder();
_orderProcessor.Process(motherOrder);
Esto tiende a ayudar con situaciones en las que la clase está probando aperturas confiar en que se pase un objeto sensible.
Por ejemplo, si agregó alguna validación de OrderNumber a la clase de orden anterior, simplemente necesitaría para crear una instancia del OrderNumber en la clase SimpleObject para que pasen todas las pruebas existentes, dejándote concentrado en escribir las pruebas de validación.
Si acaba de crear una instancia del objeto en la prueba, deberá agregarlo a cada prueba (es impactante la frecuencia con la que he visto a gente hacer esto).
Por supuesto, esto solo podría extraerse a un método, pero ponerlo en una clase separada permite que se comparta entre varias clases de prueba.
Otro comportamiento recomendado es utilizar buenos nombres descriptivos para sus métodos, para promover la reutilización. Es muy fácil terminar con un objeto por prueba, que definitivamente debe evitarse. Es mejor generar objetos que representen atributos generales que específicos y personalizarlos para su prueba. Por ejemplo, ObjectMother.WealthyCustomer() en lugar de ObjectMother.CustomerWith1MdollarsSharesInBigPharmaAndDrivesAPorsche() y ObjectMother.CustomerWith1MdollarsSharesInBigPharmaAndDrivesAPorscheAndAFerrari()
- 1. ¿Qué es una corrutina?
- 2. ¿Qué es una corriente?
- 3. ¿Qué es una subclase
- 4. ¿Qué es una proyección?
- 5. ¿Qué es una unión?
- 6. ¿Qué es una "Unidad"?
- 7. ¿Qué es y qué no es una historia de usuario?
- 8. ¿Qué es una interfaz fluida?
- 9. ¿Qué es una actualización http?
- 10. ¿Qué es una consulta ilimitada?
- 11. MySQL: ¿Qué es una página?
- 12. BDD, ¿qué es una función?
- 13. ¿Qué es una pila LAMP?
- 14. C++: ¿Qué es una secuencia
- 15. ¿Qué es una gema Ruby?
- 16. ¿Qué es una instrucción JVM?
- 17. ¿Qué es una matriz dentada?
- 18. ¿Qué es una clase parcial?
- 19. ¿Qué es una clave "opaca"?
- 20. ¿Qué es una API "conectable"?
- 21. ¿Qué es una actualización destructiva?
- 22. ¿Qué es exactamente una "Consola"?
- 23. ¿Qué es exactamente una ROM?
- 24. ¿Qué es una interfaz privada?
- 25. ¿Qué es una implementación concreta?
- 26. ¿Qué es una emisión fija?
- 27. ¿Qué es una colección java?
- 28. ¿Qué es una "transacción distribuida"?
- 29. ¿Qué es una instrucción privilegiada?
- 30. ¿Qué es una pestaña vertical?
Le hubiese votado esta vez si pudiera (le doy crédito por adaptar mis comentarios), pero dice que mi voto se bloqueó. ¡Si arreglas tu sitio web, lo haré! – area5one