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