Alex Fernández
Ingeniero senior en LogTrust
Co-organizador de Node.js Madrid
Pruebas unitarias
Pruebas de integración / de sistemas
Pruebas de carga
Pruebas automáticas: ¡las mejores!
and, of course, testing
No basta con correr el código y ver el resultado
Requieren una librería especial
Se envía el éxito o fracaso a una callback
Estilo BDD (behaviour driven development)
Ejemplo:
describe('User', function() {
describe('#save()', function() {
it('should save without error', function(done) {
var user = new User('Luna');
user.save(function(err) {
if (err) done(err);
else done();
});
});
});
});
No usa globales
No muy extendida
Más didáctica (¡espero!)
Documentación: testing
Comprobar que la función getFiveAsync()
no da error
Comprobar que devuelve el valor 5
Función que envía 5 a la callback
inmediatamente pero asíncrono
function getFiveAsync(callback) {
setImmediate(function() {
callback(null, 5);
});
}
setImmediate(callback, args...)
Llama a la callback después de los eventos de I/O
y antes de setTimeout()
y setInterval()
testing.run([test function], callback);
testing.success("Well done!", callback);
Comprueba que el valor pasado sea igual al esperado
testing.equals([value], [expected], message, callback);
testing.check(error, "There is an error", callback);
Fuente: testing
Cambiar la función para que devuelva otro valor
Devolver un error desde la función
Cambiar el valor esperado a cuatro
Diseña una API de control
Arranca y para el sistema usando la API
Tests auto-contenidos: limpia al terminar
Un solo botón
Haz los fallos visibles
Sin intervención manual
Crear un cliente de simplecached
Implementar get(), set(), delete()
Hacer pruebas con testing
var client = new Client(host, port);
Crea un nuevo cliente
client.connect(callback);
Conecta al servidor simplecached
client.get(key, (error, value) => ...);
Obtiene un valor, o
null
si no existe
client.set(key, value, callback);
Añade un valor para una clave
client.delete(key, callback);
Borra una clave existentenet.connect(port, host, listener)
Escuchar un evento una única vez
emitter.once(name, listener)
Crear una clase
class Client {
constructor(params) {
...
}
get(key, callback) {
...
}
}
Hacer pruebas del cliente:
Añadir un comando quit:
client.quit(callback);