2012-01-26 18 views
5

Estoy tratando de entrar en pruebas unitarias con NUnit. Por el momento, estoy escribiendo una prueba simple para acostumbrarme a la sintaxis y la forma de probar la unidad. Pero no estoy seguro si lo estoy haciendo bien con la siguiente prueba:¿Es una buena forma de prueba unitaria utilizar otra función probada para hacer los preparativos para la prueba real?

La clase en prueba contiene una lista de cadenas que contienen nombres de fruta, donde se pueden agregar nuevos nombres de frutas a través del class_under_test.addNewFruit(...). Entonces, para probar la funcionalidad de addNewFruit(...), primero uso el método para agregar una nueva cadena a la lista (por ejemplo, "Piña") y, en el siguiente paso, verifico si la lista contiene esta nueva cadena.

No estoy seguro si esta es una buena manera de probar la funcionalidad del método, porque confío en la respuesta de otra función (que ya he probado en una prueba de unidad anterior).

¿Es esta la manera de probar esta función, o hay mejores soluciones?

public void addNewFruit_validNewFruitName_ReturnsFalse() 
{ 
    //arrange 
    string newFruit = "Pineapple"; 

    //act 
    class_under_test.addNewFruit(newFruit); 
    bool result = class_under_test.isInFruitList(newFruit); 

    //assert 
    Assert.That(!result); 
} 

Respuesta

7

En un mundo perfecto, cada prueba de unidad solo puede romperse de una sola manera. Cada prueba unitaria "vive" aisladamente la una de la otra. Su prueba addNewFruit puede romperse rompiendo isInFruitsList - pero afortunadamente, este tampoco es un mundo perfecto.

Dado que ya ha probado el método isInFruitsList, no debe preocuparse por eso. Es como utilizar API de terceros: se prueba (generalmente) y supone que funciona. En su caso, usted asume que isInFruitsList funciona porque, bueno, lo probó.

La vuelta al "roto en un solo camino" usted podría tratar de exponer a la lista de frutas que subyace internamente (y utilizar InternalsVisibleTo atributo), o pasándolo a través de la inyección de dependencia. La pregunta es: ¿vale la pena el esfuerzo? ¿Qué ganas realmente? En un caso tan simple, generalmente se gana muy poco y la sobrecarga de la introducción de dichos constructos generalmente no vale la pena.

+2

Absolutamente ... si todas las combinaciones de pruebas son InFruitsList son buenas, y ellas son las autoras de ese código, entonces debería ser confiable para otras pruebas ... Así como "confiamos" en C# y NUnit ... – DRapp

+2

Está bien. Siempre debe encontrar el equilibrio entre escribir muy pocas/pruebas demasiado generales y sumergirse en la prueba de si 'int a = 5' en realidad asigna valor. Siempre es más sensato suponer que CLR, el código de terceros y el código probado funciona, que volverse paranoico y probar todo lo que se mueve. –

+0

¡Gracias a los dos! Me siento mucho más seguro ahora, sabiendo que se "permite" confiar en mis propias pruebas. – DIF

Cuestiones relacionadas