


Alex Fernández
Ingeniero senior en mediasmart
Co-organizador de Node.js Madrid

Pruebas unitarias
Pruebas de integración / de sistemas
Pruebas de carga
Pruebas automáticas: ¡las mejores!
No basta con correr el código y ver el resultado
Requieren una librería especial
Uses global functions
BDD-style programming
Sample:
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 un objeto
function Client(params) {
...
}
Añadir una función al prototipo
Client.prototype.get = function(params) {
...
};
Hacer pruebas del cliente:

Añadir un comando quit:
client.quit(callback);
Arrancar y parar el servidor con una API de control

npm install
: instala un paquete (o varios)
npm install -g
: instalación global
npm update
: actualiza un paquete (o varios)
npm remove
: elimina un paquete
npm test
: corre los tests del paquete
Fuente:
npm Dcoumentation
Local:
node_modules
../node_modules
../../node_modules
...
$HOME/node_modules
./node_modules
Global:
{prefix}/lib/node_modules
donde {prefix} normalmente es /usr/local
Fuente:
npm-folders
Queremos usar el paquete simplecached
Instalación:
npm install simplecached
Importación con require:
var simplecached = require('simplecached');
simplecached
Importación con require:
var simplecached = require('simplecached');var server = new simplecached.Server(port); var client = new simplecached.Client(port); client.set(key, value, function(error) {}); client.get(key, function(error, value) {});
npm install sin parámetros
npm list para ver lo que tienes instalado
npm update sin parámetros
npm remove simplecached
npm list
Fichero léeme: README.md
Definición: package.json
Punto de entrada: index.js
Código: lib/
Documentación: doc/
Binarios: bin/
{
"name": "simplecached",
"version": "0.0.1",
"description": "Simplified memcached server.",
"contributors": ["Alex Fernández "],
"license": "MIT",
"repository": {
"type": "git",
"url": "https://github.com/alexfernandez/simplecached"
},
"dependencies": {
"testing": "0.1.x"
},
"keywords" : ["simplecached", "didactic", "memcached", "caching"],
"bin": {
"simplecached": "bin/server.js"
},
"scripts": {
"test": "node test.js"
},
}
Fuente:
package.json
Fuente:
package.json dependencies,
semver
Mueve todo a su sitio:
Crea index.js que requiere el resto
Nombre y descripción
Autor(es)
Depende de simplecached
npm install sin parámetros
npm list para ver lo que tienes instalado
npm publish
¡Y ahora bórralo! con
npm unpublish --force

Crea un script en bin/test.js
Corre las pruebas en el script
Añade el script al package.json
Corre el script con npm test
