Una Prueba Unitaria, es una forma de comprobar que nuestro código, hace lo que se supone debe hacer; es decir, se asegura que muestro código no presente fallos, errores, o cálculos inesperados, y que siempre retorne el valor correcto. Cada lenguaje de programación cuenta con sus propias herramientas para realizar estas pruebas, en el caso de java, tenemos a JUnit (creado por Erich Gamma y Kent Beck).
En este post realizaremos un test a un método que estudiamos en un post anterior [Caja blanca: Prueba del camino básico] .
Necesitamos:
Paso 1: Instalación del Plugin JacoCoverage
JaCoCoverage es un complemento que funciona como un servicio adicional a JUnit, colorea todos los archivos java según la información de cobertura de las pruebas de unidad. Esto nos permite identificar más fácilmente los caminos en nuestro código que no se cumplen.
Web del plugin: https://github.com/jonathanlermitage/tikione-jacocoverage
Para instalar este plugin en Netbeans debemos:
– Abrir el menú -> Herramientas -> plugins. Seleccionar la pestaña Plugins disponibles.
– Buscar y seleccionar TikiOne JaCoCoverage, instalar.
– Nos pedirá reiniciar el IDE, hazlo.
Paso 2: El proyecto
Creamos un proyecto que llamaremos «Prueba de Cobertura», agregamos un paquete «example» y las librerías arriba mencionadas. Para finalizar, creamos una clase «Miclase.java«.
Paso 3. El código
El código que probaremos, lo estudiamos en un post anterior [LINK] donde realizamos una prueba manual del algoritmo. El algoritmo corresponde al problema de detectar el numero mayor dados tres números.
Pasamos del algoritmo a código y tenemos:
package example;
/**
* @see https://www.jc-mouse.net/
* @author mouse
*/
public class MiClase {
public int numero_mayor(int a, int b, int c) {
if (a > b && a > c) {
return a;
} else if (c > b) {
return c;
} else {
return b;
}
}
}
Paso 4: Paquete de Prueba
Ya que tenemos nuestra clase de prueba lista, procedemos a crear las clases de prueba. Clic derecho sobre nuestro proyecto -> New -> Other… En Categoría seleccionamos «Unit Tests» y en File Types, seleccionamos «Test for Existing Class» y presionamos el botón siguiente.
A continuación, presionando el botón «browse…» buscamos y seleccionamos la clase que testearemos, «Miclase«, dejamos todas las opciones tal cual están y finalizamos presionando el botón «Terminar».
Se creara otra clase en la sección de «Paquete de prueba» como se ve a continuación
Paso 5: JUnit
Antes de realizar la prueba con JUnit, debemos estudiar un poco el código generado. En la parte inferior de la clase MiClaseTest encontramos el siguiente método:
@Test
public void testNumero_mayor() {
System.out.println("numero_mayor");
int a = 0;
int b = 0;
int c = 0;
MiClase instance = new MiClase();
int expResult = 0;
int result = instance.numero_mayor(a, b, c);
assertEquals(expResult, result);
// TODO review the generated test code and remove the default call to fail.
fail("The test case is a prototype.");
}
donde:
1) @Test: Los métodos marcados con esta anotación, le indican a JUnit que es código que queremos que se ejecute. Son estos métodos donde se implementan el código de pruebas.
4,5,6) Las variables del método que probaremos
7) Instancia a nuestra de prueba
8) El resultado que esperamos obtener si la prueba tiene exito
9) la llamada al método de prueba, el resultado se almacena en otra variable
10) assertEquals: Es uno de varios métodos con los que cuenta JUnit, este método en particular compara si dos objetos son iguales, de no ser así, lanzará una excepción y la prueba se detiene.
12) fail: Este método hace que la prueba termine con fallo
Como vimos en un post anterior [Caja blanca: Prueba del camino básico], este algoritmo consta de 4 caminos posibles, eso quiere decir que debemos implementar 4 métodos de prueba.
Partiendo como base el método de prueba arriba mencionado, creamos 4 métodos con sus respectivos valores de entrada y valores esperados, es decir:
@Test
public void testNumero_mayor_caso1() {
int a = 5;
int b = 3;
int c = 7;
MiClase instance = new MiClase();
int expResult = 7;
int result = instance.numero_mayor(a, b, c);
assertEquals(expResult, result);
}
@Test
public void testNumero_mayor_caso2() {
int a = 5;
int b = 3;
int c = 4;
MiClase instance = new MiClase();
int expResult = 5;
int result = instance.numero_mayor(a, b, c);
assertEquals(expResult, result);
}
@Test
public void testNumero_mayor_caso3() {
int a = 5;
int b = 7;
int c = 6;
MiClase instance = new MiClase();
int expResult = 7;
int result = instance.numero_mayor(a, b, c);
assertEquals(expResult, result);
}
@Test
public void testNumero_mayor_caso4() {
int a = 5;
int b = 7;
int c = 9;
MiClase instance = new MiClase();
int expResult = 9;
int result = instance.numero_mayor(a, b, c);
assertEquals(expResult, result);
}
Para ejecutar el test con JUnit, clic derecho sobre la clase MiClaseTest.java -> run file
Observamos que pasamos las 4 pruebas con éxito.
Si tuviésemos algún error, este aparecería en color rojo.
Paso 6. JaCoCoverage
Como mencionamos en un principio, este plugin nos permite ver más a detalle lo que pasa con el código y los caminos que este toma. Para ejecutarlo, clic derecho sobre el proyecto -> Test with JaCoCoverage. Se abrirá una pagina en el navegador que tengamos configurado por defecto.
En esta pagina, el plugin nos brinda información importante sobre el test realizado, ademas podemos navegar por las diferentes clases que cuenta nuestro proyecto. En nuestro ejemplo pasamos todas las pruebas por lo que el código se colorea de verde.
Para observar mejor este plugin, provoquemos un error a propósito. Comentemos el método testNumero_mayor3() que corresponde al camino 3 que nos dice que el numero mayor esperado de «a»,»b» y «c», es «b» . Volvamos a ejecutar el plugin.
Observamos que ahora marca en rojo el camino que no se cumplió.
enjoy!!!
Lo que veremos en este post es la configuración del driver para PHP de SQL Server que ha creado Microsoft el cual permit[...]
Instagram es una red social y aplicación para subir fotos y videos. Sus usuarios también pueden aplicar efectos fotográf[...]
Desarrolle un programa en consola con un menú para el usuario que permita agregar elementos a una pila, eliminar element[...]
Java Printing nos permite hacer uso de las impresoras del sistema para, valga la redundancia 🙂 imprimir los gráficos de[...]
En este post crearemos un botón swing que reproducirá un sonido cuando este sea presionado por el usuario. Sin mas[...]
Cuando desarrollamos aplicaciones para android como programadores nos interesa la velocidad al tiempo de depurar el códi[...]